相关疑难解决方法(0)

用一个查询更新多行?

我找到了一些可以在这里更新一个字段的东西:http://www.karlrixon.co.uk/articles/sql/update-multiple-rows-with-different-values-and-a-single-sql-query/

UPDATE person
    SET name = CASE id
        WHEN 1 THEN 'Jim'
        WHEN 2 THEN 'Mike'
        WHEN 3 THEN 'Precious'
    END
WHERE id IN (1,2,3)
Run Code Online (Sandbox Code Playgroud)

我的问题是如何更新多个字段?如:

UPDATE person
    SET name = CASE, sex = CASE id
        WHEN 1 THEN 'Jim', 'female'
        WHEN 2 THEN 'Mike', 'male'
        WHEN 3 THEN 'Precious', 'male'
    END
WHERE id IN (1,2,3)
Run Code Online (Sandbox Code Playgroud)

哪个当然不起作用.尝试了其他一些组合并失败了.任何的想法?谢谢!

mysql sql

25
推荐指数
2
解决办法
4万
查看次数

MySQL Prepared具有可变大小变量列表的语句

你会如何在PHP中编写一个准备好的MySQL语句,每次都需要不同数量的参数?这种查询的一个例子是:

SELECT `age`, `name` FROM `people` WHERE id IN (12, 45, 65, 33)
Run Code Online (Sandbox Code Playgroud)

IN子句id每次运行时都会有不同数量的s.

我脑子里有两种可能的解决方案,但想看看是否有更好的方法.

可能的解决方案1使语句接受100个变量,并使用保证不在表中的虚拟值填充其余变量; 多次调用超过100个值.

可能的解决方案2不要使用准备好的声明; 构建并运行查询严格检查可能的注入攻击.

php mysql sql prepared-statement

22
推荐指数
2
解决办法
2万
查看次数

标签 统计

mysql ×2

sql ×2

php ×1

prepared-statement ×1