sql >> Databáze >  >> RDS >> Mysql

Je možné v MySQL vytvořit sloupec s výchozím nastavením UNIX_TIMESTAMP?

Způsob, jakým MySQL implementuje TIMESTAMP datový typ, je to vlastně ukládání času epochy do databáze. Můžete tedy použít pouze TIMESTAMP sloupec s výchozí hodnotou CURRENT_TIMESTAMP a použijte UNIX_TIMESTAMP() k němu, pokud jej chcete zobrazit jako 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)

Pokud však opravdu chcete, aby datový typ sloupce byl INT , můžete použít návrh R. Bemrose a nastavit jej pomocí triggeru:

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. mysql_num_rows() očekává, že parametr 1 bude zdrojem, zadaný booleovský

  2. Jak vytvořit tabulku s omezením cizího klíče v SQL Server - SQL Server / TSQL výukový program, část 66

  3. Dynamicky nastavit __tablename__ pro sharding v SQLAlchemy?

  4. Jak svázat parametry s nezpracovaným dotazem DB v Laravelu, který se používá na modelu?