场景:
我有一个客户端,php脚本和一个MySQL数据库。我正在从客户端向数据库发送信息,其中包含名称和喜欢的颜色。我在MySQL数据库中有2行。
姓名|最喜欢的颜色
约翰尼|绿色
其中Name是主键。
每次,客户都会发送他的名字和喜欢的颜色。因此,如果存在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();
答案 0 :(得分:8)
$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
答案 1 :(得分:1)
您正在寻找UPDATE
SQL语句。这将更新现有行:
$sql = mysql_query("UPDATE Male SET color = '$color' WHERE name = '$name'");
或者,您可以使用INSERT ... ON DUPLICATE KEY UPDATE。
如果指定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')");
答案 2 :(得分:0)
您需要使用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();
答案 3 :(得分:-1)
<?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();
?>