MySQL-在保留主键的同时更新行中的值


MySQL - Updating values in row while keeping primary key

场景:

我有一个客户端,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();
?>