文档章节

MySQL datetime数据类型设置当前时间为默认值

varchard
 varchard
发布于 2015/04/26 16:27
字数 420
阅读 212
收藏 8

环境:MySQL Sever 5.1 + MySQL命令行工具

问题:MySQL datetime数据类型设置当前时间为默认值

解决:

方法一:

由于MySQL目前字段的默认值不支持函数,所以以create_time datetime default now() 的形式设置默认值是不可能的。代替的方案是使用TIMESTAMP类型代替DATETIME类型。

TIMESTAMP列类型自动地用当前的日期和时间标记INSERT或UPDATE的操作。如果有多个TIMESTAMP列,只有第一个自动更新。

自动更新第一个TIMESTAMP列在下列任何条件下发生:

1.列值没有明确地在一个INSERT或LOAD DATA INFILE语句中指定。

2.列值没有明确地在一个UPDATE语句中指定且另外一些的列改变值。(注意一个UPDATE设置一个列为它已经有的值,这将不引起TIMESTAMP列被更新,因为如果你设置一个列为它当前的值,MySQL为了效率而忽略更改。)

3.你明确地设定TIMESTAMP列为NULL.

4.除第一个以外的TIMESTAMP列也可以设置到当前的日期和时间,只要将列设为NULL,或NOW()。

所以把日期类型 选择成timestamp 允许空就可以了

  1. CREATE TABLE test (   

  2. uname varchar(50) NOT NULL,   

  3. updatetime timestamp NULL DEFAULTCURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP   

  4. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;    

如果要在navicat下操作的话,将字段设置为timestamp,然后默认值写上CURRENT_TIMESTAMP即可

方法二:

在MySQL5.0以上版本中也可以使用trigger来实现此功能。

  1. create table test_time (   

  2.  idint(11),   

  3.  create_time datetime   

  4. );   

  5. delimiter |   

  6. create trigger default_datetime beforeinsert on test_time   

  7.   foreach row   

  8.     if new.create_time is null then   

  9.       set new.create_time = now();   

  10.     end if;|   

  11. delimiter ;

© 著作权归作者所有

共有 人打赏支持
varchard
粉丝 6
博文 58
码字总数 19458
作品 0
程序员
私信 提问
MySQL中 TIMESTAMP类型 和 DATETIME类型 的区别

1、两者的存储方式不一样 TIMESTAMP:把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储。查询时,将其又转化为客户端当前时区进行返回。 DATETIME:不做任何改变,基本上是原...

学习也休闲
2016/01/20
288
0
[mysql] timestamp自动更新和初始化

[mysql] timestamp自动更新和初始化 1.概述 在我们设计表的时候,考虑将行数据的创建时间和最后更新时间记录下来是很好的实践。尤其是可能需要做数据同步或者对数据新鲜度有要求的表。举些应...

as007012012
2017/01/13
0
0
开发规范,推荐使用TIMESTAMP,真的合适么?

在时间类型中,用的较多的是TIMESTAMP和DATETIME。 看到很多开发规范,推荐使用TIMESTAMP而不是DATETIME,原因在于TIMESTAMP占4个字节,而DATETIME需要8个字节,前者比后者省空间。 这个说法...

MySQL实战
09/17
0
0
MySQL学习笔记--1

1:SQL语言的组成 DDL-主要用于定义数据库,表,视图,索引,触发器等,如DROP,CREATE,ALTER等语句 DML-主要包括对数据库增删改,INSERT,UPDATE,DELETE DQL-主要用于数据的检索,SELECT,...

雨醉风尘
2015/09/14
75
0
Java项目统一UTC时间方案

引言 近期团队的个别项目在进行框架升级后,部分时间值存在8小时误差,原因是错误的将数据库中的时间数据理解成了UTC时间(旧版本认为是北京时间) 考虑到未来项目对于时间理解的一致性,我决...

天天顺利
2015/09/24
63
0

没有更多内容

加载失败,请刷新页面

加载更多

Java程序员可知为何公司宁花25K重新招人,也不花20K留住老员工?

身在职场,经常会暗自打听同事工资,尤其是得知身边新入职同事的工资居然比自己高,还高出一大截时,心里自然很不平衡,一心想要离职。 那么,为什么公司宁愿花高价招聘新员工也不愿意给老员...

Java填坑路
5分钟前
1
0
阿里云文件存储(NAS)助力业务系统承载双十一尖峰流量

2018天猫双11全球狂欢节,全天成交额再次刷新纪录达到2135亿元,其中总成交额在开场后仅仅用了2分05秒即突破100亿元,峰值的交易量达到惊人的高度,背后离不开阿里云大数据计算和存储能力的支...

阿里云云栖社区
9分钟前
0
0
【windows 找不到“\\192.168.X.X”,请检查拼写是否正确】错误&139端口和445端口区别

今天像往常一样,通过共享盘访问其他主机时,却出现如题的错误,百思不得其解,毕竟没有改动什么配置啊,地址也没输错啊。 然后就在网上看到了一篇博客,才想起来上周末因为考虑到安全问题,...

fang_faye
9分钟前
0
0
示例Express中路由规则及获取请求参数

本次给大家分享一篇基于express中路由规则及获取请求参数的方法,写的十分的全面细致,具有一定的参考价值,对此有需要的朋友可以参考学习下。如有不足之处,欢迎批评指正。 express中常见的...

前端攻城小牛
13分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部