标签:复制 意义 pre 整数 ror 精确 state inline .com
MySql中关于日期的类型有Date/Datetime/Timestamp三种类型。
日期赋值时,允许“不严格”语法:任何标点符都可以用做日期部分或时间部分之间的间割符。例如,‘98-12-31 11:30:45‘、‘98.12.31 11+30+45‘、‘98/12/31 11*30*45‘和‘98@12@31 11^30^45‘是等价的,对于不合法的将会转换为:0000-00-00 00:00:00
此类型的字段,存储数据格式为:YYYY-MM-DD,它支持的范围为‘1000-01-01‘到‘9999-12-31‘,并且允许使用字符串或数字为此列复制。
例如,日期格式的字段crt_date,通过字符串和数字复制后的结果如下:
update sys_tables set crt_date = 12331212 where table_name = ‘sys_dict‘; update sys_tables set crt_date = ‘1233-12-12‘ where table_name = ‘sys_dict_item‘;
日期和时间的组合,存储格式为:YYYY-MM-DD HH:MM:SS,它支持的范围为‘1000-01-01 00:00:00‘到‘9999-12-31 23:59:59‘,并且允许使用字符串或数字进行分配值。
例如:
update sys_tables set crt_date = 12331212121212 where table_name = ‘sys_dict‘; update sys_tables set crt_date = ‘1233-12-12 12:12:12‘ where table_name = ‘sys_dict_item‘;
这是时间戳,从1970-01-01 00:00:00到当前的时间差值(注意:当你在Java中输出[new Date(0)] 的时候,输出的是:Thu Jan 01 08:00:00 CST 1970,这是因为时区的概念,中国是东八区,所以对应的是早上八点),它精确到毫秒级别,范围为:1970-01-01 00:00:00 到 2037年(参考2038年问题),当值大于2037年就会抛出: [Error Code: 1292, SQL State: 22001] Data truncation: Incorrect datetime value: ‘20381212121212‘ for column ‘crt_date‘ at row 1。设置值时只允许设置数字类型的值。
在为TimeStamp类型字段赋值的时候,值必须大于19700101000000,否则就会抛出: [Error Code: 1292, SQL State: 22001] Data truncation: Incorrect datetime value: ‘10831212121212‘ for column ‘crt_date‘ at row 1。
例如:
update sys_tables set crt_date = 20081212121212 where table_name = ‘sys_dict‘;
MySQL中时间类型用Time表示。
MySQL以‘HH:MM:SS‘格式检索和显示TIME值(或对于大的小时值采用‘HHH:MM:SS‘格式)。TIME值的范围可以从‘-838:59:59‘到‘838:59:59‘。小时部分会因此大的原因是TIME类型不仅可以用于表示一天的时间(必须小于24小时),还可能为某个事件过去的时间或两个事件之间的时间间隔(可以大于24小时,或者甚至为负)。
格式说明:
MySQL中用year表示年类型
MySQL以YYYY格式检索和显示YEAR值。范围是1901到2155。
可以指定各种格式的YEAR值:
标签:复制 意义 pre 整数 ror 精确 state inline .com
原文地址:http://www.cnblogs.com/wlzjdm/p/6953398.html