说我想做UPDATE table SET name = 'bob'
和UPDATE table SET age = 55 WHERE name = 'jim'
我如何在同一个mysql_query()中做到这些?
编辑:由于这个问题有相当多的观点,我想指出,自PHP 5.5起mysql_query
和其他mysql_*
函数现已弃用,不应该使用。
答案 0 :(得分:13)
我从未尝试过这个,但我认为你可以使用mysqli::multi_query。 mysql_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
希望它对你有所帮助。