zoukankan      html  css  js  c++  java
  • INSERT INTO .. ON DUPLICATE KEY更新多行记录

     现在问题来了,如果INSERT多行记录, ON DUPLICATE KEY UPDATE后面字段的值怎么指定?要知道一条INSERT语句中只能有一个ON DUPLICATE KEY UPDATE,到底他会更新一行记录,还是更新所有需要更新的行。这个问题困扰了我很久了,其实使用VALUES()函数一切问题都解决了。

         举个例子,字段a被定义为UNIQUE,并且原数据库表table中已存在记录(2,2,9)和(3,2,1),如果插入记录的a值与原有记录重复,则更新原有记录,否则插入新行:

    INSERT INTO TABLE (a,b,cVALUES 
    (1,2,3),
    (2,5,7),
    (3,3,6),
    (4,8,2)
    ON DUPLICATE KEY UPDATE b=VALUES(b);

     

         以上SQL语句的执行,发现(2,5,7)中的a与原有记录(2,2,9)发生唯一值冲突,则执行ON DUPLICATE KEY UPDATE,将原有记录(2,2,9)更新成(2,5,9),将(3,2,1)更新成(3,3,1),插入新记录(1,2,3)和(4,8,2)

       这里的b=VALUES(b) 是指定要更新的列,这里只指定了b列,所以只更新了b列的数据,(2,2,9)更新后(2,5,9)

         如果指定b=VALUES(b),c=VALUES(c) 那么将更新两列的数据 例如原来的(2,2,9) 更新后(2,8,8)

         注意:ON DUPLICATE KEY UPDATE只是MySQL的特有语法,并不是SQL标准语法!

  • 相关阅读:
    Java中的匿名对象、内部类、包、代码块
    Java中的final和static关键字
    Java中的this与super关键字
    Java中的构造方法
    Java中的多态
    Vue+Element中Table懒加载,新增、删除操作后手动更新
    JQ取消hover事件
    github.com访问慢解决
    vue cli3 子目录问题
    右键事件 contextmenu
  • 原文地址:https://www.cnblogs.com/gide/p/4727369.html
Copyright © 2011-2022 走看看