sql >> Database >  >> RDS >> Mysql

Is het mogelijk om een ​​kolom te maken met een UNIX_TIMESTAMP standaard in MySQL?

De manier waarop MySQL de TIMESTAMP . implementeert gegevenstype, slaat het feitelijk de epochetijd op in de database. U kunt dus gewoon een TIMESTAMP . gebruiken kolom met een standaardwaarde van CURRENT_TIMESTAMP en pas de UNIX_TIMESTAMP() . toe ernaar toe als je het wilt weergeven als een 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)

Als u echter echt wilt dat het gegevenstype van de kolom INT . is , je kunt de suggestie van R. Bemrose gebruiken en deze via trigger instellen:

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. Een string invoegen in een andere string in MySQL met INSERT()

  2. Maak een CHECK-beperking in SQLite

  3. Hoe wijzig ik de positie van een kolom in een PostgreSQL-databasetabel?

  4. Ontsnappen aan MYSQL-opdrachtregels via Bash Scripting