本文介绍了是否可以创建一个在MySQL中使用UNIX_TIMESTAMP默认值的列?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我想这样做,但似乎MySQL不允许我。有没有这个问题的解决方案,或者我预计总是包括我的INSERT查询中的函数?
CREATE TABLE foo(
created INT NOT NULL DEFAULT UNIX_TIMESTAMP()
)
接受CURRENT_TIMESTAMP默认值的TIMESTAMP类型,但我的客户端坚持在数据库中使用纪元时间。
推荐答案
TIMESTAMP 数据类型,它实际上是将时期时间存储在数据库中。因此,您只需使用默认值为 CURRENT_TIMESTAMP 的 TIMESTAMP 列,并应用 UNIX_TIMESTAMP )如果你想显示为一个int:
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的建议,并通过触发器设置:
在这张名为BookRecod表中:
列:vTime 设置默认值为当前UNIX时间戳,在触发器代码中使用NEW关键字来访问该行的vTime字段值,并使用正确的列名。触发器将在插入新记录时检查’vTime’列的值是否为NULL。如果是,它将使用UNIX_TIMESTAMP()函数将当前时间的UNIX时间戳设置为’vTime’列的默认值。
sql代码:
delimiter $$
CREATE TRIGGER setDefInsTime BEFORE INSERT ON BookRecod FOR EACH ROW
BEGIN
IF ( new.vTime IS NULL ) THEN
SET new.vTime = unix_timestamp( CURRENT_DATE ( ) );
END IF;
END $$
delimiter;
增加数据后自动添加当前时间戳
这篇关于是否可以创建一个在MySQL中使用UNIX_TIMESTAMP默认值的列?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持AwingNet!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。