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/...

相关推荐
逸Y 仙X18 分钟前
Elasticsearch时间类型实战
java·大数据·elasticsearch·搜索引擎·全文检索
Gerardisite1 小时前
企微批量群发消息指南:用 QiWe 省掉人工操作
java·python·机器人·企业微信
青山师2 小时前
动态代理深度解析:JDK与CGLIB底层实现与实战
java·设计模式·面试·动态代理·java面试·cglib
放学后的泡泡2 小时前
提供一个工作流的表设计
java·设计规范
生活真难3 小时前
SpringCloud - 任务调度 - xxl-job-java
java·spring boot·spring cloud
人道领域4 小时前
【黑马点评日记】:用户签到功能详解——从Bitmap入门到避坑指南
java·数据库·redis·后端
梦梦代码精4 小时前
《企业开源商城选型:商业闭环、二次开发与成本平衡》
java·开发语言·低代码·开源·github
狼与自由4 小时前
灰度发布的策略
java
神仙别闹4 小时前
基于QT(C++)实现线性表的建立、插入、删除、查找等基本操作
java·c++·qt
Kiyra4 小时前
从上传到可问答:Interview Agent 的知识库 RAG 链路
java·人工智能·后端·spring·职场和发展