一切福田,不離方寸,從心而覓,感無不通。

mysql日期的默认值

如何给mysql设置日期的默认值呢?
mysql的日期类型:datetime ,是无法设置默认值的
TIMESTAMP类型可以设置:

o        用DEFAULT CURRENT_TIMESTAMP和ON UPDATE CURRENT_TIMESTAMP子句,列为默认值使用当前的时间戳,并且自动更新。

o        不使用DEFAULT或ON UPDATE子句,与DEFAULT CURRENT_TIMESTAMP ON UPDATECURRENT_TIMESTAMP相同。

o        用DEFAULT CURRENT_TIMESTAMP子句不用ON UPDATE子句,列为默认值使用当前的时间戳但是不自动更新。

o        不用DEFAULT子句但用ON UPDATE CURRENT_TIMESTAMP子句,列有默认值0并自动更新。

o        用常量DEFAULT值,列有给出的 默认值。如果列有一个ON UPDATE CURRENT_TIMESTAMP子句,它自动更新,否则不。

换句话说,你可以为初始值和自动更新的值使用当前的时间戳,或者其中一个使用,或者两个皆不使用。(例如,你可以指定ON UPDATE来启用自动更新而不让列自动初始化)。

·         在DEFAULT和ON UPDATE子句中可以使用CURRENT_TIMESTAMP、CURRENT_TIMESTAMP()或者NOW()。它们均具有相同的效果。

两个属性的顺序并不重要。如果一个TIMESTAMP列同时指定了DEFAULT和ON UPDATE,任何一个可以在另一个的前面。

例子,下面这些语句是等效的:

CREATE TABLE t (ts TIMESTAMP); CREATE TABLE t (ts TIMESTAMP DEFAULT CURRENT_TIMESTAMP                              ON UPDATE CURRENT_TIMESTAMP); CREATE TABLE t (ts TIMESTAMP ON UPDATE CURRENT_TIMESTAMP                              DEFAULT CURRENT_TIMESTAMP);

·         要为TIMESTAMP列而不是第1列指定自动默认或更新,必须通过将第1个TIMESTAMP列显式分配一个常量DEFAULT值来禁用自动初始化和更新。(例如,DEFAULT 0或DEFAULT’2003-01-01 00:00:00′)。然后,对于其它TIMESTAMP列,规则与第1个TIMESTAMP列相同,例外情况是不能忽略DEFAULT和ON UPDATE子句。如果这样做,则不会自动进行初始化或更新。

例如:下面这些语句是等效的:

CREATE TABLE t (     ts1 TIMESTAMP DEFAULT 0,     ts2 TIMESTAMP DEFAULT CURRENT_TIMESTAMP                   ON UPDATE CURRENT_TIMESTAMP); CREATE TABLE t (     ts1 TIMESTAMP DEFAULT 0,     ts2 TIMESTAMP ON UPDATE CURRENT_TIMESTAMP                   DEFAULT CURRENT_TIMESTAMP);

mysql目前不支持列的default 为函数的形式,
如达到你某列的默认值为当前更新日期与时间的功能,
你可以使用timestamp列类型
下面就详细说明timestamp列类型

 
timestamp列类型
timestamp值可以从1970的某时的开始一直到2037年,精度为一秒,其值作为数字显示。
timestamp值显示尺寸的格式如下表所示:

+—————+—————-+
| 列类型        | 显示格式       |
| timestamp(14) | yyyymmddhhmmss |
| timestamp(12) | yymmddhhmmss   |
| timestamp(10) | yymmddhhmm     |
| timestamp(8)  | yyyymmdd       |
| timestamp(6)  | yymmdd         |
| timestamp(4)  | yymm           |
| timestamp(2)  | yy             |
+—————+—————-+
“完整”timestamp格式是14位,但timestamp列也可以用更短的显示尺寸创造
最常见的显示尺寸是6、8、12、和14。
你可以在创建表时指定一个任意的显示尺寸,但是定义列长为0或比14大均会被强制定义为列长14。
列长在从1~13范围的奇数值尺寸均被强制为下一个更大的偶数。

 

列如:
定义字段长度     强制字段长度
timestamp(0) ->  timestamp(14)
timestamp(15)->  timestamp(14)
timestamp(1) ->  timestamp(2)
timestamp(5) ->  timestamp(6)

 

所有的timestamp列都有同样的存储大小,
使用被指定的时期时间值的完整精度(14位)存储合法的值不考虑显示尺寸。
不合法的日期,将会被强制为0存储
这有几个含意:
1、虽然你建表时定义了列timestamp(8),但在你进行数据插入与更新时timestamp列
实际上保存了14位的数据(包括年月日时分秒),
只不过在你进行查询时mysql返回给你的是8位的年月日数据。
如果你使用alter table拓宽一个狭窄的timestamp列,以前被“隐蔽”的信息将被显示。
2、同样,缩小一个timestamp列不会导致信息失去,除了感觉上值在显示时,较少的信息被显示出。
3、尽管timestamp值被存储为完整精度,直接操作存储值的唯一函数是unix_timestamp();
由于mysql返回timestamp列的列值是进过格式化后的检索的值,
这意味着你可能不能使用某些函数来操作timestamp列(例如hour()或second()),
除非timestamp值的相关部分被包含在格式化的值中。
例如,一个timestamp列只有被定义为timestamp(10)以上时,timestamp列的hh部分才会被显示,
因此在更短的timestamp值上使用hour()会产生一个不可预知的结果。
4、不合法timestamp值被变换到适当类型的“零”值(00000000000000)。(datetime,date亦然)

 

你可以使用下列语句来验证:
create table test ('id' int (3) unsigned auto_increment, 'date1' timestamp (8) primary key('id'));
insert into test set id = 1;
select * from test;
+—-+—————-+
| id | date1          |
+—-+—————-+
|  1 | 20021114       |
+—-+—————-+
alter table test change 'date1' 'date1' timestamp(14);
select * from test;
+—-+—————-+
| id | date1          |
+—-+—————-+
|  1 | 20021114093723 |
+—-+—————-+

 

 

 

你可以使用timestamp列类型自动地用当前的日期和时间标记insert或update的操作。
如果你有多个timestamp列,只有第一个自动更新。
自动更新第一个timestamp列在下列任何条件下发生:

 

1、列值没有明确地在一个insert或load data infile语句中指定。
2、列值没有明确地在一个update语句中指定且另外一些的列改变值。
(注意一个update设置一个列为它已经有的值,
这将不引起timestamp列被更新,
因为如果你设置一个列为它当前的值,mysql为了效率而忽略更改。)
3、你明确地设定timestamp列为null.
4、除第一个以外的timestamp列也可以设置到当前的日期和时间,只要将列设为null,或now()。

 
create table test (
'id' int (3) unsigned auto_increment,
'date1' timestamp (14),
'date2' timestamp (14),
primary key('id')
);

 

insert into test (id, date1, date2) values (1, null, null);
insert into test set id= 2;
+—-+—————-+—————-+
| id | date1          | date2          |
+—-+—————-+—————-+
|  1 | 20021114093723 | 20021114093723 |
|  2 | 20021114093724 | 00000000000000 |
+—-+—————-+—————-+
->第一条指令因设date1、date2为null,所以date1、date2值均为当前时间
第二条指令因没有设date1、date2列值,第一个timestamp列date1为更新为当前时间,
而二个timestamp列date2因日期不合法而变为“00000000000000”

update test set id= 3 where id=1;
+—-+—————-+—————-+

 

from:http://blog.163.com/wang_hai_fei/blog/static/309020312009621021243/