很多时候,为了简单,我们在设计数据表的时候,都需要设置时间字段为当前时间。可是MySQL 中,默认值无法使用函数,也就是你无法设置某一列,默认值是 NOW () 这样的处理。那怎么办呢?
TIMESTAMP 数据类型。插入的时候,忽略该列即可。
代码如下 | 复制代码 |
dt TIMESTAMP
|
注意:MySQL的timestamp类型时间范围between '1970-01-01 00:00:01' and '2038-01-19 03:14:07',超出这个范围则值记录为'0000-00-00 00:00:00'
该类型的一个重要特点就是保存的时间与时区密切相关,上述所说的时间范围是UTC(Universal Time Coordinated)标准,指的是经度0度上的标准时间,我国日常生活中时区以首都北京所处的东半球第8区为基准,统一使用东8区时间(俗称北京时 间),比UTC要早8个小时,服务器的时区设置也遵照此标准,因此对应过来timestamp的时间范围则应校准为'1970-01-01 08:00:01' and '2038-01-19 11:14:07',也就是说东八区的1970-1-1 08:00:01等同于UTC 1970-1-1 00:00:01。
需要特点注意,timestamp类型的时间不仅仅与写入记录时的时区有关,显示时也与时区有关,例如:
代码如下 | 复制代码 |
mysql> desc j1_dt; +-------+-----------+------+-----+-------------------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+-----------+------+-----+-------------------+-------+ | dt | timestamp | NO | | CURRENT_TIMESTAMP | | +-------+-----------+------+-----+-------------------+-------+ 1 row in set (0.00 sec) mysql> insert into j1_dt values ('1970-01-01 08:00:01'); Query OK, 1 row affected (0.00 sec) mysql> select * from j1_dt; +---------------------+ | dt | +---------------------+ | 1970-01-01 08:00:01 | +---------------------+ 1 row in set (0.00 sec) mysql> set time_zone='+0:00'; Query OK, 0 rows affected (0.00 sec) mysql> select * from j1_dt; +---------------------+ | dt | +---------------------+ | 1970-01-01 00:00:01 | +---------------------+ 1 row in set (0.00 sec) mysql> set time_zone='+1:00'; Query OK, 0 rows affected (0.00 sec) mysql> select * from j1_dt; +---------------------+ | dt | +---------------------+ | 1970-01-01 01:00:01 | +---------------------+ 1 row in set (0.00 sec) |
如上述所示,根据时区的不同,显示的日期也是不一样的,这正是timestamp类型在MySQL日期类型中独有的时区特点。
如果向timestamp类型列插入的值超出了指定范围,则实际实际保存的值为'0000-00-00 00:00:00',并触发一个警告信息:
代码如下 | 复制代码 |
mysql> set time_zone='+8:00'; Query OK, 0 rows affected (0.00 sec) mysql> select * from j1_dt; +---------------------+ | dt | +---------------------+ | 1970-01-01 08:00:01 | +---------------------+ 1 row in set (0.00 sec) mysql> insert into j1_dt values ('1970-01-01 00:00:01'); Query OK, 1 row affected, 1 warning (0.00 sec) mysql> show warnings; +---------+------+------------------------------------------------------+ | Level | Code | Message | +---------+------+------------------------------------------------------+ | Warning | 1264 | Out of range value adjusted for column 'dt' at row 1 | +---------+------+------------------------------------------------------+ 1 row in set (0.00 sec) mysql> select * from j1_dt; +---------------------+ | dt | +---------------------+ | 1970-01-01 08:00:01 | | 0000-00-00 00:00:00 | +---------------------+ 2 rows in set (0.00 sec) |
触发的警告信息在MySQL层面仅是个警告而并非错误,前端应用的try catch捕获不到,不过,由于实际写入的数据并非期望值,还是有可能埋下一些隐患,这些隐患一旦显露,就有可能触发前端应用出现异常。
对于timestamp类型,在实际应用中务必理解时区的概念,在设置timestamp列默认值,及实际赋值时务必明确写入的值实际保存时的状态,尽量避免埋入隐患。对于现有已经出错的记录,可以考虑通过批量UPDATE及修改表结构的方式予以处理。
关于 timestamp最小值与最大值一些测试例子
代码如下 | 复制代码 |
-mysql timestamp 最小值 insert into test values(1,'zjadolf','1970-01-01 08:01:00')--插入成功 insert into test values(2,'zjadolf','1970-01-01 08:00:00')-- insert into test values(3,'zjadolf','1970-01-01 08:00:30')--ok 可以插入 insert into test values(1,'zjadolf','1970-01-01 08:00:01')--ok 可以插入 insert into test values(1,'zjadolf','1970-01-01 08:00:00')--不可以插入 报错 |
看样子1970-01-01 08:00:01应该是mysql中timestamp允许的最小值,大家使用时应该注意下
验证下我们插入如下记录应该报错:
代码如下 | 复制代码 |
insert into test values(1,'zjadolf','1969-01-01 08:01:02') Category Timestamp Duration Message Line Position Error 2010/9/27 15:09:29 0:00:00.000 MySQL Database Error: Incorrect datetime value: '1969-01-01 08:01:02' for column 'hiredate' at row 1 2 0 |
--果然报错
难怪我在测试使用toad for mysql import tool导入1000000数据导到 日期为:'1970-01-01 07:57:09' 这条数据的时候报错呢!结果小于这个日期的记录都导不进去!悲剧啊!
查看官方解释文档如下:
TIMESTAMP值不能早于1970或晚于2037。
当你需要同时包含日期和时间信 息的值时则使用DATETIME类型。MySQL以'YYYY-MM-DD HH:MM:SS'格式检索和显示DATETIME值。支持的范围为'1000-01-01 00:00:00'到'9999-12-31 23:59:59'。(“支持”表示尽管先前的值可能工作,但没有保证)。
当你只需要日期值而不需要时间部分时应使用DATE类型。MySQL用'YYYY-MM-DD'格式检索和显示DATE值。支持的范围是'1000-01-01'到 '9999-12-31'。
TIMESTAMP列类型的属性不固定,取决于MySQL版本和服务器运行的SQL模式。这些属性将在本节后面描述。
看样子如果要支持较长时间的日期,那就需要使用datetime类型。
代码如下 | 复制代码 |
insert into t4 values(1,'1900-01-01 08:01:02') |
这样看来mysql 的timestamp 和db2 的timestamp还是不一样的!
db2 的timestamp 类型没有mysql 这样的限制
相关推荐
如果你有一个已经存在的表,并希望添加一个带有默认当前时间的新字段,可以使用`ALTER TABLE`命令: ```sql ALTER TABLE `existing_table` ADD COLUMN `updated_at` TIMESTAMP NULL DEFAULT CURRENT_TIMESTAMP ON ...
以下是对在MySQL建表过程中如何将日期设置为默认获取当前系统时间这一知识点的深入探讨。 ### 1. 使用`CURRENT_TIMESTAMP`作为默认值 在创建表结构时,可以指定某一列(通常是时间戳类型)的默认值为`CURRENT_...
在MySQL中,`TIMESTAMP`字段可以设置为自动更新,例如,当记录被插入或更新时,它会记录当前的时间。此外,MySQL允许在一个表中最多定义两个自动更新的`TIMESTAMP`字段,其中一个可以设置为`CURRENT_TIMESTAMP`作为...
TIMESTAMP 类型是 MySQL 中的一种日期时间类型,可以自动更新当前时间。使用 TIMESTAMP 类型可以实现自动设置默认时间值的功能。例如,创建一个名为 `test_time` 的表,其中包含一个 `create_time` 字段,类型为 ...
MySQL datetime 设置当前时间为默认值 MySQL 中的 datetime 类型字段无法使用函数作为默认值,因此无法使用 `create_time datetime default now()` 的形式设置默认值。代替的方案是使用 TIMESTAMP 类型代替 ...
这种情况下,字段初始值默认为0,在创建新记录时,不会自动设置为当前时间,但每次更新记录时会更新为当前时间。 4. **TIMESTAMP DEFAULT ‘yyyy-mm-dd hh:mm:ss' ON UPDATE CURRENT_TIMESTAMP** 在创建新记录时...
`modify_time`字段则更进一步,它不仅在插入时默认为当前时间,而且在更新记录时也会自动更新为当前时间,这得益于`ON UPDATE CURRENT_TIMESTAMP`子句。 然而,当你试图通过MySQL的图形化工具,如Navicat,来修改已...
- 默认情况下,timestamp字段在插入新记录时自动设置为当前时间。然而,如果你希望timestamp仅在插入时设置,而在后续更新时不改变,你可以只使用`TIMESTAMP DEFAULT CURRENT_TIMESTAMP`。这将确保时间戳只记录创建...
这使得该列在插入新行时默认设置为当前时间,并在后续更新时自动更新为新的当前时间。 3. 第二个TIMESTAMP列,如果没有声明为NULL或DEFAULT子句,将默认为'0000-00-00 00:00:00',在插入新行时不提供值时,该列会用...
- `TIMESTAMP`:混合日期和时间值,格式通常为`YYYYMMDD HHMMSS`,但可自定义,占用4个字节,支持设置为系统当前时间,默认值可为`CURRENT_TIMESTAMP`。 2. **应用场景**: - 创建时间:记录数据插入时的日期和...
这些函数在处理日期相关操作时非常实用,例如设置默认插入日期或计算日期间隔。 若你需要当前时间(小时、分钟和秒),则可以使用`curtime()`函数,它返回`HH:MM:SS`格式的时间,比如`14:30:00`。与之类似的,`...
它会在插入新行时自动填充当前时间,并且在更新行时也可以自动更新为当前时间。 **特点:** - 自动维护当前时间。 - 存储格式为 YYYYMMDDHHMMSS。 - 受时区设置的影响。 **应用场景:** - 需要自动记录创建或更新...
如果未提供任何参数,则`UNIX_TIMESTAMP()`会默认返回当前时间的Unix时间戳值: ```sql SELECT UNIX_TIMESTAMP(); ``` #### 3. 特殊日期格式的处理 在某些情况下,可能需要处理特殊格式的日期,例如`YYYYMMDD`或`...
- 如果需要字段默认为当前时间,且不需要考虑时区,TIMESTAMP可以设置默认值,简化插入操作。 总结起来,MySQL中的datetime和timestamp各有优劣,选择使用哪种类型取决于具体的需求和场景。在处理全球范围内的数据...
然而,MySQL的一个限制是每个表只能有一个Timestamp字段默认为CURRENT_TIMESTAMP,并且如果该字段被设置为NOT NULL,MySQL会隐式地将其设为默认值。这意味着在同一个表中不能有两个Timestamp字段都使用这两个特性。 ...