你如何在一个mysql_query中做多个SQL语句?

时间:2011-07-25 19:22:20

标签: php mysql sql

说我想做UPDATE table SET name = 'bob'UPDATE table SET age = 55 WHERE name = 'jim'我如何在同一个mysql_query()中做到这些?

编辑:由于这个问题有相当多的观点,我想指出,自PHP 5.5起mysql_query和其他mysql_*函数现已弃用,不应该使用。

3 个答案:

答案 0 :(得分:13)

我从未尝试过这个,但我认为你可以使用mysqli::multi_querymysql_query拒绝多个语句的好处之一是它会立即排除一些更常见的SQL注入攻击,例如将'; DELETE FROM ... #添加到语句中。因此,您可能需要小心多个语句。

答案 1 :(得分:8)

正如它在manual

的顶部所说的那样
  

mysql_query()向与指定link_identifier关联的服务器上的当前活动数据库发送唯一查询(不支持多个查询)。

答案 2 :(得分:2)

您可以通过以下方式进行“条件”更新:

create table test (
id int not null auto_increment primary key,
name varchar(50),
age tinyint
) engine = myisam;

insert into test (name) values ('jim'),('john'),('paul'),('mike');


update test
set age =
case 
when name = 'jim' then 10
when name = 'paul' then 20
else 30
end

希望它对你有所帮助。