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

打印 上一主题 下一主题

主题 874|帖子 874|积分 2632

拓展阅读

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 语句用于向表中插入新的行数据。语法如下:
  1. INSERT INTO tableName (column1, column2, ...)
  2. VALUES (value1, value2, ...)
复制代码
上述语句中,tableName 是表的名称,column1, column2, ... 是要插入的列名,value1, value2, ... 是要插入的对应列的值。
而 ON DUPLICATE KEY UPDATE 子句是用于在插入数据时,当遇到主键或唯一索引辩说时,执行更新操纵。如许可以避免插入重复的数据,而是更新已存在的行。
在你提供的例子中,ON DUPLICATE KEY UPDATE time=now() 的意思是,当插入数据时,假如出现主键或唯一索引辩说,将会更新已存在行中的 time 列为当前的时间戳(使用 now() 函数获取)。
所以,这个语句的含义是:假如要插入的数据在表中已存在(根据主键或唯一索引判断),则更新已存在行的时间列为当前时间;假如数据不存在,则插入新的行数据。
参考资料

https://github.com/jaywcjlove/mysql-tutorial

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

正序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

篮之新喜

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表