데이터 베이스 MySQL 튜토리얼 sql数据库学习系列四之SQL Server 索引和视图

sql数据库学习系列四之SQL Server 索引和视图

Jun 07, 2016 pm 03:30 PM
server sql 공부하다 데이터 베이스 시리즈 색인

1、 什么是索引 索引就是数据表中数据和相应的存储位置的列表,利用索引可以提高在表或视图中的查找数据的速度。 2、 索引分类 数据库中索引主要分为两类:聚集索引和非聚集索引。SQL Server 2005还提供了唯一索引、索引视图、全文索引、xml索引等等。聚集索

    1、 什么是索引

        索引就是数据表中数据和相应的存储位置的列表,利用索引可以提高在表或视图中的查找数据的速度。

 

    2、 索引分类

        数据库中索引主要分为两类:聚集索引和非聚集索引。SQL Server 2005还提供了唯一索引、索引视图、全文索引、xml索引等等。聚集索引和非聚集索引是数据库引擎中索引的基本类型,是理解其他类型索引的基础。

 

    # 聚集索引

        聚集索引是值表中数据行的物理存储顺序和索引的存储顺序完全相同。聚集索引根据索引顺序物理地重新排列了用户插入到表中的数据,因此,每个表只能创建一个聚集索引。聚集索引经常创建在表中经常被搜索到的列或按顺序访问的列上。在默认情况下,主键约束自动创建聚集索引。

 

    # 非聚集索引

        非聚集索引不改变表中数据列的物理存储位置,数据与索引分开存储,通过索引指向的地址与表中的数据发生关系。

        非聚集索引没有改变表中物理行的位置,索引可以在以下情况下使用非聚集索引:

        一、如果某个字段的数据唯一性比较高

        二、如果查询所得到的数据量比较少

 

聚集索引和非聚集索引的区别:

聚集索引

非聚集索引

每个表只允许创建一个聚集索引

最多可以有249个非聚集索引

物理的重排表中的数据以符合索引约束

创建一个键值列表,键值指向数据在数据页中的位置

用于经常查找数据的列

用于从表中查找单个值的列

    # 其他类型索引

    除了以上索引,还有以下类型索引:

        a、 唯一索引:如果希望索引键都不同,可以创建唯一索引。聚集索引和非聚集索引都可以是唯一索引。

        b、 包含新列索引:索引列的最大数量是16个,索引列的字节总数的最高值是900。如果当多个列的字节总数大于900,切又想在这些劣种都包含索引是,可以使用包含性列索引

        c、 视图索引:提供视图查询效率,可以视图的索引物理化,也就是说将结果集永久存储在索引中,可以创建视图索引。

        d、 XML索引:是与xml数据关联的索引形式,是XML二进制blob的已拆分持久表示形式

        e、 全文索引:一种特殊类型的基于标记的功能性功能,用于帮助在字符串中搜索赋值的词

   

    3、 创建索引

    语法

<span>create</span> [<span>unique</span>] [<span>clustered</span> | noclustered]
로그인 후 복사
<span>index</span> index_name
로그인 후 복사
<span>on</span> table_name (column_name ...)
로그인 후 복사
[<span>with</span> <span>fillfactor</span>=x]
로그인 후 복사

    unique唯一索引

    clustered聚集索引

    noclustered非聚集索引

    fillfactor填充因子大小,范围在0-100直接,表示索引页填满的空间所占的百分比。

 

    示例

<span>if</span> (<span>exists</span> (<span>select</span> * <span>from</span> sys.indexes <span>where</span> name = <span>'idx_stu_name'</span>))
로그인 후 복사
    <span>drop</span> <span>index</span> student.idx_stu_name
로그인 후 복사
<span>go</span>
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
<span>create</span> <span>index</span> idx_stu_name
로그인 후 복사
<span>on</span>
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
student(name);
로그인 후 복사
로그인 후 복사
 
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
--联合索引
로그인 후 복사
<span>if</span> (<span>exists</span> (<span>select</span> * <span>from</span> sys.indexes <span>where</span> name = <span>'idx_uqe_clu_stu_name_age'</span>))
로그인 후 복사
    <span>drop</span> <span>index</span> student.idx_uqe_clu_stu_name_age
로그인 후 복사
<span>go</span>
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
<span>create</span> <span>unique</span> <span>clustered</span> <span>index</span> idx_uqe_clu_stu_name_age
로그인 후 복사
<span>on</span> student(name, age);
로그인 후 복사
 
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
<span>if</span> (<span>exists</span> (<span>select</span> * <span>from</span> sys.indexes <span>where</span> name = <span>'idx_cid'</span>))
로그인 후 복사
로그인 후 복사
    <span>drop</span> <span>index</span> student.idx_cid
로그인 후 복사
로그인 후 복사
<span>go</span>
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
 
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
<span>if</span> (<span>exists</span> (<span>select</span> * <span>from</span> sys.indexes <span>where</span> name = <span>'idx_cid'</span>))
로그인 후 복사
로그인 후 복사
    <span>drop</span> <span>index</span> student.idx_cid
로그인 후 복사
로그인 후 복사
<span>go</span>
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
 
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
--非聚集索引
로그인 후 복사
<span>create</span> <span>nonclustered</span> <span>index</span> idx_cid
로그인 후 복사
<span>on</span>
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
student (cid)
로그인 후 복사
<span>with</span> <span>fillFactor</span> = 30;    --填充因子
로그인 후 복사
 
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
--聚集索引
로그인 후 복사
로그인 후 복사
<span>if</span> (<span>exists</span> (<span>select</span> * <span>from</span> sys.indexes <span>where</span> name = <span>'idx_sex'</span>))
로그인 후 복사
    <span>drop</span> <span>index</span> student.idx_sex
로그인 후 복사
<span>go</span>
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
<span>create</span> <span>clustered</span> <span>index</span> idx_sex
로그인 후 복사
<span>on</span>
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
student(sex);
로그인 후 복사
 
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
--聚集索引
로그인 후 복사
로그인 후 복사
<span>if</span> (<span>exists</span> (<span>select</span> * <span>from</span> sys.indexes <span>where</span> name = <span>'idx_name'</span>))
로그인 후 복사
    <span>drop</span> <span>index</span> student.idx_name
로그인 후 복사
<span>go</span>
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
<span>create</span> <span>unique</span> <span>index</span> idx_name
로그인 후 복사
<span>on</span>
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
student(name);
로그인 후 복사
로그인 후 복사

   

    4、 适合的创建索引的列

        当数据库的某一列被频繁的用于数据库查询时,或者该列用于数据库进行排序时可以创建成索引

 

    5、 不适合创建索引的列

        如果列中有几个不同的值,或者表中仅包含几行值,则不推荐为其创建索引。因为索引在搜索数据所花的时间比在表中逐行搜索话的时间更长。

 

? 视图

    1、 什么是视图

        视图就是一个虚拟的数据表,该数据表中的数据记录是有一条查询语句的查询结果得到的。

 

    2、 创建视图准则

        创建视图需要考虑一下准则:

    # 视图名称必须遵循标识符的规则,该名称不得与该架构的如何表的名称相同

    # 你可以对其他视图创建视图。允许嵌套视图,但嵌套不得超过32层。视图最多可以有1024个字段

    # 不能将规则和default定义于视图相关联

    # 视图的查询不能包含compute子句、compute by子句或into关键字

    # 定义视图的查询不能包含order by子句,除非在select 语句的选择列表中还有top子句

   

    下列情况必须指定视图中每列的名称:

    # 视图中的如何列都是从算术表达式、内置函数或常量派生而来

    # 视图中有两列或多列具有相同名称(通常由于视图定义包含联接,因此来自两个或多个不同的列具有相同的名称)

    # 希望视图中的列指定一个与其原列不同的名称(也可以在视图中重命名列)。无论是否重命名,视图列都回继承原列的数据类型

 

    3、 创建视图

--创建视图
로그인 후 복사
<span>if</span> (<span>exists</span> (<span>select</span> * <span>from</span> sys.objects <span>where</span> name = <span>'v_stu'</span>))
로그인 후 복사
    <span>drop</span> <span>view</span> v_stu
로그인 후 복사
<span>go</span>
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
<span>create</span> <span>view</span> v_stu
로그인 후 복사
<span>as</span>
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
<span>select</span> id, name, age, sex <span>from</span> student;
로그인 후 복사

   

    4、 修改视图

<span>alter</span> <span>view</span> v_stu
로그인 후 복사
<span>as</span>
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
<span>select</span> id, name, sex <span>from</span> student;
로그인 후 복사
 
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
<span>alter</span> <span>view</span> v_stu(编号, 名称, 性别)
로그인 후 복사
<span>as</span>
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
    <span>select</span> id, name, sex <span>from</span> student
로그인 후 복사
<span>go</span>
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
<span>select</span> * <span>from</span> v_stu;
로그인 후 복사
 
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
<span>select</span> * <span>from</span> information_schema.views;
로그인 후 복사

   

    5、 加密视图

--加密视图
로그인 후 복사
<span>if</span> (<span>exists</span> (<span>select</span> * <span>from</span> sys.objects <span>where</span> name = <span>'v_student_info'</span>))
로그인 후 복사
    <span>drop</span> <span>view</span> v_student_info
로그인 후 복사
<span>go</span>
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
<span>create</span> <span>view</span> v_student_info
로그인 후 복사
<span>with</span> encryption --加密
로그인 후 복사
<span>as</span>
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
    <span>select</span> id, name, age <span>from</span> student
로그인 후 복사
<span>go</span>
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
--view_definition <span>is</span> <span>null</span>
로그인 후 복사
<span>select</span> * <span>from</span> information_schema.views 
로그인 후 복사
<span>where</span> table_name <span>like</span> <span>'v_stu'</span>;
로그인 후 복사
로그인 후 복사

로그인 후 복사
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Hibernate 프레임워크에서 HQL과 SQL의 차이점은 무엇입니까? Hibernate 프레임워크에서 HQL과 SQL의 차이점은 무엇입니까? Apr 17, 2024 pm 02:57 PM

Hibernate 프레임워크에서 HQL과 SQL의 차이점은 무엇입니까?

Go 언어는 데이터베이스의 추가, 삭제, 수정 및 쿼리 작업을 어떻게 구현합니까? Go 언어는 데이터베이스의 추가, 삭제, 수정 및 쿼리 작업을 어떻게 구현합니까? Mar 27, 2024 pm 09:39 PM

Go 언어는 데이터베이스의 추가, 삭제, 수정 및 쿼리 작업을 어떻게 구현합니까?

Xiaomi 15 시리즈 전체 코드명 공개: Dada, Haotian, Xuanyuan Xiaomi 15 시리즈 전체 코드명 공개: Dada, Haotian, Xuanyuan Aug 22, 2024 pm 06:47 PM

Xiaomi 15 시리즈 전체 코드명 공개: Dada, Haotian, Xuanyuan

화웨이 메이트 60 시리즈 구매 최적기, 새로운 AI 제거 + 이미지 업그레이드, 가을 프로모션 즐기기 화웨이 메이트 60 시리즈 구매 최적기, 새로운 AI 제거 + 이미지 업그레이드, 가을 프로모션 즐기기 Aug 29, 2024 pm 03:33 PM

화웨이 메이트 60 시리즈 구매 최적기, 새로운 AI 제거 + 이미지 업그레이드, 가을 프로모션 즐기기

PHP에서 MySQLi를 사용하여 데이터베이스 연결을 설정하는 방법에 대한 자세한 튜토리얼 PHP에서 MySQLi를 사용하여 데이터베이스 연결을 설정하는 방법에 대한 자세한 튜토리얼 Jun 04, 2024 pm 01:42 PM

PHP에서 MySQLi를 사용하여 데이터베이스 연결을 설정하는 방법에 대한 자세한 튜토리얼

Hibernate는 어떻게 다형성 매핑을 구현합니까? Hibernate는 어떻게 다형성 매핑을 구현합니까? Apr 17, 2024 pm 12:09 PM

Hibernate는 어떻게 다형성 매핑을 구현합니까?

iOS 18에는 손실되거나 손상된 사진을 검색할 수 있는 새로운 '복구된' 앨범 기능이 추가되었습니다. iOS 18에는 손실되거나 손상된 사진을 검색할 수 있는 새로운 '복구된' 앨범 기능이 추가되었습니다. Jul 18, 2024 am 05:48 AM

iOS 18에는 손실되거나 손상된 사진을 검색할 수 있는 새로운 '복구된' 앨범 기능이 추가되었습니다.

HTML이 데이터베이스를 읽는 방법에 대한 심층 분석 HTML이 데이터베이스를 읽는 방법에 대한 심층 분석 Apr 09, 2024 pm 12:36 PM

HTML이 데이터베이스를 읽는 방법에 대한 심층 분석

See all articles