MySQL数据库-插入语句

mysql关键字说明

链接

判断两个字段是否同时存在,存在则更新,不存在则插入

在MySQL中,要实现先判断两个字段是否同时存在,存在则更新,不存在则插入的操作,你可以使用INSERT ... ON DUPLICATE KEY UPDATE语句结合唯一性约束来实现。

假设你有一个名为table_name的表,其中包含两个字段field1field2。你可以按照以下步骤进行操作:

field1field2字段创建一个唯一性约束,确保这两个字段的组合值在表中是唯一的。你可以使用以下语句为这两个字段添加唯一性约束:

sql

ALTER TABLE table_name  
ADD CONSTRAINT unique_key UNIQUE (field1, field2);

使用INSERT ... ON DUPLICATE KEY UPDATE语句进行插入和更新操作:

sql

INSERT INTO table_name (field1, field2)  
VALUES (value1, value2)  
ON DUPLICATE KEY UPDATE  
    field1 = VALUES(field1),  
    field2 = VALUES(field2);

在上述语句中,你需要将table_name替换为实际的表名,field1field2替换为要判断和更新的字段名,以及value1value2替换为要插入的值。

当插入的记录在表中不存在时,将会插入一条新记录。如果存在相同的记录(即field1field2的值与插入的值匹配),则会更新field1和field2字段的值。

这样,你就可以通过唯一性约束和INSERT ... ON DUPLICATE KEY UPDATE语句实现先判断两个字段是否同时存在,存在则更新,不存在则插入的操作。

两条查询语句同时执行返回结果

results:  [
  [
    {
      id: 6,
      user_infor_id: 4,
      remark: null
    }
  ],
  [
    {
      id: 4,
      number: 2,
      user_effective: 1,
      phone: null,
      company: null,
      remark: '',
      createtime: 2023-11-25T02:30:04.000Z
    }
  ]
]

你可能感兴趣的:(数据库MySQL,数据库,mysql,oracle)