mysql 日期默认系统时间 mysql 默认值不支持函数
2016-01-28 13:35
621 查看
转载自:http://www.cnblogs.com/ckaimnet/archive/2011/07/29/2120554.html
由于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()。
另外在5.0以上版本中也可以使用trigger来实现此功能。
create table test_time (
id int(11),
create_time datetime
);
delimiter |
create trigger default_datetime before insert on test_time
for each row
if new.create_time is null then
set new.create_time = now();
end if;|
delimiter ;
由于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()。
另外在5.0以上版本中也可以使用trigger来实现此功能。
create table test_time (
id int(11),
create_time datetime
);
delimiter |
create trigger default_datetime before insert on test_time
for each row
if new.create_time is null then
set new.create_time = now();
end if;|
delimiter ;
相关文章推荐
- Navicat设定mysql定时任务
- mysql 用source 导入数据库报错
- spark - 将RDD保存到RMDB(MYSQL)数据库中
- 设计模式 - 单例模式mysql数据库操作类
- MySQL中KEY与INDEX的区别
- mysql读写分离(使用Atlas实现)
- MySQL中EXPLAIN详解
- MySql 账户管理
- mysql聚集索引的优缺点
- [转]向facebook学习,通过协程实现mysql查询的异步化
- mysql 命令行执行sql语句
- unix下mysql丢失或者遗忘密码怎么办
- SqlServer实时数据同步到MySql
- MySQL 插入时间
- mysql : Lock wait timeout exceeded; try restarting transaction
- mysql 的 几种 timeout(更新中......)
- SqlServer实时数据同步到mysql
- 破解mysql root密码的几种方法
- mysqldump
- MySQL日期时间函数大全