MySQL 可以使用 MERGE 语句吗?
将 INSERT 和 UPDATE 操作合并到单个查询中通常是可取的。许多 SQL 数据库为此提供了 MERGE 语句。但是,MySQL 支持这样的语句吗?
MySQL 和 MERGE 语句
MySQL 不明确支持 MERGE 语句。但是,它确实提供了实现类似功能的替代方案:INSERT...ON DUPLICATE KEY UPDATE。
语法和用法
INSERT...ON DUPLICATE KEY UPDATE 语句允许您向表中插入新行,如果已存在具有相同主键或唯一键的行,它将更新现有行新值。
语法如下:
INSERT INTO table (column1, column2, ...) VALUES (value1, value2, ...) ON DUPLICATE KEY UPDATE column1 = new_value1, column2 = new_value2, ...
示例
为了说明其用法,请考虑以下示例:
INSERT INTO Employees (id, name, salary) VALUES (1, 'John Doe', 50000) ON DUPLICATE KEY UPDATE salary = salary + 10000;
如果员工表中已存在 ID 为 1 的员工,则此语句将通过添加来更新他们的工资10000。否则,它将为 John Doe 插入一个新行,其工资为 50000。
以上是MySQL 是否提供等效的 MERGE 语句?的详细内容。更多信息请关注PHP中文网其他相关文章!