dongtan1009 2016-09-12 01:07
浏览 52

mySQL - 如何在一个查询中进行多次更新? [重复]

This question already has an answer here:

I have 2 update queries, same tables but different rows and values. Since its same table, making 2 queries is an unprofessional way.

UPDATE members SET age="18" WHERE nick = "John"
UPDATE members SET height="180" WHERE nick = "Stuart"

Is there a better (1 query) method for this ? Thanks

</div>
  • 写回答

1条回答 默认 最新

  • duanji2002 2016-09-12 01:08
    关注

    Just use the right where clause:

    UPDATE members
        SET age = 18
    WHERE nick IN ('John', 'Stuart')
    

    I am guessing that age is an integer. I should also point out that storing "age" in a database is very uncommon -- because it is a bad idea. Every day, people's ages change.

    EDIT:

    UPDATE members
        SET age = (CASE WHEN nick = 'John' THEN 18 ELSE age END),
            height = (CASE WHEN nick = 'Stuart' THEN 180 ELSE height END)
    WHERE nick IN ('John', 'Stuart')
    

    I really read the problem as updating only age. For this, you can use a case statement:

    评论

报告相同问题?

悬赏问题

  • ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
  • ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)
  • ¥15 相敏解调 matlab
  • ¥15 求lingo代码和思路
  • ¥15 公交车和无人机协同运输
  • ¥15 stm32代码移植没反应
  • ¥15 matlab基于pde算法图像修复,为什么只能对示例图像有效
  • ¥100 连续两帧图像高速减法
  • ¥15 如何绘制动力学系统的相图
  • ¥15 对接wps接口实现获取元数据