Kit*_*nde 35 mysql sql database database-design database-schema
我试图这样做,但似乎MySQL不允许我这样做.是否有解决此问题的方法,或者我希望在我的INSERT查询中始终包含该函数?
CREATE TABLE foo(
created INT NOT NULL DEFAULT UNIX_TIMESTAMP()
)
Run Code Online (Sandbox Code Playgroud)
我知道接受CURRENT_TIMESTAMP默认值的TIMESTAMP类型,但我的客户端坚持在数据库中使用纪元时间.
Ike*_*ker 50
MySQL实现TIMESTAMP
数据类型的方式实际上是将纪元时间存储在数据库中.所以你可以使用一个TIMESTAMP
默认值为的列,如果要将其显示为int,则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)
Run Code Online (Sandbox Code Playgroud)
但是,如果您真的想要列的数据类型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)
Run Code Online (Sandbox Code Playgroud)
您可以为此创建触发器.
用于插入
CREATE TRIGGER {trigger_name} BEFORE INSERT ON {table_name} FOR EACH ROW SET new.{field_name} = UNIX_TIMESTAMP(NOW());
CREATE TRIGGER my_trigger_name_1 BEFORE INSERT ON foo FOR EACH ROW SET new.created = UNIX_TIMESTAMP(NOW());
更新
CREATE TRIGGER {trigger_name} BEFORE UPDATE ON {table_name} FOR EACH ROW SET new.{field_name} = UNIX_TIMESTAMP(NOW());
CREATE TRIGGER my_trigger_name_2 BEFORE UPDATE ON foo FOR EACH ROW SET new.created = UNIX_TIMESTAMP(NOW());
注意:我不知道MYSQL TRIGGER的性能
请仔细阅读这些链接
小智 8
正如ktretyak 的回答,使用 MySQL v8+,您可以使用括号来做到这一点。
CREATE TABLE foo(
created INT NOT NULL DEFAULT (UNIX_TIMESTAMP())
)
Run Code Online (Sandbox Code Playgroud)
经过一些插入后,您可以看到它工作正常。
(在 MySQL 8.0.26 上测试 + 仅文本颜色修补)
或者,您也可以使用表达式。
检查ktretyak 的答案。
我写这个答案而不是评论或编辑答案(尝试并拒绝),
因为缺乏声誉,并且使用括号现在是一个很好的解决方案。