目录

SQL 使用日期


SQL 日期

使用日期时最困难的部分是确保尝试插入的日期格式与数据库中日期列的格式匹配。

只要您的数据仅包含日期部分,您的查询就会按预期工作。然而,如果涉及到时间部分,事情就会变得更加复杂。


SQL 日期数据类型

MySQL具有以下数据类型,用于在数据库中存储日期或日期/时间值:

  • DATE- 格式 YYYY-MM-DD
  • DATETIME- 格式:YYYY-MM-DD HH:MI:SS
  • TIMESTAMP- 格式:YYYY-MM-DD HH:MI:SS
  • YEAR- 格式 YYYY 或 YY

SQL服务器具有以下数据类型,用于在数据库中存储日期或日期/时间值:

  • DATE- 格式 YYYY-MM-DD
  • DATETIME- 格式:YYYY-MM-DD HH:MI:SS
  • SMALLDATETIME- 格式:YYYY-MM-DD HH:MI:SS
  • TIMESTAMP- 格式:唯一的数字

笔记:当您在数据库中创建新表时,将为列选择日期类型!


SQL 处理日期

看下表:

订单表

OrderId ProductName OrderDate
1 Geitost 2008-11-11
2 Camembert Pierrot 2008-11-09
3 Mozzarella di Giovanni 2008-11-11
4 Mascarpone Fabioli 2008-10-29

现在我们要从上表中选择 OrderDate 为 "2008-11-11" 的记录。

我们使用以下SELECT陈述:

SELECT * FROM Orders WHERE OrderDate='2008-11-11'

结果集将如下所示:

OrderId ProductName OrderDate
1 Geitost 2008-11-11
3 Mozzarella di Giovanni 2008-11-11

笔记:如果不涉及时间成分,可以轻松比较两个日期!

现在,假设 "Orders" 表如下所示(注意 "OrderDate" 列中添加的时间组件):

OrderId ProductName OrderDate
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'

我们不会得到任何结果!这是因为查询仅查找没有时间部分的日期。

提示:为了使您的查询简单且易于维护,请勿在日期中使用时间组件,除非必须这样做!