MySQL 使用日期
MySQL 日期
使用日期时最困难的部分是确保要插入的日期格式与数据库中日期列的格式匹配。
只要您的数据只包含日期部分,您的查询将按预期工作。但是,如果涉及时间部分,就会变得更加复杂。
MySQL 日期数据类型
MySQL 提供以下数据类型用于在数据库中存储日期或日期/时间值
-
DATE
- 格式 YYYY-MM-DD -
DATETIME
- 格式:YYYY-MM-DD HH:MI:SS TIMESTAMP
- 格式:YYYY-MM-DD HH:MI:SS-
YEAR
- 格式 YYYY 或 YY
注意: 日期数据类型在您在数据库中创建新表时为列设置!
使用日期
查看下表
订单表
订单 ID | 产品名称 | 订单日期 |
---|---|---|
1 | Geitost | 2008-11-11 |
2 | Camembert Pierrot | 2008-11-09 |
3 | Mozzarella di Giovanni | 2008-11-11 |
4 | Mascarpone Fabioli | 2008-10-29 |
现在我们想从上面的表中选择订单日期为“2008-11-11”的记录。
我们使用以下 SELECT
语句
SELECT * FROM Orders WHERE OrderDate='2008-11-11'
结果集将如下所示
订单 ID | 产品名称 | 订单日期 |
---|---|---|
1 | Geitost | 2008-11-11 |
3 | Mozzarella di Giovanni | 2008-11-11 |
注意:如果日期没有时间部分,则可以轻松地比较两个日期!
现在,假设“订单”表如下所示(请注意“订单日期”列中添加了时间部分)
订单 ID | 产品名称 | 订单日期 |
---|---|---|
1 | Geitost | 2008-11-11 13:23:44 |
2 | Camembert Pierrot | 2008-11-09 15:45:21 |
3 | Mozzarella di Giovanni | 2008-11-11 11:12:01 |
4 | Mascarpone Fabioli | 2008-10-29 14:56:59 |
如果我们使用与上面相同的SELECT
语句
SELECT * FROM Orders WHERE OrderDate='2008-11-11'
我们将得到没有结果!这是因为查询只查找没有时间部分的日期。
提示:为了使您的查询保持简单易于维护,除非必要,否则请不要在您的日期中使用时间部分!