位置: 编程技术 - 正文

优化 SQL Server 索引的小技巧(sqlserver优化方案)

编辑:rootadmin
在本文中,我将说明如何用SQL Server的工具来优化数据库索引的使用,本文还涉及到有关索引的一般性知识。      关于索引的常识      影响到数据库性能的最大因素就是索引。由于该问题的复杂性,我只可能简单的谈谈这个问题,不过关于这方面的问题,目前有好几本不错的书籍可供你参阅。我在这里只讨论两种SQL Server索引,即clustered索引和nonclustered索引。当考察建立什么类型的索引时,你应当考虑数据类型和保存这些数据的column。同样,你也必须考虑数据库可能用到的查询类型以及使用的最为频繁的查询类型。      索引的类型   如果column保存了高度相关的数据,并且常常被顺序访问时,最好使用clustered索引,这是因为如果使用clustered索引,SQL Server会在物理上按升序(默认)或者降序重排数据列,这样就可以迅速的找到被查询的数据。同样,在搜寻控制在一定范围内的情况下,对这些column也最好使用clustered索引。这是因为由于物理上重排数据,每个表格上只有一个clustered索引。      与上面情况相反,如果columns包含的数据相关性较差,你可以使用nonculstered索引。你可以在一个表格中使用高达个nonclustered索引——尽管我想象不出实际应用场合会用的上这么多索引。      当表格使用主关键字(primary keys),默认情况下SQL Server会自动对包含该关键字的column(s)建立一个独有的cluster索引。很显然,对这些column(s)建立独有索引意味着主关键字的唯一性。当建立外关键字(foreign key)关系时,如果你打算频繁使用它,那么在外关键字cloumn上建立nonclustered索引不失为一个好的方法。如果表格有clustered索引,那么它用一个链表来维护数据页之间的关系。相反,如果表格没有clustered索引,SQL Server将在一个堆栈中保存数据页。      数据页   当索引建立起来的时候,SQLServer就建立数据页(datapage),数据页是用以加速搜索的指针。当索引建立起来的时候,其对应的填充因子也即被设置。设置填充因子的目的是为了指示该索引中数据页的百分比。随着时间的推移,数据库的更新会消耗掉已有的空闲空间,这就会导致页被拆分。页拆分的后果是降低了索引的性能,因而使用该索引的查询会导致数据存储的支离破碎。当建立一个索引时,该索引的填充因子即被设置好了,因此填充因子不能动态维护。      为了更新数据页中的填充因子,我们可以停止旧有索引并重建索引,并重新设置填充因子(注意:这将影响到当前数据库的运行,在重要场合请谨慎使用)。DBCC INDEXDEFRAG和DBCC DBREINDEX是清除clustered和nonculstered索引碎片的两个命令。INDEXDEFRAG是一种在线操作(也就是说,它不会阻塞其它表格动作,如查询),而DBREINDEX则在物理上重建索引。在绝大多数情况下,重建索引可以更好的消除碎片,但是这个优点是以阻塞当前发生在该索引所在表格上其它动作为代价换取来得。当出现较大的碎片索引时,INDEXDEFRAG会花上一段比较长的时间,这是因为该命令的运行是基于小的交互块(transactional block)。      填充因子   当你执行上述措施中的任何一个,数据库引擎可以更有效的返回编入索引的数据。关于填充因子(fillfactor)话题已经超出了本文的范畴,不过我还是提醒你需要注意那些打算使用填充因子建立索引的表格。      在执行查询时,SQL Server动态选择使用哪个索引。为此,SQL Server根据每个索引上分布在该关键字上的统计量来决定使用哪个索引。值得注意的是,经过日常的数据库活动(如插入、删除和更新表格),SQL Server用到的这些统计量可能已经“过期”了,需要更新。你可以通过执行DBCC SHOWCONTIG来查看统计量的状态。当你认为统计量已经“过期”时,你可以执行该表格的UPDATE STATISTICS命令,这样SQL Server就刷新了关于该索引的信息了。      建立数据库维护计划   SQL Server提供了一种简化并自动维护数据库的工具。这个称之为数据库维护计划向导(Database Maintenance Plan Wizard ,DMPW)的工具也包括了对索引的优化。如果你运行这个向导,你会看到关于数据库中关于索引的统计量,这些统计量作为日志工作并定时更新,这样就减轻了手工重建索引所带来的工作量。如果你不想自动定期刷新索引统计量,你还可以在DMPW中选择重新组织数据和数据页,这将停止旧有索引并按特定的填充因子重建索引。

推荐整理分享优化 SQL Server 索引的小技巧(sqlserver优化方案),希望有所帮助,仅作参考,欢迎阅读内容。

优化 SQL Server 索引的小技巧(sqlserver优化方案)

文章相关热门搜索词:sql优化索引,sql server sql优化,sql优化索引,sql server 优化查询,sql server 优化查询,sql server sql优化,sql server sql优化,sql server 优化查询,内容如对您有帮助,希望把文章链接给更多的朋友!

SQL server高级应用 收藏版 一.建库,建表,加约束.1.1建库usemastergoifexists(select*fromsysdatabaseswherename='MyDatabase')—判断master数据库sysdatagbases表中是否存在将要创建的数据库名dropdatabaseMyD

Sql Server 分页方法分析(offset and fetch) 其中offsetandfetch最重要的新特性是用来分页,既然要分析分页,就肯定要和之前的分页方式来比较了,特别是Row_Number()了,在比较过程中,发现了蛮多

sqlserver 触发器学习(实现自动编号) 总结常用基本点如下:1、触发器有两种类型:数据定义语言触发器(DDL触发器)和数据操纵语言触发器(DML触发器)。DDL触发器:在用户对数据库执行

标签: sqlserver优化方案

本文链接地址:https://www.jiuchutong.com/biancheng/348178.html 转载请保留说明!

上一篇:SqlServer 索引自动优化工具(sqlserver怎么使用索引)

下一篇:SQL server高级应用 收藏版(sql server高级应用)

  • 房地产销售商品房税率
  • 公司承担个税的账务处理
  • 物业管理费专票可以抵扣吗
  • 2019年新政府会计制度
  • 2019个体户经营所得税税率表
  • 收到快递费属于什么科目
  • 赠送产品能直接用吗
  • 公司收到一次性吸纳就业补贴款怎么分录
  • 进项税转出申报表能填负数吗
  • 其他应付款在现金流量表中应该填哪里
  • 员工自己领取社保卡需要带什么资料
  • 客户预付货款会计分录
  • 居民企业只就其境内全部所得纳税
  • 贷款的印花税税率
  • 企业购买硬件与软件该如何做账?
  • 所有者权益的利得和损失
  • 银行直接扣的手续费怎么记账
  • 规避税收风险什么意思
  • 不是房屋产权人可以卖房吗
  • win10开机选择系统%1
  • 招标公司返回的钱怎么算
  • thinkphp怎么用
  • 图解在OS X中管理窗口大小的多种方法
  • PHP:Memcached::addServers()的用法_Memcached类
  • php数组函数输出《咏雪》里有多少"片"字
  • 持有至到期投资在资产负债表怎么填
  • 房产开发企业涉及税种
  • 最保值的ipad
  • 不开票收入如何纳税申报
  • vue3怎么用
  • 因汇率变动而导致的损失属于
  • 固定资产减值准备可以转回吗
  • 520要来了要吵架的赶紧
  • js浅拷贝和深拷贝的方法
  • ping命令详解步骤
  • 处理二手物品要交增值税吗
  • 计提坏账准备不会影响应收账款账面价值
  • 公司出售房子怎么交税
  • 不走流水开发票可以吗
  • MySQL发生系统错误2和5
  • 清包工一般计税如何开票
  • 安置房是交付的时候交钱吗
  • 电子承兑没到期可以提示付款吗
  • SQLserver2014(ForAlwaysOn)安装图文教程
  • 交车险代收的车可以退吗
  • 固定资产备抵科目有哪些
  • 小企业附加税减免政策
  • 12月计提的工资没有发完怎么做账
  • 建筑工程拨款申请模板
  • 建筑工程行业前景
  • 怎样银行存款,预付帐款,应收帐款余额做资金平衡表
  • sqlserver 获取表字段
  • 台式电脑二级网页打不开怎么办
  • win8创建新用户
  • 苹果mac最新的系统
  • openssl安装教程
  • linux系统开机黑屏啥也没有
  • centos8 apache
  • SmartFTP.exe - SmartFTP是什么进程
  • osx 10.9
  • lsass.exe是什么病毒
  • linux与windows有哪些主要区别
  • win8无线网络受限 重连又好了
  • win7系统出现蓝屏怎么进去桌面
  • win10内置管理员账户禁用
  • jquery操作dom
  • 搜狐畅游手游官网
  • python中的字符型
  • js动态生成函数
  • android 点击按钮如果数据库有数据就更新,没有就创建
  • javascript开发自学
  • 基于python的系统
  • jQuery Easyui Datagrid实现单行的上移下移及保存移动的结果
  • jquery 判断是否显示
  • 广东民生求助热线电话是多少
  • 小规模纳税人怎么申报纳税
  • 电子税务完税证明怎么打印
  • 江西公安电子证件
  • 北京税务局网站官网
  • 企业申报系统网址
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设