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)