`
wsql
  • 浏览: 11776883 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
文章分类
社区版块
存档分类
最新评论

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

 
阅读更多

环境: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 允许空就可以了


CREATE TABLE test ( 
uname varchar(50) NOT NULL, 
updatetime timestamp NULL DEFAULTCURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP 
) ENGINE=InnoDB DEFAULT CHARSET=utf8; 


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

方法二:


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


create table test_time ( 
 idint(11), 
 create_time datetime 
); 
delimiter | 
create trigger default_datetime beforeinsert on test_time 
  foreach row 
    if new.create_time is null then 
      set new.create_time = now(); 
    end if;| 
delimiter ; 


参考资料:


mysql 日期默认系统时间 mysql 默认值不支持函数


MySQL的datetime设置当前时间为默认值


MySQL里如何给日期类型设置默认值


MySQL 字段约束 null,notnull,default,auto_increment





分享到:
评论

相关推荐

    详解Mysql数据库date, datetime类型设置0000-00-00默认值(default)报错问题

    现象:MySQL5.7版本之后,date, datetime类型设置默认值”0000-00-00″,出现异常:Invalid default value for ‘time’ 原因:在命令行窗口查看当前的sql_mode配置: select @@sql_mode; 结果如下: ONLY_FULL_GROUP_BY...

    MySQL如何为字段添加默认时间浅析

    是否支持设置系统默认值 date 3 YYYY-MM-DD 日期值 不支持 time 3 HH:MM:SS 时间值或持续时间 不支持 year 1 YYYY 年份 不支持 datetime 8 YYYY-MM-DD HH:MM:SS 日期和时间混合值 不支持 timestamp 4 ...

    MySQL 8.0.13设置日期为0000-00-00 00:00:00时出现的问题解决

    先是根据Mysql 数据库date, datetime类型设置0000-00-00默认值报错问题 这篇博客操作的。但是发现。我电脑上没有文章中提到的cnf文件。于是就在网上搜索该文件。粘贴了my.cnf这个内容到/etc/my.cnf里边。 可是等我将...

    mysql 数据类型TIMESTAMP

    在mysql中timestamp数据类型是一个比较特殊的数据类型,他可以自动在你不使用程序更新情况下只要你更新了记录timestamp会自动更新时间 通常表中会有一个Create date 创建日期的字段,其它数据库均有默认值的选项。...

    深入ORACLE迁移到MYSQL的总结分析

    数据库的表结构问题:数据类型不同需要解决varchar2——varchar、number—–int、date—-datetime,建表的sql语句字段默认值、注释怎么解决。2. oracle中没有所谓的敏感字段,可是mysql表中的敏感字段有好多。当时...

    数据库设计命名规范.docx

    注:在MySQL5.0以上的版本中,varchar数据类型的长度支持到了65535,也就是说可以存放65532个字节的数据,起始位和结束位占去了3个字节 建议在大 数表中含有如下字段 数据库设计命名规范全文共6页,当前为第5页。...

    mysql数据库的基本操作语法

    如果需要改变列名建议使用change,如果需要改变数据类型和显示位置可以使用modify 13、 删除表 drop table users; drop删除表会删除表结构,表对象将不存在数据中;数据也不会存在;表内的对象也不存在,如:索引、...

    mysql基础只是总结

    2、数据类型 日期类型:date Y-M-D 20110105(自动去除其中的非法符号!,*) time h:m:s 14:12:11 datetime date+time Y-M-D H:m:S timestamp:更新时日期值也会更新 timestamp default current_timestamp:只记录第...

    DataDirectory.rar

    字段名 数据类型 允许为空 字段说明 默认值 键值 id bigint(20) NO 主键 - PRI merchant_id bigint(20) NO 商户主键 - - coupon_id bigint(20) NO 优惠券主键 - - creat_time datetime NO 创建时间 - - update_...

    数据库表概要设计.pdf

    数据库表概要设计 数据库表概要设计 vc 端符合直觉,m 端追求快速(TDD BDD) 长期... 【缩写】 我们规定 类似 bq = blockquote cT ... 类型 datetime 较⽅便查看创建时间 更新时间 text 富⽂本 decimal(totaLen,preci)

    简单的ADO.net数据访问客户端

    若所有规则都为命中,则对象字段将在映射中被忽略从而保持字段类型的默认值。 注意:使用匿名对象作为模板查询时,匿名对象的字段名称需和查询结果的字段名称完全匹配,不支持模糊匹配。 Indexing扩展 在Data....

Global site tag (gtag.js) - Google Analytics