我正在尝试这样做,但似乎MySQL不允许我这样做。是否有解决此问题的方法,或者我希望总是在我的INSERT查询中包括该函数?

CREATE TABLE foo(
  created INT NOT NULL DEFAULT UNIX_TIMESTAMP()
)

我知道可以接受CURRENT_TIMESTAMP缺省值的TIMESTAMP类型,但是我的客户坚持要在数据库中使用纪元时间。

最佳答案

MySQL实现TIMESTAMP数据类型的方式,实际上是将纪元时间存储在数据库中。因此,您只需要使用TIMESTAMP列(默认值为CURRENT_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的建议并通过触发器设置它:
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)

关于mysql - 是否可以在MySQL中使用UNIX_TIMESTAMP默认值创建列?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/5331026/

10-13 07:14
查看更多