场景:
我有一个客户端,php脚本和一个MySQL数据库。我将信息从客户端发送到数据库,其中的值包括名称和喜欢的颜色。我在MySQL数据库中有2行。
名称|最喜欢的颜色
Johnny |绿色
其中Name是主键。
每次,客户都会发送他的名字和最喜欢的颜色。所以,若名称(主键)存在,它就会显示错误。如果客户想要更新他喜欢的颜色,我应该如何设置我的php脚本来做出反应?换句话说,保留主键,但更新最喜欢的颜色。
script.php
<?php
mysql_connect("localhost","root","")
mysql_select_db("Information");
$name = mysql_real_escape_string($_POST["name"]);
$color = mysql_real_escape_string($_POST["color"]);
$sql=mysql_query("insert into Male (name, color) VALUES ('$name','$color')");
mysql_close();
$sql=mysql_query("INSERT INTO Male (name, color) VALUES ('".$name."', '".$color."')
ON DUPLICATE KEY UPDATE color='".$color."'");
http://dev.mysql.com/doc/refman/5.1/en/insert-on-duplicate.html
您正在查找UPDATE
SQL语句。这将更新现有行:
$sql = mysql_query("UPDATE Male SET color = '$color' WHERE name = '$name'");
或者,您可以使用INSERT。。。在重复密钥更新时。
如果指定ON DUPLICATE KEY UPDATE,并且插入的行会导致UNIQUE索引或PRIMARY KEY中的值重复,则会执行旧行的UPDATE。
$sql = mysql_query("INSERT INTO Male (name, color) VALUES ('$name','$color')
ON DUPLICATE KEY UPDATE color = '$color'");
MySQL提供了一个SQL扩展,即REPLACE,如果不存在,它将插入一个新行。
$sql = mysql_query("REPLACE INTO Male (name, color) VALUES ('$name','$color')");
您需要使用update语句而不是insert来修改您的mysql_query。像这样的东西。
$name = mysql_real_escape_string($_POST["name"]);
$color = mysql_real_escape_string($_POST["color"]);
$sql=mysql_query("UPDATE Male SET color = '".$color."' WHERE name = '".$name."'");
mysql.close();
<?php
mysql_connect("localhost","root","")
mysql_select_db("Information");
$name = mysql_real_escape_string($_POST["name"]);
$color = mysql_real_escape_string($_POST["color"]);
$query = mysql_query("select name from Male where name = '$name'");
if(mysql_num_rows($query) > 0) {
mysql_query("update Male set color='$color' where name='$name'");
} else {
mysql_query("insert into Male (name, color) VALUES ('$name','$color')");
}
mysql.close();
?>