MySQL数据库TIMESTAMP设置默认值的灵活运用

MySQL数据库TIMESTAMP设置默认值是本文我们主要要介绍的内容,我们知道,CURRENT_TIMESTAMP :当我更新这条记录的时候,这条记录的这个字段不会改变。

成都创新互联专注为客户提供全方位的互联网综合服务,包含不限于成都网站建设、成都网站设计、郯城网络推广、微信小程序开发、郯城网络营销、郯城企业策划、郯城品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;成都创新互联为所有大学生创业者提供郯城建站搭建服务,24小时服务热线:028-86922220,官方网址:www.cdcxhl.com

CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP :当我更新这条记录的时候,这条记录的这个字段将会改变。即时间变为了更新时候的时间。(注意一个UPDATE设置一个列为它已经有的值,这将不引起TIMESTAMP列被更新,因为如果你设置一个列为它当前的值,MySQL为了效率而忽略更改。)

如果有多个TIMESTAMP列,只有***个自动更新。

接下来我们看几个实际的例子:

#1创建一个有两个timestamp字段的表dj1。

 
 
 
  1. root@localhost:test >create table dj1 (a char(1), b timestamp ,c timestamp); 
  2. Query OK, 0 rows affected (0.01 sec)

#2插入两行数据,仅赋值于列A

 
 
 
  1. root@localhost:test >insert into dj1 values (1,null,null);
  2. Query OK, 1 row affected (0.00 sec)
  3. root@localhost:test >insert into dj1 values (2,null,null); 
  4. Query OK, 1 row affected (0.00 sec)

#3查询插入数据,b,c两列都使用current timestamp作为默认值。

 
 
 
  1. root@localhost:test >select * from dj1;
  2. +------+---------------------+---------------------+
  3. | a | b | c |
  4. +------+---------------------+---------------------+
  5. | 1 | 2009-09-09 13:48:40 | 2009-09-09 13:48:40 | 
  6. | 2 | 2009-09-09 13:48:44 | 2009-09-09 13:48:44 | 
  7. +------+---------------------+---------------------+
  8. 2 rows in set (0.00 sec)

#4更新一行数据,发现b列timestamp被自动更新,而c列保持不变。

 
 
 
  1. root@localhost:test >update dj1 set a=9 where a=1; 
  2. Query OK, 1 row affected (0.00 sec)
  3. Rows matched: 1 Changed: 1 Warnings: 0
  4. root@localhost:test >select * from dj1;
  5. +------+---------------------+---------------------+
  6. | a | b | c |
  7. +------+---------------------+---------------------+
  8. | 9 | 2009-09-09 13:49:08 | 2009-09-09 13:48:40 | 
  9. | 2 | 2009-09-09 13:48:44 | 2009-09-09 13:48:44 | 
  10. +------+---------------------+---------------------+
  11. 2 rows in set (0.00 sec)

#5再更新一列,仍然如#4

 
 
 
  1. root@localhost:test >update dj1 set a=8 where a=2; 
  2. Query OK, 1 row affected (0.00 sec)
  3. Rows matched: 1 Changed: 1 Warnings: 0
  4. root@localhost:test >select * from dj1;
  5. +------+---------------------+---------------------+
  6. | a | b | c |
  7. +------+---------------------+---------------------+
  8. | 9 | 2009-09-09 13:49:08 | 2009-09-09 13:48:40 | 
  9. | 8 | 2009-09-09 13:49:36 | 2009-09-09 13:48:44 | 
  10. +------+---------------------+---------------------+
  11. 2 rows in set (0.00 sec)

#6在b列上创建***索引

 
 
 
  1. root@localhost:test >create unique index dj1_idx_u1 on dj1(b);
  2. Query OK, 2 rows affected (0.01 sec)
  3. Records: 2 Duplicates: 0 Warnings: 0

#7更新所有行a列,报***性冲突。

 
 
 
  1. root@localhost:test >update dj1 set a=1;
  2. ERROR 1062 (23000): Duplicate entry '2009-09-09 13:54:45' for key 'dj1_idx_u1'

结论:

1.MySQL默认表的***个timestamp字段为NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP属性,必须显式定义改变这种行为。

2.MySQL只允许一个timestamp字段拥有[DEFAULT CURRENT_TIMESTAMP |ON UPDATE CURRENT_TIMESTAMP]属性。 我的理解为要么都是DEFAULT CURRENT_TIMESTAMP 要么都是DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP

3.修改字段属性值

 
 
 
  1. show create table tbl_ledgerrecord;
  2. alter table tbl_ledgerrecord change intoStorageDate  intoStorageDate timestamp DEFAULT CURRENT_TIMESTAMP;

关于MySQL数据库TIMESTAMP设置默认值的灵活运用的知识就介绍到这里了,希望本次的介绍能够对您有所收获!

文章名称:MySQL数据库TIMESTAMP设置默认值的灵活运用
文章网址:http://www.csdahua.cn/qtweb/news41/260391.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网