摘要: 对于MS SQL server 数据库,有几个容易让人产生误解的问题,对于这几个问题,即使很多 SQL server DBA 都有错误认识或者认识不充分,所以我想撰文几篇,把这些容易理解错误的问题前前后后深入阐述一下,也希望纠正一下网上对这几个问题的讹传(我也可能有认识不对的地方,欢迎批评指正)。 ... 阅读全文
posted @ 2015-08-31 16:46 雍洲无名 阅读(434) 评论(0) 推荐(0) 编辑
摘要: 一:delete操作 现在我们已经知道,索引都是以B树的形式存在的,既然是B树,我们就要看看他们的叶子节点和分支结点,先准备点测试数据,如下图:按 Ctrl+C 复制代码按 Ctrl+C 复制代码 叶子结点的变化 从上面的图中大概可以看到,当我插入完毕后,现在有4个索引数据页,其中PID=200... 阅读全文
posted @ 2015-08-31 14:49 雍洲无名 阅读(770) 评论(0) 推荐(0) 编辑
摘要: 1.查询表中的RIDRID=RowID=(fileID:pageID:slotID)SELECT sys.fn_PhysLocFormatter(%%physloc%%) AS rid,* FROM person2.开启DBCC命令语法--开启DBCC TRACEON(2588)--帮助命令DBCC... 阅读全文
posted @ 2015-08-31 10:45 雍洲无名 阅读(367) 评论(0) 推荐(0) 编辑
摘要: 一:现象1:无索引的情况 还是老规矩,看个例子感受下,首先我有一个Product表,里面没有任何索引,如下图:从上图中,我悲剧的看到了,物理读是9次,也就说明走了9次硬盘,你也可以想到,走硬盘的目的是为了拿数据,逻辑读有1636次,要注意的是这里的”次“是“页”的意思,也就是在内存中走了1636个... 阅读全文
posted @ 2015-08-31 10:30 雍洲无名 阅读(256) 评论(0) 推荐(0) 编辑
摘要: 一:表扫描1.现象 ”表扫描“听起来很简单,不就是一行一行的扫嘛,你要说”执行计划”的话,我也会玩,为了更可观,我build一个表,再插入三行数据,如下图:上面的Person我是一个索引都没建,然后where一下,看看表扫描是啥样的???果然是看到了万恶的“表扫描”三个字,既然是万恶的东西,我们一... 阅读全文
posted @ 2015-08-31 09:12 雍洲无名 阅读(191) 评论(0) 推荐(0) 编辑
摘要: 说到sql的参数化处理,我也是醉了,因为sql引擎真的是一个无比强大的系统,我们平时做系统的时候都会加上缓存,我想如果没有缓存,就不会有什么大网站能跑的起来,而且大公司一般会在一个东西上做的比较用心,比较细,sqlserver同样也使用了缓存,其中就包括Data cache 和Plan cache两... 阅读全文
posted @ 2015-08-30 20:53 雍洲无名 阅读(463) 评论(0) 推荐(0) 编辑
摘要: 一:执行计划生成过程 说到执行计划,首先要知道的是执行计划大概生成的过程,这样就可以做到就心中有数了,下面我画下简图:1. 分析过程 这三个比较容易理解,首先我们要保证sql的语法不能错误,select和join的表是必须存在的,以及你是有执行这个sql的权限,对不对。。。这样我们就走完了执行计... 阅读全文
posted @ 2015-08-30 16:29 雍洲无名 阅读(342) 评论(0) 推荐(0) 编辑
摘要: 一: 当select遇到性能低下的update会怎么样?1. 还是使用原始的person表,插入6条数据,由于是4000字节,所以两条数据就是一个数据页,如下图:1 DROP TABLE dbo.Person2 CREATE TABLE Person(ID INT IDENTITY,NAME CHA... 阅读全文
posted @ 2015-08-29 15:49 雍洲无名 阅读(203) 评论(0) 推荐(0) 编辑
摘要: 一:到底都有哪些锁 学习锁之前,必须要知道锁大概有几种???通常情况下作为码农我们只需知道如下几个锁即可。。。1.S(Share)锁 为了方便理解,我们可以直接这么认为,当在select的时候在表,数据页,记录上加上共享锁。2.X(Exclusive) 锁 我们在delete数据的时候会在记录... 阅读全文
posted @ 2015-08-28 16:51 雍洲无名 阅读(196) 评论(0) 推荐(0) 编辑
摘要: 1、NOLOCK(不加锁) 此选项被选中时,SQL Server 在读取或修改数据时不加任何锁。 在这种情况下,用户有可能读取到未完成事务(Uncommited Transaction)或回滚(Roll Back)中的数据, 即所谓的“脏数据”。2、HOLDLOCK(保持锁) 此选项被选中时,SQL... 阅读全文
posted @ 2015-08-28 13:14 雍洲无名 阅读(574) 评论(0) 推荐(0) 编辑