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

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

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
MYSQL中怎样设列的默认值为Now()的介绍

MYSQL中怎样设列的默认值为Now()的介绍 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 |   |   +----+----------------+   ALTER TABLE test CHANGE date1 date1 TIMESTAMP(14);   SELECT * FROM test;   +----+----------------+   | id | date1     |   +----+----------------+   | 1 | 20021114093723 |   +----+----------------+      你可以使用TIMESTA

文档评论(0)

xcs88858 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档