摘要:
聚集索引,数据实际上是按顺序存储的,数据页就在索引页上。就好像参考手册将所有主题按顺序编排一样。一旦找到了所要搜索的数据,就完成了这次搜索,对于非聚集索引,索引是安全独立于数据本身结构的,在索引中找到了寻找的数据,然后通过指针定位到实际的数据。 SQL Server中的索引使用标准的B-树来存储他们的信息,如下图所示,B-树通过查找索引中的一个关键之来提供对于数据的快速访问,B-树以相似的键记录聚合在一起,B不代表二叉(binary),而是代表balanced(平衡的),而B-树的一个核心作用就是保持树的平衡。同伙向下遍历这棵树以找到一个数值并定位记录。因为树是平衡的,所以寻找任何记录都只需要 阅读全文
摘要:
sql集合运算: union ,except,intersect熟练使用SQL Server中的各种用法会给查询带来很多方便。今天就介绍一下EXCEPT和INTERSECT。注意此语法仅在SQL Server 2005及以上版本支持。EXCEPT是指在第一个集合中存在,但是不存在于第二个集合中的数据。INTERSECT是指在两个集合中都存在的数据。create table t1(id int,mark char(2))gocreate table t2(id int,mark char(2))goinsert into t1 select 1,'t1' union all se 阅读全文
摘要:
一. 聚集索引B树分析1.聚集索引按B树结构进行组织的,索引B树种的每一页称为一个索引节点。B树的顶端节点称为根节点。 索引中的低层节点称为叶节点。根节点与叶节点之间的任何索引级别统称为中间级。在聚集索引中,叶节点包含基础表的数据页。 根节点和中间级节点包含存有索引行的索引页。每个索引行包含一个键值和一个指针,该指针指向 B 树上的某一中间级页或叶级索引中的某个数据行.每级索引中的页均被连接在双向链接列表中。2.索引使用的每一个分区的index_id = 1 ,默认情况下聚集索引单个分区,当使用分区表的时候,每个分区都有一个包含该特定分区相关数据的B树结构,我是这么理解的不知道对不对?3.SQ 阅读全文
摘要:
SELECT DATEDIFF(day,'2008-12-29','2008-12-30') AS DiffDate解释: 第一个参数 day 表示 返回2个日期间隔的 个间隔类型 是 日期;结果 是 1。 也可以 改成 hh 表示返回小时 ,即24小时,详细查看http://www.w3school.com.cn/sql/func_datediff.asp 阅读全文
摘要:
(case when CharIndex('0 then '1' else '0' end)解释: 在 newstext这个字段列表里面 搜索 具有 '<img' 的字符串,并返回该字符串所在的位置。 阅读全文
摘要:
这个分组函数 并不是 group by的分组。 阅读全文
摘要:
全局临时表的生命周期一直持续到创建会话(不是创建级别)才终止。例如,如果你在存储过程中创建全局临时表,当超出存储过程的范围时,该表并不会被销毁。当创建会话终止后,SQL Server才会自动尝试删除该表,其他会话中对其提交的所有语句都将结束,并释放它们所保持的所有锁。 但在某些情况下,你可能想创建一个不属于任何会话的全局临时表。这时,无论哪个会话打开或关闭,它总数存在,只有显式的删除它才能被移除。为此,可以在一个特殊的存储过程中(使用sp_前缀,在master中创建)创建该表并使用“startup”选项标记该存储过程。Sql Server会在每次启动时调用启动过程(startup proce. 阅读全文
摘要:
子查询内 找不到的 字段 会 向外 寻找,还是找不到 就报错;找到了就不报错,但是 子查询语句就毫无意义了;解决办法: 字段前面要跟上表的名称。 一般 字段无效 立刻 报错。 阅读全文
摘要:
可以 通过 where 条件 把 null的情况 筛选掉,已避免出现上述的情况。1,exist 返回 true or false; in 返回 true unknow。not之后not true or not false ; 返回 not true or not unknow; (两个都是 null)2,区分in和exists主要是造成了驱动顺序的改变(这是性能变化的关键),如果是exists,那么以外层表为驱动表,先被访问,如果是IN,,那么先执行子查询IN适合于外表大而内表小的情况;EXISTS适合于外表小而内表大的情况 阅读全文
摘要:
SQL中withas的用法——使用公用表表达式(CTE)公用表表达式(CTE)可以认为是在单个SELECT、INSERT、UPDATE、DELETE或CREATEVIEW语句的执行范围内定义的临时结果集。CTE与派生表类似,具体表现在不存储为对象,并且只在查询期间有效。与派生表的不同之处在于,CTE可自引用,还可在同一查询中引用多次。CTE可用于:创建递归查询。在不需要常规使用视图时替换视图,也就是说,不必将定义存储在元数据中。启用按从标量嵌套select语句派生的列进行分组,或者按不确定性函数或有外部访问的函数进行分组。在同一语句中多次引用生成的表。使用CTE可以获得提高可读性和轻松维护复杂 阅读全文