on duplicate key update
时间: 2023-08-28 14:07:20 浏览: 96
ON DUPLICATE KEY UPDATE是一种SQL语句,用于在插入数据时检查主键是否冲突,如果冲突则执行更新操作。如果ON DUPLICATE KEY UPDATE的子句中要更新的值与原来的值都一样,则不更新。如果有一个值与原值不一样,则更新。\[1\]
这个语句通常用于在插入数据之前先检查数据库中是否已经存在相同的记录,如果存在则更新该记录,如果不存在则插入新的记录。这在某些业务需求中非常有用。\[2\]
如果想要动态赋值,可以使用VALUES()函数来获取要插入的值。例如,可以使用"age = VALUES(age)"来动态获取主键冲突时要更新的age字段的值。\[3\]
#### 引用[.reference_title]
- *1* *3* [ON DUPLICATE KEY UPDATE 用法](https://blog.csdn.net/qq_38803590/article/details/124692041)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item]
- *2* [ON DUPLICATE key update的介绍与使用](https://blog.csdn.net/ke2602060221/article/details/125096269)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]
阅读全文