首页
学习
活动
专区
圈层
工具
发布

mysql如何设置update时间字段自动更新?

在给网站做表设计的时候时间字段都是用的datetime类型,初始值都是设置的CURRENT_TIMESTAMP。...由于给文章表设计的有创建时间和更新时间两个字段,但是更新时间字段需要在更新文章后再次更新,当时由于不了解mysql还可以设置自动更新时间戳的功能,而是在更新文章的接口中手动更新时间字段,即以下这种方式:...update pages set update_date=now() 由于最近考虑给一些编辑功能增加更新时间字段,了解到Mysql 本身已经支持这个功能了,所以尝试采用新的方式来实现update_date...sql语句核心的语句为 ON UPDATE CURRENT_TIMESTAMP 所有可以将通过执行以下语句来实现时间字段自动更新功能: # 若该字段不存在 ALTER TABLE `dsiab_com`...`update_date` `update_date` DATETIME on update CURRENT_TIMESTAMP NULL DEFAULT NULL; 上面的语句主要都是在update_date

65310
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL insert or update sql

    MySQL 一条 sql 实现数据保存变更 insert or update ,如果没有执行insert,有就update 需要 有主键 PRIMARY 或 唯一索引 UNIQUE MySQL...中的INSERT … ON DUPLICATE KEY UPDATE语句,该语句是基于唯一索引或主键使用 ON DUPLICATE KEY UPDATE后面可以放多个字段,用英文逗号分割。...使用ON DUPLICATE KEY UPDATE,最终如果插入了一个新行,则受影响的行数是1,如果修改了已存在的一行数据,则受影响的行数是2,如果值不变,则受影响行数是0。...grade`=20, `time_sub`=NOW(), `time_do`=200; 上面语句亲测可用,但有一个警告 共 2 行受到影响, 1 个警告 执行耗时 : 0.059 sec 传送时间...插入……对于具有多个唯一密钥的表的重复密钥更新是不安全的 相关博客:https://blog.csdn.net/rick_zyl/article/details/79024612 mysql 有就更新

    3.8K20

    MySQL的SELECT …for update

    补充:MySQL select…for update的Row Lock与Table Lock   上面我们提到,使用select…for update会把数据给锁住,不过我们需要注意一些锁的级别,MySQL...InnoDB默认Row-Level Lock,所以只有「明确」地指定主键,MySQL 才会执行Row lock (只锁住被选取的数据) ,否则MySQL 将会执行Table Lock (将整个数据表单给锁住...;   console2:查询被阻塞 console2:如果console1长时间未提交,则会报错 例2: (明确指定主键,若查无此数据,无lock)   console1:查询结果为空 set...state=2 for UPDATE    查询阻塞,说明console1把表给锁住了.若console1长时间未提交,则返回锁超时。...select * from person where id>=2 for UPDATE   以上就是关于数据库主键对MySQL锁级别的影响实例,需要注意的是,除了主键外,使用索引也会影响数据库的锁定级别

    4.8K30

    MySQL 案例:Update 死锁详解

    死锁的两个语句如下: UPDATE tbl_deadlock SET col1 = 1, col2 = 1, update_time = 1603685523 WHERE (id1 = 6247476)...AND (id2 = 74354) UPDATE tbl_deadlock SET col1 = 1, col2 = 1, update_time = 1603685523 WHERE (id1 =...MySQL 的锁机制天然具备这个条件。 请求与保持条件:资源请求被阻塞时,已持有的资源不会被释放。 MySQL 不触发死锁回滚,且未进入 lockwait_timeout 的时候,具备这个条件。...MySQL 的锁机制天然具备这个条件。 循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系,通常会表现为有向环。...由于 MySQL 的锁机制的原因,只需要判断出两个 SQL 语句的锁存在循环等待,那么死锁的条件就会成立了。

    16.1K175

    Mysql Insert Or Update语法实例

    有的时候会需要写一段insert的sql,如果主键存在,则update;如果主键不存在,则insert。Mysql中提供了这样的用法:ON DUPLICATE KEY UPDATE。...insert into test values(1,'b4','c4') 错误代码: 1062 Duplicate entry '1' for key 'PRIMARY' 执行耗时 : 0 sec 传送时间...: 0 sec 总耗时 : 0.008 sec 这时,就可以使用ON DUPLICATE KEY UPDATE,它的意思是先执行前面的Insert,如果主键重复,则执行后面的UPDATE...INSERT INTO test VALUES (1,'b4','c4') ON DUPLICATE KEY UPDATE b=VALUES(b),c=VALUES(c); 可以把上面的SQL简单的理解为...b=VALUES(b),c=VALUES(c) 共 2 行受到影响 执行耗时 : 0.023 sec 传送时间 : 0 sec 总耗时 : 0.023 sec 执行完,数据就变成下面的样子了

    2.6K70

    数据库update 随机时间-mysql多库表关联问题症结

    但是数据库update 随机时间,四月初统计上个月的月报的时候,发现到处全部的数据需要花费超过12个小时的时间。   10几分钟的到处已然让人无法接受了,12个小时简直要了人命!   ...本文基于导出时间长的问题,说下数据库表的设计和多表关联需要注意的事情!   ...二、导出格式的要求   1、每个渠道有各自的导出模板;   2、每个模板不同数据库update 随机时间,模板中的字段分散在近十张表中。   三、为什么需要那么多库表的关联?   ...根本原因在于: 永远用小结果集驱动大记录集,因为在mysql中,只有Nested Join一种Join方式,就是说mysql的join是通过嵌套循环来实现的。...《高性能mysql》、《高可用mysql》有时间一定要好好研读(说给自己)。

    2K20
    领券