MySQL 06 mysql 如何实现类似 oracle 的 merge into

拓展阅读

MySQL View

MySQL truncate table 与 delete 清空表的区别和坑

MySQL Ruler mysql 日常开发规范

MySQL datetime timestamp 以及如何自动更新,如何实现范围查询

MySQL 06 mysql 如何实现类似 oracle 的 merge into

MySQL 05 MySQL入门教程(MySQL tutorial book)

MySQL 04- EMOJI 表情与 UTF8MB4 的故事

MySQL Expression 1 of ORDER BY clause is not in SELECT list,references column

mysql 中 insert into tableName values() ON DUPLICATE KEY update time=now() 啥意思

在 MySQL 中,INSERT INTO 语句用于向表中插入新的行数据。语法如下:

sql 复制代码
INSERT INTO tableName (column1, column2, ...)
VALUES (value1, value2, ...)

上述语句中,tableName 是表的名称,column1, column2, ... 是要插入的列名,value1, value2, ... 是要插入的对应列的值。

ON DUPLICATE KEY UPDATE 子句是用于在插入数据时,当遇到主键或唯一索引冲突时,执行更新操作。这样可以避免插入重复的数据,而是更新已存在的行。

在你提供的例子中,ON DUPLICATE KEY UPDATE time=now() 的意思是,当插入数据时,如果出现主键或唯一索引冲突,将会更新已存在行中的 time 列为当前的时间戳(使用 now() 函数获取)。

所以,这个语句的含义是:如果要插入的数据在表中已存在(根据主键或唯一索引判断),则更新已存在行的时间列为当前时间;如果数据不存在,则插入新的行数据。

参考资料

github.com/jaywcjlove/...

相关推荐
蝎子莱莱爱打怪3 小时前
OpenClaw 从零配置指南:接入飞书 + 常用命令 + 原理图解
java·后端·ai编程
狼爷5 小时前
Go 没有 override?别硬套继承!用接口+嵌入,写更清爽的“覆盖”逻辑
java·go
小兔崽子去哪了7 小时前
Java 自动化部署
java·后端
ma_king7 小时前
入门 java 和 数据库
java·数据库·后端
后端AI实验室7 小时前
我用Cursor开发了3个月,整理出这套提效4倍的工作流
java·ai
码路飞11 小时前
GPT-5.3 Instant 终于学会好好说话了,顺手对比了下同天发布的 Gemini 3.1 Flash-Lite
java·javascript
SimonKing12 小时前
OpenCode AI编程助手如何添加Skills,优化项目!
java·后端·程序员
Seven9714 小时前
剑指offer-80、⼆叉树中和为某⼀值的路径(二)
java
怒放吧德德1 天前
Netty 4.2 入门指南:从概念到第一个程序
java·后端·netty
雨中飘荡的记忆1 天前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端