【转】SQL SERVER DateTime类型的精度
先看下边的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类型的精度的更多相关文章
- sql 根据日期模糊查询&SQL Server dateTime类型 模糊查询
曾经遇到这样的情况,在数据库的Meeting表中有PublishTime (DateTime,8)字段,用来存储一个开会时间,在存入时由于要指明开会具体时间,故格式为yyyy-mm-dd hh:mm: ...
- sql server datetime类型字段使用isnull返回1900-01-01 00:00:00.000的问题
若字段定义的类型为datetime,插入为''(空),那么会默认值为1900-01-01 00:00:00.000 解决方法查询的时候过滤下cast(nullif('','') as datetime ...
- SQL Server时间类型datetime
SQL Server时间类型datetime 兼容ADO的COleDateTime. SQL datetime 日期和时间数据,可表示1753.1.1 至 9999.12.31的时间,精度为1/300 ...
- 【转】一道SQL SERVER DateTime的试题
学习过上一篇SQL SERVER DateTime精度的文章后.再来做一道题. IF ('2011-07-31 00:00:00.000' BETWEEN '2011-07-01' and '2011 ...
- SQL Server 字段类型 decimal(18,6)小数点前是几位?记一次数据库SP的BUG处理
原文:SQL Server 字段类型 decimal(18,6)小数点前是几位?记一次数据库SP的BUG处理 SQL Server 字段类型 decimal(18,6)小数点前是几位? 不可否认,这是 ...
- SQL Server锁类型
SQL Server锁类型(SQL)收藏 1. HOLDLOCK: 在该表上保持共享锁,直到整个事务结束,而不是在语句执行完立即释放所添加的锁. 2. NOLOCK:不添加共享锁和排它锁,当这个选项生 ...
- Sqlserver:datetime类型的精度(不确定性)问题
转自http://www.xuebuyuan.com/212359.html 背景:近日进行大型数据表的迁移处理,遭遇创建 主键时 索引键值重复的错误.仔细检查原始表,并未有任何问题.分析后发现是迁移 ...
- MS SQL server对象类型type
执行下面代码,将获取ms sql server对象类型以及其说明 IF OBJECT_ID('tempdb.dbo.#type') IS NOT NULL DROP TABLE #type CREAT ...
- SQL Server 方言类型映射问题
关于SQL Server的类型映射问题,例如,nvarchar无法进行hibernate类型映射,需要通过convert进行类型转换方可进行获取
随机推荐
- magic矩阵 分类: 数学 2015-07-31 22:56 2人阅读 评论(0) 收藏
魔方矩阵 魔方矩阵是有相同的行数和列数,并在每行每列.对角线上的和都相等.你能构造任何大小(除了2x2)的魔方矩阵. 1.历史 魔方又称幻方.纵横图.九宫图,最早记录于我国古代的洛书.据说 ...
- Chrome A标签的迁移错误:【Error loading page】
在IE中经常使用A标签用来迁移,正确的写法是 <a href="001.html"></a>即可,不过在chrome上面可能会引发错误无法迁移. 比如用下面 ...
- SQL Server用户自定义函数
用户自定义函数不能用于执行一系列改变数据库状态的操作,但它可以像系统 函数一样在查询或存储过程等的程序段中使用,也可以像存储过程一样通过EXECUTE 命令来执行.在 SQL Server 中根据函数 ...
- ISBN号码
总时间限制: 1000ms 内存限制: 65536kB 描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如"x-xxx- ...
- android中的Handler
android的Handler 前言 学习android一段时间了,为了进一步了解android的应用是如何设计开发的,决定详细研究几个开源的android应用.从一些开源应用中吸收点东西,一边进 ...
- java计算文件32位md5值
protected static String getFileMD5(String fileName) { File file = new File(fileName); if(!file.exist ...
- Linux嵌入式入门
虚拟机Linux系统网络配置: 1.Vmware网络设置 虚拟机设置->网路适配器->网络连接 桥接模式:能提供独立的IP地址的情况下使用 NAT模式:一台计算机只能使用一个I ...
- Java——匿名内部类
/* * 匿名内部类, 就是内部类的简写形式. * * 必须有前提: * 内部类必须继承或者实现一个外部类或者接口. * 匿名内部类其实就是一个子类对象. * * 格式:new 父类or接 ...
- java的nio之:java的nio系列教程之selector
一:Java NIO的selector的概述===>Selector(选择器)是Java NIO中能够检测一到多个NIO通道,并能够知晓通道是否为诸如读写事件做好准备的组件.这样,一个单独的线程 ...
- 在div中设置文字与内部div垂直居中
要实现如图一所示的结果: html代码如下: <!DOCTYPE html> <html> <head lang="zh"> <meta ...