TIMESTAMP列类型详解( 怎样设列的默认值为Now() )

来源:互联网 发布:华图网络课程怎么样 编辑:程序博客网 时间:2024/05/17 01:02

作者:shuixin13

MySQL目前不支持列的Default  为函数的形式,  
http://www.faq-it.org/design/">faq-it.org/design/ 如达到你某列的默认值为当前更新日期与时间的功能,  
你可以使用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;  
+----+----------------+----------------+  
 ¦  id    ¦  date1                      ¦  date2                      ¦  
+----+----------------+----------------+  
 ¦    3    ¦  20021114094009    ¦  20021114093723    ¦  
 ¦    2    ¦  20021114093724    ¦  00000000000000    ¦  
+----+----------------+----------------+  
->这条指令没有明确地设定date2的列值,所以第一个TIMESTAMP列date1将被更新为当前时间  
 
 
UPDATE  test  SET  id=  1,date1=date1,date2=NOW()  WHERE  id=3;  
+----+----------------+----------------+  
 ¦  id    ¦  date1                      ¦  date2                      ¦  
+----+----------------+----------------+  
 ¦    1    ¦  20021114094009    ¦  20021114094320    ¦  
 ¦    2    ¦  20021114093724    ¦  00000000000000    ¦  
+----+----------------+----------------+  
->这条指令因设定date1=date1,所以在更新数据时date1列值并不会发生改变  
   而因设定date2=NOW(),所以在更新数据时date2列值会被更新为当前时间  
   此指令等效为  UPDATE  test  SET  id=  1,date1=date1,date2=NULL  WHERE  id=3;  
     
因MySQL返回的  TIMESTAMP  列为数字显示形式,  
 
---------------------------------------------------------------