sql >> Database >  >> RDS >> Mysql

Kan ik MysQL-tijdstempel vergelijken met datetime-kolommen? is het erg?

Ja, je kunt een datetime . vergelijken met een timestamp . Het is niet slecht, maar let op het volgende:

Van MySQL Reference Manual ::De typen DATETIME, DATE en TIMESTAMP .

Merk op hoe de volgende testgevallen allemaal goed werken:

CREATE TABLE t1 (d1 datetime, d2 timestamp);

INSERT INTO t1 VALUES ('1968-01-01 00:00:00', '1980-01-01 00:00:00');
INSERT INTO t1 VALUES ('2040-01-01 00:00:00', '1980-01-01 00:00:00');

SELECT * FROM t1 WHERE d2 < d1;
+---------------------+---------------------+
| d1                  | d2                  |
+---------------------+---------------------+
| 2040-01-01 00:00:00 | 1980-01-01 00:00:00 |
+---------------------+---------------------+
1 row in set (0.00 sec)

SELECT * FROM t1 WHERE d2 > d1;
+---------------------+---------------------+
| d1                  | d2                  |
+---------------------+---------------------+
| 1968-01-01 00:00:00 | 1980-01-01 00:00:00 |
+---------------------+---------------------+
1 row in set (0.00 sec)

SELECT * FROM t1 WHERE d2 < '2040-01-01 00:00:00';
+---------------------+---------------------+
| d1                  | d2                  |
+---------------------+---------------------+
| 1968-01-01 00:00:00 | 1980-01-01 00:00:00 |
| 2040-01-01 00:00:00 | 1980-01-01 00:00:00 |
+---------------------+---------------------+
2 rows in set (0.00 sec)

SELECT * FROM t1 WHERE d2 > '2040-01-01 00:00:00';
Empty set (0.00 sec)



  1. Een formulier met 50 velden indienen bij meerdere tabellen; reguliere POST, AJAX POST of iets anders?

  2. Juistheid en beperkingen

  3. Database wordt niet automatisch bijgewerkt met MySQL en Python

  4. Oracle SQL*Plus gebruiken