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

时间:2012-01-11 03:08:57

标签: php mysql

场景:

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

4 个答案:

答案 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();
?>