WEB开发网
开发学院数据库MySQL MYSQL中怎样设列的默认值为Now()的介绍 阅读

MYSQL中怎样设列的默认值为Now()的介绍

 2008-12-19 11:14:52 来源:WEB开发网   
核心提示: 1、虽然你建表时定义了列TIMESTAMP(8),但在你进行数据插入与更新时TIMESTAMP列实际上保存了14位的数据(包括年月日时分秒),MYSQL中怎样设列的默认值为Now()的介绍(2),只不过在你进行查询时MySQL返回给你的是8位的年月日数据,如果你使用ALTER TABLE拓

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 |
  +----+----------------+

上一页  1 2 3 4  下一页

Tags:MYSQL 怎样 默认

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接