我正在try 这样做,但似乎MySQL不允许我这样做.这个问题有解决方案吗?或者我是否应该在插入查询中始终包含该函数?
CREATE TABLE foo(
created INT NOT NULL DEFAULT UNIX_TIMESTAMP()
)
我知道时间戳类型接受当前的时间戳默认值,但我的客户坚持在数据库中使用纪元时间.
我正在try 这样做,但似乎MySQL不允许我这样做.这个问题有解决方案吗?或者我是否应该在插入查询中始终包含该函数?
CREATE TABLE foo(
created INT NOT NULL DEFAULT UNIX_TIMESTAMP()
)
我知道时间戳类型接受当前的时间戳默认值,但我的客户坚持在数据库中使用纪元时间.
MySQL实现TIMESTAMP
数据类型的方式实际上是在数据库中存储纪元时间.因此,如果您希望将其显示为int,则可以只使用TIMESTAMP
列,默认值为CURRENT_TIMESTAMP
,并对其应用UNIX_TIMESTAMP()
:
CREATE TABLE foo(
created TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP
);
insert into foo values (current_Date()),(now());
select unix_timestamp(created) from foo;
+-------------------------+
| unix_timestamp(created) |
+-------------------------+
| 1300248000 |
| 1300306959 |
+-------------------------+
2 rows in set (0.00 sec)
但是,如果您真的希望列的数据类型为INT
,可以使用R.Bemrose的建议并通过触发器进行设置:
CREATE TABLE foo(
created INT NULL
);
delimiter $$
create trigger tr_b_ins_foo before insert on foo for each row
begin
if (new.created is null)
then
set new.created = unix_timestamp();
end if;
end $$
delimiter ;
insert into foo values (unix_timestamp(current_Date())), (null);
select created from foo;
+------------+
| created |
+------------+
| 1300248000 |
| 1300306995 |
+------------+
2 rows in set (0.00 sec)