Đối với điều này, bạn có thể sử dụng STR_TO_DATE (). Đầu tiên chúng ta hãy tạo một bảng -
mysql> create table DemoTable1565 -> ( -> ArrivalDatetime varchar(40) -> ); Query OK, 0 rows affected (0.82 sec)
Chèn một số bản ghi vào bảng bằng lệnh chèn -
mysql> insert into DemoTable1565 values('10/01/2019 21:29:35'); Query OK, 1 row affected (0.22 sec) mysql> insert into DemoTable1565 values('10/13/2019 4:56:00'); Query OK, 1 row affected (0.14 sec) mysql> insert into DemoTable1565 values('10/13/2018 12:40:46'); Query OK, 1 row affected (0.10 sec) mysql> insert into DemoTable1565 values('10/13/2019 21:30:00'); Query OK, 1 row affected (0.58 sec)
Hiển thị tất cả các bản ghi từ bảng bằng câu lệnh select -
mysql> select * from DemoTable1565;
Điều này sẽ tạo ra kết quả sau -
+---------------------+ | ArrivalDatetime | +---------------------+ | 10/01/2019 21:29:35 | | 10/13/2019 4:56:00 | | 10/13/2018 12:40:46 | | 10/13/2019 21:30:00 | +---------------------+ 4 rows in set (0.00 sec)
Ngày hiện tại như sau -
mysql> select now(); +---------------------+ | now() | +---------------------+ | 2019-10-13 21:34:14 | +---------------------+ 1 row in set (0.00 sec)
Đây là truy vấn để chuyển đổi từ varchar sang datetime và so sánh -
mysql> select * from DemoTable1565 where str_to_date(ArrivalDatetime,'%m/%d/%Y')=curdate();
Điều này sẽ tạo ra kết quả sau -
+---------------------+ | ArrivalDatetime | +---------------------+ | 10/13/2019 4:56:00 | | 10/13/2019 21:30:00 | +---------------------+ 2 rows in set, 4 warnings (0.03 sec)