先看下边的SQL 语句

CREATE TABLE #DateTest(

Id INT,

SampleDate DATETIME

)

INSERT INTO #DateTest VALUES(1,'1 jan 2010 10:30')

INSERT INTO #DateTest VALUES(2,'2 jan 2010 23:59')

INSERT INTO #DateTest VALUES(3,'3 jan 2010 12:34')

INSERT INTO #DateTest VALUES(4,'3 jan 2010 12:56')

INSERT INTO #DateTest VALUES(5,'4 jan 2010')

INSERT INTO #DateTest VALUES(6,'4 jan 2010 00:00')

INSERT INTO #DateTest VALUES(7,'4 jan 2010 13:31')

INSERT INTO #DateTest VALUES(8,'4 jan 2010 00:10')

INSERT INTO #DateTest VALUES(9,'5 jan 2010 12:01')

DECLARE @DATE1 DATETIME

DECLARE @DATE2 DATETIME

SELECT @DATE1 = '2 jan 2010'

SELECT @DATE2 = '4 jan 2010'

SELECT Id

FROM #DateTest

WHERE SampleDate BETWEEN  @DATE1 AND @DATE2

DROP TABLE #DateTest

查询语句查询的是'2010-01-02 00:00:00.000'到'2010-01-04 00:00:00.000'的时间,所以查询结果为2,3,4,5,6。

再执行如下的SQL 语句:

CREATE TABLE #DateTest(

Id INT,

SampleDate DATETIME

)

INSERT INTO #DateTest VALUES(1,'2010-01-01T10:30:21.000')

INSERT INTO #DateTest VALUES(2,'2010-01-01T23:59:59.999')

INSERT INTO #DateTest VALUES(3,'2010-01-02T12:56:00.000')

INSERT INTO #DateTest VALUES(4,'2010-01-02T23:59:59.998')

INSERT INTO #DateTest VALUES(5,'2010-01-03T00:00:00.000')

INSERT INTO #DateTest VALUES(6,'2010-01-03T13:31:00.000')

INSERT INTO #DateTest VALUES(7,'2010-01-04T00:00:00.001')

INSERT INTO #DateTest VALUES(8,'2010-01-04T00:00:00.002')

INSERT INTO #DateTest VALUES(9,'2010-01-05T12:01:00.002')

DECLARE @DATE1 DATETIME

DECLARE @DATE2 DATETIME

SELECT @DATE1 = '2 jan 2010'

SELECT @DATE2 = '4 jan 2010'

SELECT *

FROM #DateTest

WHERE SampleDate BETWEEN  @DATE1 AND @DATE2

DROP TABLE #DateTest

查询结果为:

Id          SampleDate

----------- -----------------------

2           2010-01-02 00:00:00.000

3           2010-01-02 12:56:00.000

4           2010-01-02 23:59:59.997

5           2010-01-03 00:00:00.000

6           2010-01-03 13:31:00.000

7           2010-01-04 00:00:00.000

在执行结果中,ID为2的日期变成2010-01-02 00:00:00.000.这是为什么呢?

因为,在SQL SERVER中DATETIME表示的时间为00:00:00到23:59:59.997,它的时间精度为1/300秒,在使用时会舍入到舍入到 .000、.003 或 .007 秒三个增量。如下表是DATETIME秒的小数部分精度的舍入。

用户指定的值

系统存储的值

01/01/98 23:59:59.999

1998-01-02 00:00:00.000

01/01/98 23:59:59.995

01/01/98 23:59:59.996

01/01/98 23:59:59.997

01/01/98 23:59:59.998

1998-01-01 23:59:59.997

01/01/98 23:59:59.992

01/01/98 23:59:59.993

01/01/98 23:59:59.994

1998-01-01 23:59:59.993

01/01/98 23:59:59.990

根据这一规则,在上边的SQL语句中,实际插入表中的数据为:

Id          SampleDate

----------- -----------------------

1           2010-01-01 10:30:21.000

2           2010-01-02 00:00:00.000

3           2010-01-02 12:56:00.000

4           2010-01-02 23:59:59.997

5           2010-01-03 00:00:00.000

6           2010-01-03 13:31:00.000

7           2010-01-04 00:00:00.000

8           2010-01-04 00:00:00.003

9           2010-01-05 12:01:00.003

在查询某一天当中的数据时,如果查询条件为BETWEEN  '2010-01-02T00:00:00.000'

AND '2010-01-02T23:59:59.999',实际查询的是'2010-01-02T00:00:00.000'

到'2010-01-03T00:00:00.000'之间的数据。

例子如,将上边的SQ语句的查询条件更改为:

SELECT @DATE1 = '2010-01-02T00:00:00.000'

SELECT @DATE2 = '2010-01-02T23:59:59.999'

其执行结果:

Id          SampleDate

----------- -----------------------

2           2010-01-02 00:00:00.000

3           2010-01-02 12:56:00.000

4           2010-01-02 23:59:59.997

5           2010-01-03 00:00:00.000

所以,在查询某一天的数据时,查询条件应为:BETWEEN  '2010-01-02T00:00:00.000'

AND '2010-01-02T23:59:59.998'。

更改查询条件,重新执行查询:

SELECT @DATE1 = '2010-01-02T00:00:00.000'

SELECT @DATE2 = '2010-01-02T23:59:59.998'

其执行结果为:

Id          SampleDate

----------- -----------------------

2           2010-01-02 00:00:00.000

3           2010-01-02 12:56:00.000

4           2010-01-02 23:59:59.997

在SQL SERVER 2008中新增了Datetime2类型,可以提供更高的时间精度,且可以自定义时间精度,以后可以使用这种数据类型。

【转】SQL SERVER DateTime类型的精度的更多相关文章

  1. sql 根据日期模糊查询&SQL Server dateTime类型 模糊查询

    曾经遇到这样的情况,在数据库的Meeting表中有PublishTime (DateTime,8)字段,用来存储一个开会时间,在存入时由于要指明开会具体时间,故格式为yyyy-mm-dd hh:mm: ...

  2. sql server datetime类型字段使用isnull返回1900-01-01 00:00:00.000的问题

    若字段定义的类型为datetime,插入为''(空),那么会默认值为1900-01-01 00:00:00.000 解决方法查询的时候过滤下cast(nullif('','') as datetime ...

  3. SQL Server时间类型datetime

    SQL Server时间类型datetime 兼容ADO的COleDateTime. SQL datetime 日期和时间数据,可表示1753.1.1 至 9999.12.31的时间,精度为1/300 ...

  4. 【转】一道SQL SERVER DateTime的试题

    学习过上一篇SQL SERVER DateTime精度的文章后.再来做一道题. IF ('2011-07-31 00:00:00.000' BETWEEN '2011-07-01' and '2011 ...

  5. SQL Server 字段类型 decimal(18,6)小数点前是几位?记一次数据库SP的BUG处理

    原文:SQL Server 字段类型 decimal(18,6)小数点前是几位?记一次数据库SP的BUG处理 SQL Server 字段类型 decimal(18,6)小数点前是几位? 不可否认,这是 ...

  6. SQL Server锁类型

    SQL Server锁类型(SQL)收藏 1. HOLDLOCK: 在该表上保持共享锁,直到整个事务结束,而不是在语句执行完立即释放所添加的锁. 2. NOLOCK:不添加共享锁和排它锁,当这个选项生 ...

  7. Sqlserver:datetime类型的精度(不确定性)问题

    转自http://www.xuebuyuan.com/212359.html 背景:近日进行大型数据表的迁移处理,遭遇创建 主键时 索引键值重复的错误.仔细检查原始表,并未有任何问题.分析后发现是迁移 ...

  8. MS SQL server对象类型type

    执行下面代码,将获取ms sql server对象类型以及其说明 IF OBJECT_ID('tempdb.dbo.#type') IS NOT NULL DROP TABLE #type CREAT ...

  9. SQL Server 方言类型映射问题

    关于SQL Server的类型映射问题,例如,nvarchar无法进行hibernate类型映射,需要通过convert进行类型转换方可进行获取

随机推荐

  1. 274. H-Index

    Given an array of citations (each citation is a non-negative integer) of a researcher, write a funct ...

  2. MATLAB符号运算 分类: 图像处理 2015-07-31 22:53 3人阅读 评论(0) 收藏

    1.符号运算 使用MATLAB可以进行多项式乘除运算,也可以进行因式分解. 例1. 多项式乘除运算(x+3)3 >> syms x; >> expand((x+3)^3) an ...

  3. LeetCode()Substring with Concatenation of All Words 为什么我的超时呢?找不到原因了!!!

    超时代码 class Solution { public: vector<int> findSubstring(string s, vector<string>& wo ...

  4. 学生管理系统-火车订票系统 c语言课程设计

    概要: C 语言课程设计一---学生管理系统 使使用 C 语言实现学生管理系统.系统实现对学生的基本信息和考试成绩的 管理.采用终端命令界面,作为系统的输入输出界面.采用文件作为信息存储介质. 功能描 ...

  5. kuangbin_ShortPath S (POJ 3169)

    被cow类题目弄得有些炸裂 想了好久好久写了120多行 依然长跪不起发现计算约束条件的时候还是好多麻烦的地方过不去 然后看了看kuangbin的blog 都是泪啊 差分约束的方式做起来只要70多行啊炒 ...

  6. android:id="@+id/button1" 与 android:id="@id/button1" 区别 @string

    一.android:id="@+id/button1" 与 android:id="@id/button1" 区别 android:id="@+id/ ...

  7. Redis GEO ,GEOHASH,Spatial_index

    https://matt.sh/redis-geo http://antirez.com/latest/0 http://invece.org/ https://github.com/davidmot ...

  8. PHP-关于$_SERVER

    类似于Nginx中的请求头,所有header,都可以使用 $http_xxx来使用,比如$http_accept,甚至包括自定义的,比如,$http_x_forwarded_host proxy_se ...

  9. cacti 添加

    一,为已有host添加新的监控图 (基于snmp) 在console控制台下点击“New Graphs”,选择要添加监控图的主机.在Graph Templates中选择一个Graph模板,本例选择SN ...

  10. unity vr sample on htc vive

    http://forum.unity3d.com/threads/unity-vr-samples-now-available.372753/