sql脚本

    xiaoxiao2021-03-25  68

    Windows下执行命令 \. d:\book.sql 这里使用了case when 这个小技巧来实现批量更新。//一个字段 UPDATE categories      SET display_order = CASE id          WHEN 1 THEN 3          WHEN 2 THEN 4          WHEN 3 THEN 5      END WHERE id IN (1,2,3) 这句sql的意思是,更新display_order 字段,如果id=1 则display_order 的值为3,如果id=2 则 display_order 的值为4,如果id=3 则 display_order 的值为5。 即是将条件语句写在了一起。 这里的where部分不影响代码的执行,但是会提高sql执行的效率。确保sql语句仅执行需要修改的行数,这里只有3条数据进行更新,而where子句确保只有3行数据执行。  //多个字段 UPDATE categories     SET display_order = CASE id          WHEN 1 THEN 3          WHEN 2 THEN 4          WHEN 3 THEN 5      END,      title = CASE id          WHEN 1 THEN 'New Title 1'         WHEN 2 THEN 'New Title 2'         WHEN 3 THEN 'New Title 3'     END WHERE id IN (1,2,3) 到这里,已经完成一条mysql语句更新多条记录了。
    转载请注明原文地址: https://ju.6miu.com/read-38617.html

    最新回复(0)