4.2 索引及其操作

        对数据库中的表进行查询操作时有两种搜索扫描方式,一种是全表扫描,另一种就是使用表上建立的索引进行扫描。

        全表扫描要查找某个特定的行,必须从头开始一一查看表中的每一行,与查询条件做对比,返回满足条件的记录,当表中有很多行时,查询效率非常低;
索引是按数据表中一列或多个列进行索引排序,并为其建立指向数据表记录所在位置的指针。   

        使用索引可以提高系统的性能,加快数据检索的速度。但是使用索引要付出一定的代价。增加存储空间,降低更新表中数据的速度。

索引的分类:

1)普通索引
       最基本的索引类型,没有唯一性之类的限制。创建普通索引的关键字是INDEX。
2)唯一性索引
       和普通索引基本相同,但唯一性索引的索引列的所有值都只能出现一次,即必须是唯一的。创建唯一性索引的关键字是UNIQUE。
3)主键
       是一种唯一性索引,必须指定为primary key。一般在创建表时指定,也可以通过修改表的方式加入主键。每个表只能有一个主键。
4)聚簇索引
       聚簇索引的索引顺序就是数据存储的物理顺序,保证索引值相近的元组所存储的物理位置也相近。一个表只能有一个聚簇索引。
5)全文索引
        MySQL支持全文检索和全文索引。在MysQL中,全文索引的索引类型为fulltext。

索引可以建立在一列上,称为单列索引,一个表可以建立多个单列索引。索引也可以建立在多个列上,称为组合索引、复合索引或多列索引。

4.2.1 创建索引

三种方法:

在已有的表上创建索引可用create index语句和alter table语句;
在创建表的同时创建索引可用create table语句。

1. 使用create index语句创建索引

语法格式:create [ unique ] INDEX index_name
                        on table_name ( col_name [ ( length ) ] [ asc | desc ],... )

其中,length为可选项,用于指定使用列的前length个字符创建索引。

【例4.12】在数据库study中学生表的姓名列上创建一个普通索引 Ⅰ_studentSname。

create index I_studentSname on 学生(姓名);

【4.13】在数据库study中课程表的课程号列上创建一个普通索引Ⅰ_courseCno,要求按课程号字段值降序排列。

create index I_courseCno on 课程(课程号 desc);

【4.14】在数据库study中选课表的成绩列(降序)和学号列(升序)创建一个组合索引Ⅰ_courseGradeSno。

create index I_courseGradeSno on 选课(成绩 desc,学号);

排序时先按成绩列降序排序。若成绩列值相同,再按学号列升序排序。 

2.使用alter table语句创建索引

语法格式:
alter TABLE tab_name
add [ unique | fulltext ] [ index | key ] [ index_name ] (col_name [ ( length ) ] [ asc | desc ],...)  

【例4.15】在数据库study中教师表的tname列创建一个唯一索引Ⅰ_teacherTname。

alter table 教师add unique index I_teacherTname(tname desc);

这里的“tname desc”是指按照汉语拼音对应的英文字母顺序排列;相应的,如果是英文,按照英文字母顺序进行排列。

3. 使用create table语句创建索引

可在创建表的同时创建索引。

语法格式:create TABLE tab_name [ col_name data_type ]
                        [ constraint index_name ] [ unique | fulltext ]
                        [ index | key ] [ index_name ] (col_name [ ( length ) ] [ asc | desc ],...)  

【例4.16】在数据库study中创建新表选课1表,主键为学号和课程号,同时在成绩列上创建普通索引。

create table 选课1 (学号 char(6) not null,课程号 char(4) not null,成绩 tinyint,primary key(学号,课程号),index(成绩));

 

4.2.2 查看表上建立的索引

语法格式:show { index | indexes | keys } { from | in } tb1_name [ { from | in } db_name ]

【例4.17】查看4.16所创建的选课1表的索引。

show index from 选课1;

从以上代码可以看出,在选课1表上建立了3个索引,2个主键索引,索引名称是primary。索引建立在学号和课程号列上,1个普通索引,索引名称是grade,索引建立在grade列上。

4.2.3 删除索引

1. 使用drop index语句。

语法格式:drop INDEX index_name on table_name

【例4.18】删除已建的索引Ⅰ_courseGradeSno。

drop index I_courseGradeSno on 选课;

该语句执行后,选课表上的索引被删除,对选课表无影响,也不影响该表上其他索引。

2. 使用alter table语句删除索引。

语法格式:alter  table tb1_name drop INDEX index_name

【例4.19】删除已建的索引Ⅰ_teacherTname。

alter table 教师drop index I_teacherTname;

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/848299.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【AndroidStudio旧版本BUG问题】完美解决运行报错问题Invalid keystore format

由于之前安装的版本导致AndroidStudio 运行报错:Invalid keystore format 在如下截图的路径中删了debug.keystore重新打开Android Studio运行一下就好了!!! 下面介绍各个模块功能: adbkey 是 Android Debug Bridge (AD…

洛谷P2179 [NOI2012] 骑行川藏

题目描述 蛋蛋非常热衷于挑战自我,今年暑假他准备沿川藏线骑着自行车从成都前往拉萨。 川藏线的沿途有着非常美丽的风景,但在这一路上也有着很多的艰难险阻,路况变化多端,而蛋蛋的体力十分有限,因此在每天的骑行前设定好目的地&…

如何处理SSL证书过期问题?

SSL证书是网络安全的重要组成部分,它为网站提供了数据加密、身份验证和增强用户信任等多重保护。然而,SSL证书并非永久有效,其有效期通常为一年。当SSL证书过期时,网站安全性会受到影响,甚至可能面临安全风险。本文旨在…

好的一些网安资源

镜像:https://msdn.itellyou.cn/ 编程学习{ 菜鸟教程:https://www.runoob.com/ w3school:https://www.w3school.com.cn/ https://www.dotcpp.com/ http://zh.cppreference.com/ https://beginnersbook.com/ https://www.ai8py.com/ }…

《2024年网络安全预测:未来规划深度洞察》

2024 年打击网络对手的计划。 阅读报告,了解我们的专家对 2024 年网络安全行业的预测,包括: 攻击者将人工智能融入其行动中,防御者利用它来加强检测和响应 民族国家继续开展网络行动以实现其地缘政治目标 攻击者继续利用零日漏洞…

【Android面试题】请说一说ArrayList 如何保证线程安全,除了加关键字的方式 ?

面试题:请说一说ArrayList 如何保证线程安全,除了加关键字的方式 ? 这道题想考察什么? ArrayList的底层原理: ArrayList是基于数组实现的,是一个动态的数组,可以自动扩容。 但是ArrayList不是线程安全的,效率比较高,只能用于单线程环境 考察的知识点 ArrayList底层…

【UML用户指南】-08-对基本结构建模-图

目录 1、41视图 2、术语和概念 3、结构图 (1)类图(class diagram): (2)构件图:(component diagram) (3)组合结构图:…

会声会影2024官方旗舰版最新版评测

随着数字内容创作的兴起,越来越多的人开始关注视频制作领域。对于初学者和专业人士来说,选择一款适合自己的视频编辑软件是非常重要的。今天,我将为大家全面而深入地评测会声会影2024最新版,从易用性、功能性以及性价比方面进行评…

Lisp解析器技术文档

Lisp解析器技术文档 目录 Lisp解析器技术文档 一、引言 二、Lisp语言简介 三、Lisp解析器实现

js 数字精确度

事情的起源: 项目中 填写的赔付金额是小数 传给后端需要 *100 9.87 *100 传给后端后是986.9999999999999 后端直接取整 就变成了9.86了 0.1 0.2 ! 0.3 console.log(0.1 0.2) //0.30000000000000004 console.log(0.1 0.2 0.3) //false1. 数字的存储 浮点数是用…

InfiniGate自研网关实现思路七

25.网关Nginx负载模型配置 通过模拟多个HTTP服务配置到 Nginx 做负载均衡,以学习API网关负载的配置和使用 API 网关是用于支撑分布式 RPC 接口协议转换提供 HTTP 调用的一套服务,那么 API 网关系统就需要可横向扩展来满足系统的吞吐量诉求。所以这里需…

宝塔nginx配置

将跟php有关的注释掉: 添加: #解决vue刷新404问题try_files $uri $uri/ /index.html; location /prod-api/ {proxy_set_header Host $http_host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header REMOTE-HOST $remote_addr;proxy_set_header…

Day13:vw 和 vh 基本使用

目标:使用 vw 和 less 完成移动端的布局。 一、vw 适配方案 1、vw 和 vh 基本使用 vw 和 vh 是相对单位,相对视口尺寸计算结果。 vw:viewport width(1vw 1/100视口宽度 )vh:lviewport height ( 1vh 1/…

《C++避坑神器·二十六》结构体报重定义错误问题和std::variant同时存储不同类型的值使用方式

1、结构体重定义错误问题: struct person {int age; }p;p是一个已经创建好的对象,相当于struct person p; 如果放在头文件中容易被多个文件包含报重定义错误 typedef struct person {int age; }person;person就是struct person,这时候并没有…

Priority_queue

一、priority_queue的介绍和使用 1.1 priority_queue的介绍 1.优先队列是一种容器适配器,根据严格的弱排序标准,它的第一个元素总是它所包含的元素中最大的。 2.优先队列类似于堆, 在堆中可以随时插入元素, 并且只能检索最大堆…

深入了解JavaScript中的indexOf()方法:实现数组元素的搜索和索引获取

在JavaScript中,indexOf()方法用于搜索数组中的元素,并返回匹配的第一个元素的索引。如果数组中没有匹配的元素,则返回-1。 indexOf()方法的语法如下所示: array.indexOf(searchElement[, fromIndex]) 其中searchElement是要搜…

CMakeLists.txt和Package.xml

CMakeLists.txt和Package.xml CMakeLists.txt 总览 CMakeLists.txt 是用于定义如何构建 ROS (Robot Operating System) 包的 CMake 脚本文件。CMake 是一个跨平台的构建系统,用于自动化编译过程。在 ROS 中,CMakeLists.txt 文件指定了如何编译代码和链…

门面模式Api网关(SpringCloudGateway)

1. 前言 当前通过Eureka、Nacos解决了服务注册和服务发现问题,使用Spring Cloud LoadBalance解决了负载均衡的需求,同时借助OpenFeign实现了远程调用。然而,现有的微服务接口都直接对外暴露,容易被外部访问。为保障对外服务的安全…

分布式系统常用的三注解:@DS,@DistributeLock,@GlobalTransactional【开发实践】

文章目录 一、多数据源的动态切换:DS1.1 多数据源的背景1.1.1 主从复制1.1.2 读写分离1.1.3 分库分表 1.2 DS的使用流程1.2.1 添加依赖1.2.2 配置数据源1.2.3 使用 DS 切换数据源 1.3 使用DS切换数据源失效1.3.1 情形二:同类中的方法调用DS方法1.3.2 情形…

关于Golang中自定义包的简单使用-Go Mod

1. go env 查看 GO111MODULE 是否为 on,不是修改成on go env -w GO111MODULEon 2 .自定义包的目录格式 3. test.go 内容 package calc func Add(x, y int) int { // 首字母大写表示公有方法return x y }func Sub(x, y int) int {return x - y } 4.生成calc目…