博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL Server 创建索引的 5 种方法
阅读量:6527 次
发布时间:2019-06-24

本文共 3071 字,大约阅读时间需要 10 分钟。

前期准备:

            create table Employee (

            ID int not null primary key,
            Name nvarchar(4),
            Credit_Card_ID varbinary(max)); --- 小心这种数据类型。
            go

            说明:本表上的索引,都会在创建下一个索引前删除。

-------------------------------------------------------------------------------------------------------------------------------------------------------------

操作 1、

         创建聚集索引

         方法 1、

               alter table table_name add constraint cons_name priamry key(columnName ASC|DESC,[.....]) with (drop_existing = on);

               alter table Employee

               add constraint PK_for_Employee primary key clustered (ID);
               go

               这个是一种特别的方法,因为在定义主键的时候,会自动添加索引,好在加的是聚集索引还是非聚集索引是我们人为可以控制的。

               通过sp_helpindex 可以查看表中的索引

               execute sp_helpindex @objname = 'Employee';

               go

               

              注意、

                     这个索引是无法删除的,不信! 你去删一下

                     drop index Employee.PK__Employee__3214EC277D95E615;

                     go

                     

        方法 2、

                 create clustered index ix_name on table_name(columnName ASC|DESC[,......]) with (drop_existing = on);方法

                 create clustered index ix_clu_for_employee_ID on Employee(ID);

                 go

                 查看创建的索引

                 

 

操作 2、

         创建复合索引

         create index ix_com_Employee_IDName on Employee (ID,Name)with (drop_existing = on);

         

        这样就算是创建一个复合索引了,不过脚下的路很长,我们看下一个复合索引的例句:

        create index ix_com_Employee_IDCreditCardID on Employee(ID,Credit_Card_ID);

        看到这句话,你先问一下自己它有没有错!

        

       可以发现它错了,varbinary是不可以建索引的。

操作 3、

         创建覆盖索引

         create index index_name on table_Name (columnName ASC|DESC[,......]) include(column_Name_List)with (drop_existing = on);

         create index ix_cov_Employee_ID_Name on Employee (ID) include(Name);

         go

         首先,覆盖索引它只是非聚集索引的一种特别形式,下文说的非聚集索引不包涵覆盖索引,当然这个约定只适用于这一段话,这样做的

         目的是为了说明各中的区别。

         首先:

               1、非聚集索引不包涵数据,通过它找到的只是文件中数据行的引用(表是堆的情况下)或是聚集索引的引用,SQL Server

                    要通这个引用去找到相应的数据行。

               2、正因为非聚集索引它没有数据,才引发第二次查找。

               3、覆盖索引就是把数据加到非聚集索引上,这样就不需要第二次查找了。这是一种以空间换性能的方法。非聚集索引也是。

                    只是做的没有它这么出格。

操作 4、

         创建唯一索引

         create unique index index_name on table_name (column ASC|DESC[,.....])with (drop_existing = on);

         正如我前面所说,在创建表上的索引前,我会删除表上的所有索引,这里为什么我要再说一下呢!因为我怕你忘了。二来这个例子用的到它。

         目前表是一个空表,我给它加两行数据。

         insert into Employee(ID,Name) values(1,'AAA'),(1,'BBB');

         

        这下我们为表加唯一索引,它定义在ID这个列上

        create unique index ix_uni_Employee_ID on Employee(ID);

        go -- 可以想到因为ID有重复,所以它创建不了。

        

        结论 1、 如果在列上有重复值,就不可以在这个列上定义,唯一索引。

        下面我们把表清空: truncate table Employee;

        

        接下来要做的就是先,创建唯一索引,再插入重复值。

        create unique index ix_uni_Employee_ID on Employee(ID);

        go

        

        insert into Employee(ID,Name) values(1,'AAA'),(1,'BBB');

        go

        

       

       结论 2、

                定义唯一索引后相应的列上不可以插入重复值。

操作 5、

         筛选索引

         create index index_name on table_name(columName) where boolExpression;

         create index ix_Employee_ID on Employee(ID) where ID>100 and ID< 200;

         go

         只对热点数据加索引,如果大量的查询只对ID 由 100 ~ 200 的数据感兴趣,就可以这样做。

         1、可以减小索引的大小

         2、为据点数据提高查询的性能。      

 

 

总结:

      BTree 索引有聚集与非聚集之分。

                                               就查看上到聚集索引性能比非聚集索引性能要好。

      非聚集索引分    覆盖索引,唯一索引,复合索引(当然聚集索引也有复合的,复合二字,只是说明索引,引用了多列),一般非聚集索引

                                               就查看上到非聚集索引中覆盖索引的性能比别的非聚集索引性能要好,它的性能和聚集索引差不多,可是

                                               它也不是’银弹‘ 它会用更多的磁盘空间。

 

最后说一下这个

 

                  with (drop_existing = on|off),加上这个的意思是如果这个索引还在表上就drop 掉然后在create 一个新的。特别是在聚集索引上

                   用使用这个就可以不会引起非聚集索引的重建。

                  with (online = on|off) 创建索引时用户也可以访问表中的数据,

                  with(pad_index = on|off fillfactor = 80); fillfactor 用来设置填充百分比,pad_index 只是用来连接fillfactor 但是它又不难少,

                  这点无语了。

                  with(allow_row_locks = on|off   |   allow_page_locks = on |off);  是否允许页锁 or 行锁

                  with (data_compression = row | page );  这样可以压缩索引大小

                  

      

 

 

 

 

 

 

 

 

               

         

转载于:https://www.cnblogs.com/JiangLe/p/4007091.html

你可能感兴趣的文章
ios兼容iphonex刘海屏解决方案
查看>>
就是要你懂TCP -- 握手和挥手
查看>>
Andrew Ng机器学习公开课笔记 -- Regularization and Model Selection
查看>>
《Python游戏编程快速上手》一1.3 如何使用本书
查看>>
《Android游戏开发详解》——第1章,第1.3节声明和初始化变量
查看>>
《Visual Studio程序员箴言》----1.2 滚动与导航
查看>>
Processing编程学习指南2.7 Processing参考文档
查看>>
架构师速成-架构目标之伸缩性\安全性
查看>>
执行可运行jar包时读取jar包中的文件
查看>>
linux下ExtMail邮件使用及管理平台
查看>>
linux中iptables设置自建dns服务器的端口
查看>>
TP5+PHPexcel导入xls,xlsx文件读取数据
查看>>
基于Yum安装zabbix3.0
查看>>
Master-work模式
查看>>
dos命令行 指令
查看>>
RT-Thread--时间管理
查看>>
BUPT 63T 高才生 找最佳基站
查看>>
linux 学习(二)防火墙
查看>>
scala001
查看>>
android - SpannableString或SpannableStringBuilder以及string.xml文件中的整型和string型代替...
查看>>