2014-03-29 311 views
0

我有脚本将写入信息到数据库,但我怎么能让它从数据库打印变量“时间”后,它更新基于输入的电子邮件写入相同的查询数据库?这是用于JSON。读取和写入SQL数据库

<?php 
if(!empty($_POST)) 
{ 
$dbhost = 'localhost'; 


$dbuser = 'casaange_testapp'; 
$dbpass = 'testapp1'; 
$conn = mysql_connect($dbhost, $dbuser, $dbpass); 
if(! $conn) 
{ 
    die('Could not connect: ' . mysql_error()); 
} 
mysql_select_db('casaange_volunteertest'); 
$email= $_POST['email']; 
$time= $_POST['time']; 

$sql = "UPDATE users SET time= '$time' WHERE email = '$email'"; 



$retval = mysql_query($sql, $conn); 
if(! $retval) 
{ 
    die('Could not update data: ' . mysql_error()); 
} 

if($retval){ 
$response["success"] = 1; 
$response["message"] = "Update successful!"; 
die(json_encode($response)); 
} 

//echo '{"success":1, "message":"Time added!"}'; 
mysql_close($conn); 
} 
else 
{ 
?> 
<form method="post" action="timeinsert.php"> 
<table width="400" border="0" cellspacing="1" cellpadding="2"> 
<tr> 
<td width="100">Email:</td> 
<td><input name="email" type="text" id="email"></td> 
</tr> 
<tr> 
<td width="100">Time:</td> 
<td><input name="time" type="text" id="time"></td> 
</tr> 
<tr> 
<td width="100"> </td> 
<td> </td> 
</tr> 
<tr> 
<td width="100"> </td> 
<td> 
<input name="update" type="submit" id="update" value="Update"> 
</td> 
</tr> 
</table> 
</form> 
<?php 
} 
?> 
</body> 
</html> 

回答

0

我想你想知道的是UPDATE查询是否实际上改变了数据库中的值?

您可以使用mysql_affected_rows()看到有多少行改变您的查询的结果 - 在你的情况下,将1或0。

如果您需要返回您刚刚放入数据库的时间,您可以通过选择以电子邮件地址作为关键字来查询实际进入数据库的值。

一些有关您的代码一般观察,如果可以的话:

  • 把它变成一个SQL查询 像之前必须转义POST数据。充其量,它将成为错误的来源,最糟糕的是一个巨大的安全漏洞。

  • 如果您正在编写新代码,您应该考虑使用较新的MySQLi或PDO_MySQL扩展而不是旧的MySQL调用 。

  • 您可以使用json_encode将关联的PHP数组转换为JSON 对象,而不是自己构建JSON字符串。

+0

你可以举一个如何返回数据库中刚刚更新的时间变量的例子吗?我是PHP的新手,所以我还不知道所有这些命令。 –