sql >> Database teknologi >  >> RDS >> Mysql

Er det muligt at oprette en kolonne med en UNIX_TIMESTAMP standard i MySQL?

Den måde, MySQL implementerer TIMESTAMP på datatype, er det faktisk at gemme epoketiden i databasen. Så du kunne bare bruge en TIMESTAMP kolonne med standardværdien CURRENT_TIMESTAMP og anvend UNIX_TIMESTAMP() til den, hvis du vil vise den som en 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)

Men hvis du virkelig ønsker, at kolonnens datatype skal være INT , kan du bruge R. Bemroses forslag og indstille det via trigger:

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)


  1. Hvordan kan jeg omdøbe kolonne i laravel ved hjælp af migration?

  2. nul pointer undtagelse, når du forsøger at få adgang til DatabaseHelper i en kopieret database fra aktiver til data\data\

  3. Interessante ting om I STEDET FOR triggere

  4. Lagring af filer i SQL Server