关闭 x
IT技术网
    技 采 号
    ITJS.cn - 技术改变世界
    • 实用工具
    • 菜鸟教程
    IT采购网 中国存储网 科技号 CIO智库

    IT技术网

    IT采购网
    • 首页
    • 行业资讯
    • 系统运维
      • 操作系统
        • Windows
        • Linux
        • Mac OS
      • 数据库
        • MySQL
        • Oracle
        • SQL Server
      • 网站建设
    • 人工智能
    • 半导体芯片
    • 笔记本电脑
    • 智能手机
    • 智能汽车
    • 编程语言
    IT技术网 - ITJS.CN
    首页 » SQL Server »SQL Server datetime数据类型设计与优化误区

    SQL Server datetime数据类型设计与优化误区

    2011-05-11 10:39:00 出处:ITJS
    分享

    一、场景

    在SQL Server 2005中,有一个表TestDatetime,其中Dates这个字段的数据类型是datetime,假如你看到表的记录如下图所示,你最先想到的是什么呢?

    数据列表

    (图1:数据列表)

    你看到这些数据,是不是觉得这样的设计既浪费了存储空间,又使得这个列的索引增大,查询起来更慢,你也想使用一些其它的数据类型来代替这个datetime吧?

    其实大家都是这么想的,这个方向是100%正确的,但是在写该文以前,我进入了两个误区:(假如你中了下面的两个误区,那么请你看看该文吧。)

    误区一:把Dates字段的datetime数据类型换成smalldatetime,这样数据就由:‘2009-04-09 00:00:00.000’变为‘2009-04-09 00:00:00’,这个看起来没有减少多少存储空间哦。

    误区二:把Dates字段的datetime数据类型换成char(10),这样数据就由:‘2009-04-09 00:00:00.000’变为‘2009-04-09’,这好像能减少很多存储空间哦。

    二、分析

    在SQL Server 2005版本中保存日期的数据类型只有两种:datetime、smalldatetime,但是在SQL Server 2008版本中新增了一些日期数据类型:time、date、smalldatetime、datetime、datetime2、datetimeoffset,其中的date类型就能满足我们场景中的需求了,假如你幸运的在使用SQL Server 2008的话,那么恭喜你,请使用date数据类型吧。

    但是我就比较可悲一点了,在使用SQL Server 2005的前提下,我进入了误区一、误区二。其实这也是因为自己忽略了一下基础性的东西,假如知道不同数据类型的存储空间大小,也许就很轻易的避免这样低级的错误了。

    其实你查看表TestDatetime中的Dates字段的时候,看到查询结果中的:“-”、“:”只是用于显示的,并不是真实保存的时候就这样格式的。

    datetime占用8个字节,前4个字节存储base date(即1900年1月1日)之前或之后的天数,后4个字节存储午夜后的毫秒数。值范围:1753-01-01 到 9999-12-31。

    smalldatetime占用4个字节,前2个字节存储base date(1900年1月1日)之后的天数。后2个字节存储午夜后的分钟数。值范围:1900-01-01 到 2079-06-06。

    date占用3个字节,它比smalldatetime的前2个字节多了1字节,所以值的范围更广了。值范围:0001-01-01 到 9999-12-31。

    所以,假如你使用char(10)来保存截断的日期,那么你的存储空间反而更大了。

    结论: 假如是SQL Server 2005,那么请你使用smalldatetime吧,数据能节约一半,虽然查询的时候看起来没什么改变;假如你是SQL Server 2008,那么请你使用date吧,虽然3个字节跟4个字节没有多大的差距,但是从设计上和逻辑清晰度上都有很大的提升,而且差距有些时候并不是1个字节的问题,比如当表数据量达到几个亿的时候,还是有差别的,又或者一条记录可能因为差1个字节就刚刚好给8060字节的页瓜分,这些都不容忽视的。

    三、测试

    下面我们就从数据存储的大小、索引存储的大小、索引使用时候的速度这几个方面进行测试:(这里只测试数据类型:,,数据的内容都是一样的)

    (一) 测试前奏:

    1. 创建三种数据类型char(10)、datetime、smalldatetime的表;(表结构如下面SQL)

    CREATE TABLE [dbo].[TestDatetime](

    [Id] [int] IDENTITY(1,1) NOT NULL,

    [Dates] [datetime] NULL,

    CONSTRAINT [PK_TestDatetime] PRIMARY KEY CLUSTERED

    (

    [Id] ASC

    )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY]

    ) ON [PRIMARY]

    2. 插入相同记录到三个表中;(这里插入1210000条记录)

    3.为[Dates]字段创建索引;(在创建索引的时候可以设置填充因子为100%)

    4. 查看索引属性中的索引碎片信息,查看表数据和索引占用的空间,测试[Dates]字段索引的查询效率;

    (二) 测试结果:

    1.数据存储大小:

    数据空间对比

    (图2:数据空间对比)

    2. 索引存储信息:

    char(10)

    (图3:char(10))

    datetime

    (图4:datetime)

    smalldatetime

    (图5:smalldatetime)

    3.索引查询的情况:

    多次执行,SQL Server执行时间为:[char(10)] 大部分在43~59徘徊,偶尔出现小于10的;[datetime]平均在1~2毫秒;[smalldatetime]均在1毫秒;而且大家会发现 [smalldatetime]有其它的9次逻辑读取变为8次了。

    --[TestChar10]

    SQL Server 分析和编译时间:

    CPU 时间= 0 毫秒,占用时间= 1 毫秒。

    (2200 行受影响)

    表'TestChar10'。扫描计数1,逻辑读取9 次,物理读取0 次,预读0 次,lob 逻辑读取0 次,lob 物理读取0 次,lob 预读0 次。

    SQL Server 执行时间:

    CPU 时间= 0 毫秒,占用时间= 59 毫秒。

    SQL Server 执行时间:

    CPU 时间= 0 毫秒,占用时间= 1 毫秒。

    --[TestDatetime]

    SQL Server 分析和编译时间:

    CPU 时间= 0 毫秒,占用时间= 1 毫秒。

    (2200 行受影响)

    表'TestDatetime'。扫描计数1,逻辑读取9 次,物理读取0 次,预读0 次,lob 逻辑读取0 次,lob 物理读取0 次,lob 预读0 次。

    SQL Server 执行时间:

    CPU 时间= 0 毫秒,占用时间= 2 毫秒。

    SQL Server 执行时间:

    CPU 时间= 0 毫秒,占用时间= 1 毫秒。

    --[TestSmalldatetime]

    SQL Server 分析和编译时间:

    CPU 时间= 0 毫秒,占用时间= 1 毫秒。

    (2200 行受影响)

    表'TestSmalldatetime'。扫描计数1,逻辑读取8 次,物理读取0 次,预读0 次,lob 逻辑读取0 次,lob 物理读取0 次,lob 预读0 次。

    SQL Server 执行时间:

    CPU 时间= 0 毫秒,占用时间= 1 毫秒。

    SQL Server 执行时间:

    CPU 时间= 0 毫秒,占用时间= 1 毫秒。

    --SQL Server 2008新数据类型

    1. SELECT

    2. CAST('2007-05-08 12:35:29. 1234567 +12:15' AS time(7)) AS 'time'

    3. ,CAST('2007-05-08 12:35:29. 1234567 +12:15' AS date) AS 'date'

    4. ,CAST('2007-05-08 12:35:29.123' AS smalldatetime) AS

    5. 'smalldatetime'

    6. ,CAST('2007-05-08 12:35:29.123' AS datetime) AS 'datetime'

    7. ,CAST('2007-05-08 12:35:29. 1234567 +12:15' AS datetime2(7)) AS 'datetime2'

    8. ,CAST('2007-05-08 12:35:29.1234567 +12:15' AS datetimeoffset(7)) AS 'datetime

    上一篇返回首页 下一篇

    声明: 此文观点不代表本站立场;转载务必保留本文链接;版权疑问请联系我们。

    别人在看

    hiberfil.sys文件可以删除吗?了解该文件并手把手教你删除C盘的hiberfil.sys文件

    Window 10和 Windows 11哪个好?答案是:看你自己的需求

    盗版软件成公司里的“隐形炸弹”?老板们的“法务噩梦” 有救了!

    帝国CMS7.5编辑器上传图片取消宽高的三种方法

    帝国cms如何自动生成缩略图的实现方法

    Windows 12即将到来,将彻底改变人机交互

    帝国CMS 7.5忘记登陆账号密码怎么办?可以phpmyadmin中重置管理员密码

    帝国CMS 7.5 后台编辑器换行,修改回车键br换行为p标签

    Windows 11 版本与 Windows 10比较,新功能一览

    Windows 11激活产品密钥收集及专业版激活方法

    IT头条

    智能手机市场风云:iPhone领跑销量榜,华为缺席引争议

    15:43

    大数据算法和“老师傅”经验叠加 智慧化收储粮食尽显“科技范”

    15:17

    严重缩水!NVIDIA将推中国特供RTX 5090 DD:只剩24GB显存

    00:17

    无线路由大厂 TP-Link突然大裁员:补偿N+3

    02:39

    Meta 千万美金招募AI高级人才

    00:22

    技术热点

    微软已修复windows 7/windows 8.1媒体中心严重漏洞 用户可下载安

    卸载MySQL数据库,用rpm如何实现

    windows 7中使用网上银行或支付宝支付时总是打不开支付页面

    一致性哈希算法原理设计

    MySQL数字类型中的三种常用种类

    如何解决SQL Server中传入select语句in范围参数

      友情链接:
    • IT采购网
    • 科技号
    • 中国存储网
    • 存储网
    • 半导体联盟
    • 医疗软件网
    • 软件中国
    • ITbrand
    • 采购中国
    • CIO智库
    • 考研题库
    • 法务网
    • AI工具网
    • 电子芯片网
    • 安全库
    • 隐私保护
    • 版权申明
    • 联系我们
    IT技术网 版权所有 © 2020-2025,京ICP备14047533号-20,Power by OK设计网

    在上方输入关键词后,回车键 开始搜索。Esc键 取消该搜索窗口。