bitsCN.com
索引是创建在表上的,对数据库表中一列或多列的值进行排序的一种结构
其作用主要在于提高查询的速度,降低数据库系统的性能开销
通过索引,查询数据不必读完记录的全部信息进行匹配,而是只查询索引列
索引相当于字典中的音序表,要查询某字时可以在音序表中找到
然后直接跳转到那一音序所在位置,而不必从字典第一页开始翻,逐字匹配
tips:索引虽能提高查询速度,但在插入记录时会按照索引进行排序,因此降低了插入速度
最好的操作方式是先删除索引,插入大量记录后再创建索引
索引分类
1.普通索引:不附加任何限制条件,可创建在任何数据类型中
2.唯一性索引:使用unique参数可以设置索引为唯一性索引,在创建索引时,限制该索引的值必须唯一,主键就是一种唯一性索引
3.全文索引:使用fulltext参数可以设置索引为全文索引。全文索引只能创建在char、varchar或text类型的字段上。查询数据量较大的字符串类型字段时,效果明显。但只有MyISAM存储引擎支持全文检索
4.单列索引:在表中单个字段上创建的索引,单列索引可以是任何类型,只要保证索引只对应一个一个字段
5.多列索引:在表中多个字段上创建的索引,该索引指向创建时对应的多个字段
6.空间索引:使用spatial参数可以设置索引为空间索引,空间索引只能建立在空间数据类型上比如geometry,并且不能为空,目前只有MyISAM存储引擎支持
在创建表时创建索引
创建普通索引
mysql> create table index1( -> id int, -> name varchar(20), -> sex boolean, -> index(id) -> );Query OK, 0 rows affected (0.11 sec)
此处在id字段上创建索引,show create table可查看
创建唯一性索引
mysql> create table index2( -> id int unique, -> name varchar(20), -> unique index index2_id(id ASC) -> );Query OK, 0 rows affected (0.12 sec)
此处使用id字段创建了一个名为index2_id的索引
这里的id字段可以不设置唯一性约束,但这样一来索引就没有作用
创建全文索引
mysql> create table index3( -> id int, -> info varchar(20), -> fulltext index index3_info(info) -> )engine=MyISAM;Query OK, 0 rows affected (0.07 sec)
要注意创建全文索引时只能使用MyISAM存储引擎
创建单列索引
mysql> create table index4( -> id int, -> subject varchar(30), -> index index4_st(subject(10)) -> );Query OK, 0 rows affected (0.12 sec)
此处subject字段长度是30,而索引长度则是10
这么做的目的在于提高查询速度,对于字符型的数据不用查询全部信息
创建多列索引
mysql> create table index5( -> id int, -> name varchar(20), -> sex char(4), -> index index5_ns(name,sex) -> );Query OK, 0 rows affected (0.10 sec)
可以看出,这里使用了name字段和sex字段创建索引列
创建空间索引
mysql> create table index6( -> id int, -> space geometry not null, -> spatial index index6_sp(space) -> )engine=MyISAM;Query OK, 0 rows affected (0.07 sec)
这里需要注意空间space字段不能为空,还有存储引擎
在已经存在的表上创建索引
创建普通索引
mysql> create index index7_id on example0(id);Query OK, 0 rows affected (0.07 sec)Records: 0 Duplicates: 0 Warnings: 0
这里在现有表的id字段上创建了一条名为index7_id的索引
创建唯一性索引
mysql> create unique index index8_id on example1(course_id);Query OK, 0 rows affected (0.16 sec)Records: 0 Duplicates: 0 Warnings: 0
此处只需要在index关键字前面加上unique即可
至于表中的course_id字段,最要也设置唯一性约束条件
创建全文索引
mysql> create fulltext index index9_info on example2(info);Query OK, 0 rows affected (0.07 sec)Records: 0 Duplicates: 0 Warnings: 0
fulltext关键字用来设置全文引擎,此处的表必须是MyISAM存储引擎
创建单列索引
mysql> create index index10_addr on example3(address(4));Query OK, 0 rows affected (0.16 sec)Records: 0 Duplicates: 0 Warnings: 0
此表中address字段的长度是20,这里只查询4字节,不需要全部查询
创建多列索引
mysql> create index index11_na on example4(name,address);Query OK, 0 rows affected (0.16 sec)Records: 0 Duplicates: 0 Warnings: 0
索引创建好之后,查询中必须有name字段才能使用
创建空间索引
mysql> create spatial index index12_line on example5(space);Query OK, 0 rows affected (0.07 sec)Records: 0 Duplicates: 0 Warnings: 0
这里需要注意存储引擎是MyISAM,还有空间数据类型
用alter table语句来创建索引
创建普通索引
mysql> alter table example6 add index index13_n(name(20));Query OK, 0 rows affected (0.16 sec)Records: 0 Duplicates: 0 Warnings: 0
创建唯一性索引
mysql> alter table example7 add unique index index14_id(id);Query OK, 0 rows affected (0.20 sec)Records: 0 Duplicates: 0 Warnings: 0
创建全文索引
mysql> alter table example8 add fulltext index index15_info(info);Query OK, 0 rows affected (0.08 sec)Records: 0 Duplicates: 0 Warnings: 0
创建单列索引
mysql> alter table example9 add index index16_addr(address(4));Query OK, 0 rows affected (0.16 sec)Records: 0 Duplicates: 0 Warnings: 0
创建多列索引
mysql> alter table example10 add index index17_in(id,name);Query OK, 0 rows affected (0.16 sec)Records: 0 Duplicates: 0 Warnings: 0
创建空间索引
mysql> alter table example11 add spatial index index18_space(space);Query OK, 0 rows affected (0.06 sec)Records: 0 Duplicates: 0 Warnings: 0
到此,三种操作方式,每种索引类别的建立就都列举了
对于索引,重要的是理解索引的概念,明白索引的种类
更多的是自己的使用经验
最后来看看索引的删除
删除索引
mysql> drop index index18_space on example11;Query OK, 0 rows affected (0.08 sec)Records: 0 Duplicates: 0 Warnings: 0
这里是刚刚创建的一条索引
其中index18_space是索引名,example11是表名
bitsCN.com

Microsoft Word文档在保存时包含一些元数据。这些详细信息用于在文档上识别,例如创建时间、作者是谁、修改日期等。它还具有其他信息,例如字符数,字数,段落数等等。如果您可能想要删除作者或上次修改的信息或任何其他信息,以便其他人不知道这些值,那么有一种方法。在本文中,让我们看看如何删除文档的作者和上次修改的信息。删除微软Word文档中的作者和最后修改的信息步骤 1 –转到

拼多多软件内提供的商品好物非常多,随时随地想买就买,而且每一件商品质量都是严格把关的,件件商品都是正品,不同还有非常多优惠的购物折扣,让大家网购根本停不下来。输入手机号在线登录,在线添加多个收货地址和联系方式,可以随时查看最新的物流动态,不同品类的商品板块都是开放的,搜索上下滑动选购下单,足不出户轻松体验便捷的网购服务,还能查看所有的购买记录,包括自己买过的商品,数十个购物红包、优惠券免费领取使用,现在小编在线详细为拼多多用户们带来查看买过的商品记录的方法。 1.打开手机,点击拼多多图标,

如何在Linux中查看命令历史记录在Linux中,我们使用history命令来查看所有以前执行的命令的列表。它有一个非常简单的语法:history与历史记录命令配对的一些选项包括:选项描述-c清除当前会话的命令历史记录-w将命令历史记录写入文件-r从历史记录文件重新加载命令历史记录-n限制最近命令的输出数量只需运行history命令即可在Linux终端中查看所有以前执行的命令的列表:除了查看命令历史记录之外,您还可以管理命令历史记录并执行修改先前执行的命令、反向搜索命令历史记录甚至完全删除历史记

iPhone中的通话记录经常被低估,并且是iPhone最关键的功能之一。凭借其简单性,此功能具有至关重要的意义,可以提供有关在设备上拨打或接听的呼叫的重要见解。无论是出于工作目的还是法律诉讼,访问通话记录的能力都被证明是无价的。简单来说,通话记录是指每当拨打或接听电话时在iPhone上创建的条目。这些日志包含关键信息,包括联系人的姓名(如果未另存为联系人,则为号码)、时间戳、持续时间和呼叫状态(已拨打、未接或未接听)。它们是您的通信历史记录的简明记录。通话记录包括存储在iPhone上的通话记录条

C#开发建议:日志记录与监控系统摘要:在软件开发过程中,日志记录与监控系统是至关重要的工具。本文章将介绍C#开发中日志记录与监控系统的作用和实施建议。引言:在大型软件开发项目中,日志记录和监控是必不可少的工具。它们可以帮助我们实时了解程序运行状况,快速发现并解决问题。本文将讨论C#开发中如何使用日志记录和监控系统,以提高软件质量和开发效率。日志记录系统的作用

如何进行Java开发项目的日志记录与监控一、背景介绍随着互联网的快速发展,越来越多的企业开始进行Java开发,构建各种类型的应用程序。而在开发过程中,日志记录和监控是一个不可忽视的重要环节。通过日志记录与监控,开发人员可以及时发现和解决问题,保证应用程序的稳定性和安全性。二、日志记录的重要性1.问题追踪:在应用程序出现错误时,日志记录可以帮助我们快速定位问题

数据库系统的三级模式结构是指数据库系统由外模式、模式和内模式三级构成。模式也称逻辑模式,是所有用户的公共数据视图;外模式也称用户模式,是数据库用户的数据视图,是与某应用有关的数据的逻辑表示;内模式也称存储模式是数据在数据库内部的组织方式。

iPhone可让您在“健康”App中添加药物,以便跟踪和管理您每天服用的药物、维生素和补充剂。然后,您可以在设备上收到通知时记录已服用或跳过的药物。记录用药后,您可以查看您服用或跳过用药的频率,以帮助您跟踪自己的健康状况。在这篇文章中,我们将指导您在iPhone上的健康应用程序中查看所选药物的日志历史记录。如何在“健康”App中查看用药日志历史记录简短指南:前往“健康”App>浏览“>用药”>用药“>选择一种用药>”选项“&a


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Dreamweaver Mac version
Visual web development tools

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.
