拓展阅读
MySQL 02 truncate table 与 delete 清空表的区别和坑
MySQL 03 Expression 1 of ORDER BY clause is not in SELECT list,references column
MySQL 04 EMOJI 表情与 UTF8MB4 的故事
MySQL 05 MySQL入门教程(MySQL tutorial book)
MySQL 06 mysql 如何实现类似 oracle 的 merge into
MySQL 08 datetime timestamp 以及如何自动更新,如何实现范围查询
MySQL 09 MySQL-09-SP mysql 存储过程
mysql 中 insert into tableName values() ON DUPLICATE KEY update time=now() 啥意思
在 MySQL 中,INSERT INTO
语句用于向表中插入新的行数据。语法如下:
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()
函数获取)。
所以,这个语句的含义是:如果要插入的数据在表中已存在(根据主键或唯一索引判断),则更新已存在行的时间列为当前时间;如果数据不存在,则插入新的行数据。
参考资料
https://github.com/jaywcjlove/mysql-tutorial