详解Mariadb索引 (详解macOS苹果电脑系统完全卸载删除APP、PKG应用软件)

教程大全 2025-07-21 03:43:36 浏览

索引是一种特殊的文件(InnoDB数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的引用指针。

更通俗的说,数据库索引好比是一本书前面的目录,在查找内容之前可以先在目录中查找索引位置,以此快速定位查询数据。

单值(列)索引:即一个索引只包含单个列,一个表可以有多个单列索引。

唯一索引:索引列的值必须唯一,但允许有空值。 -> 主键是特殊的唯一索引,因为其不允许有空值。

复合(组合)索引:即一个索引包含多个列。

全文索引:FULLTEXTl类型索引,可以在CHAR,VARCHAR,或者TEXT类型的列上创建,仅MyISAM支持。

空间索引:对空间数据库的支持,GIS系统什么的。。。。哎呀,不看这里了,看起来比较吊。

各存储引擎支持的索引结构如下表(摘自MariaDB的KB):

其中BTREE是默认的索引结构,而对于MEMORY存储引擎,HASH则是默认的。

详解Mariadb索引

B-TREE:支持 >, >=, =, >=, 操作符,

R-tree:空间索引上的数据结构,不看了…..太难。

哪些情况需要创建索引

哪些情况不要创建索引

提高了查询速度,同时却会降低更新表的速度,如对表进行INSERT、UPDATE、和DELETE。

因为更新表时,MySQL不仅要保存数据,还要保存一下索引文件。

数据重复且分布平均的表字段,因此应该只为最经常查询和最经常排序的数据建立索引。

注意,如果某个数据列包含许多重复的内容,为它建立索引就没有太大的实际效果。

最左前缀原则

这里找到一篇好文章,摘自知乎:mysql索引最左匹配原则的理解? 作者:沈杰

表结构如下:有三个字段,分别是id,name,cid

CREATETABLE`student`(`id`int(11)NOTNULLAUTO_INCREMENT,`name`varchar(255)DEFAULTNULL,`cid`int(11)DEFAULTNULL,PRIMARYKEY(`id`),KEY`name_cid_INX`(`name`,`cid`),)ENGINE=InnoDBAUTO_INCREMENT=8DEFAULTCHARSET=utf8

索引方面:id是主键,(name,cid)是一个多列索引。

下面是你有疑问的两个查询:

EXPLAINSELECT*FROMstudentWHEREcid=1;

Mariadb学习总结(六):索引Mariadb学习总结(六):索引

EXPLAINSELECT*FROMstudentWHEREcid=1ANDname=;

Mariadb学习总结(六):索引Mariadb学习总结(六):索引

你的疑问是: sql查询用到索引的条件是必须要遵守最左前缀原则,为什么上面两个查询还能用到索引?

讲上面问题之前,我先补充一些知识,因为我觉得你对索引理解是狭隘的: 上述你的两个查询的explain结果中显示用到索引的情况类型是不一样的。,可观察explain结果中的type字段。

你的查询中分别是: \1. type: index \2. type: ref

解释: index:这种类型表示是mysql会对整个该索引进行扫描。要想用到这种类型的索引,对这个索引并无特别要求,只要是索引,或者某个复合索引的一部分,mysql都可能会采用index类型的方式扫描。但是呢,缺点是效率不高,mysql会从索引中的第一个数据一个个的查找到最后一个数据,直到找到符合判断条件的某个索引。

所以:对于你的第一条语句:

EXPLAINSELECT*FROMstudentWHEREcid=1;

判断条件是cid=1,而cid是(name,cid)复合索引的一部分,没有问题,可以进行index类型的索引扫描方式。explain显示结果使用到了索引,是index类型的方式。

ref:这种类型表示mysql会根据特定的算法快速查找到某个符合条件的索引,而不是会对索引中每一个数据都进行一 一的扫描判断,也就是所谓你平常理解的使用索引查询会更快的取出数据。而要想实现这种查找,索引却是有要求的,要实现这种能快速查找的算法,索引就要满足特定的数据结构。简单说,也就是索引字段的数据必须是有序的,才能实现这种类型的查找,才能利用到索引。

有些了解的人可能会问,索引不都是一个有序排列的数据结构么。不过答案说的还不够完善,那只是针对单个索引,而复合索引的情况有些同学可能就不太了解了。

以该表的(name,cid)复合索引为例,它内部结构简单说就是下面这样排列的:

mysql创建复合索引的规则是首先会对复合索引的最左边的,也就是第一个name字段的数据进行排序,在第一个字段的排序基础上,然后再对后面第二个的cid字段进行排序。其实就相当于实现了类似 order by name cid这样一种排序规则。

所以:第一个name字段是绝对有序的,而第二字段就是无序的了。所以通常情况下,直接使用第二个cid字段进行条件判断是用不到索引的,当然,可能会出现上面的使用index类型的索引。这就是所谓的mysql为什么要强调最左前缀原则的原因。

那么什么时候才能用到呢?当然是cid字段的索引数据也是有序的情况下才能使用咯,什么时候才是有序的呢?观察可知,当然是在name字段是等值匹配的情况下,cid才是有序的。发现没有,观察两个name名字为 c 的cid字段是不是有序的呢。从上往下分别是4 5。 这也就是mysql索引规则中要求复合索引要想使用第二个索引,必须先使用第一个索引的原因。(而且第一个索引必须是等值匹配)。

所以对于你的这条sql查询:

EXPLAINSELECT*FROMstudentWHEREcid=1ANDname=;

没有错,而且复合索引中的两个索引字段都能很好的利用到了!因为语句中最左面的name字段进行了等值匹配,所以cid是有序的,也可以利用到索引了。

你可能会问:我建的索引是(name,cid)。而我查询的语句是cid=1 AND name=’小红’; 我是先查询cid,再查询name的,不是先从最左面查的呀?

好吧,我再解释一下这个问题:首先可以肯定的是把条件判断反过来变成这样 name=’小红’ and cid=1; 最后所查询的结果是一样的。那么问题产生了?既然结果是一样的,到底以何种顺序的查询方式最好呢?所以,而此时那就是我们的mysql查询优化器该登场了,mysql查询优化器会判断纠正这条sql语句该以什么样的顺序执行效率最高,最后才生成真正的执行计划。

所以,当然是我们能尽量的利用到索引时的查询顺序效率最高咯,所以mysql查询优化器会最终以这种顺序进行查询执行。

赞一个~不请自转,感谢原作者沈杰,如有侵权请告知。

创建表的时候创建索引

CREATETABLEtbl_name(Column_def1,Column_def2,Columndef3,.....index_def);index_def:{INDEX|KEY}[index_name][index_type](index_col_name,...)[index_option]...|{FULLTEXT|SPATIAL}[INDEX|KEY][index_name](index_col_name,...)[index_option]...|[CONSTRAINT[symbol]]PRIMARYKEY[index_type](index_col_name,...)[index_option]...|[CONSTRAINT[symbol]]UNIQUE[INDEX|KEY][index_name][index_type](index_col_name,...)[index_option]...|[CONSTRAINT[symbol]]FOREIGNKEY[index_name](index_col_name,...)reference_definition

例子,创建一张表,三个字段:id,name,gid 为name创建索引:

MariaDB[mydb]>CREATETABLE(->idint(10)PRIMARYKEYAUTO_INCREMENT,->nameVARCHAR(10)NOTNULL,->gidint(3),->INDEXname_idx(name(5))->);

其中需要说明的是,name(5)就是为name列创建索引,且仅取前5个字符进行索引。

更多创建表时的SQL语法可参考:

为存在的表创建索引

CREATE INDEX语法如下:

CREATE[ORREPLACE][ONLINE|OFFLINE][UNIQUE|FULLTEXT|SPATIAL]INDEX[IFNOTEXISTS]index_name[index_type]ONtbl_name(index_col_name,...)[WAITn|NOWAIT][index_option][algorithm_option|LOCK_option]...index_col_name:col_name[(length)][ASC|DESC]index_type:USING{BTREE|HASH|RTREE}index_option:KEY_BLOCK_SIZE[=]value|index_type|WITHPARSERparser_name|COMMENTalgorithm_option:ALGORITHM[=]{DEFAULT|INPLACE|COPY}lock_option:LOCK[=]{DEFAULT|NONE|SHARED|EXCLUSIVE}

先查看下上面创建的索引:

MariaDB[mydb]>SHOWINDEXFROM\G;***************************1.row***************************//主键会创建一个索引Table:Non_unique:0Key_name:PRIMARYSeq_in_index:1Column_name:idCollation:ACardinality:0Sub_part:NULLPacked:NULLNull:Index_type:BTREEComment:Index_comment:***************************2.row***************************//这个是我们自己创建的索引Table:Non_unique:1Key_name:name_idxSeq_in_index:1Column_name:nameCollation:ACardinality:0Sub_part:5Packed:NULLNull:Index_type:BTREEComment:Index_comment:2rows(0.00sec)

现在,我们把之前创建的索引删掉,然后创建一个多列索引(name,gid)

DROPINDEXname_idxON;//删除索引CREATEINDEXname_gid_idxON(name(5),gidDESC);//创建了多列索引,且name取前5,而gid则倒叙排列CREATEORREPLACEINDEXname_gid_idxON(name(5),gid);//修改了上面创建的这个索引

唯一索引

创建唯一约束时会自动创建唯一索引,但创建唯一索引时则不会创建唯一约束,且唯一索引能做到和唯一约束一样的效果。


mysql索引类型解释

索引分单列索引和组合索引。 单列索引,即一个索引只包含单个列,一个表可以有多个单列索引,但这不是组合索引。 组合索引,即一个索包含多个列。 MySQL索引类型包括:(1)普通索引这是最基本的索引,它没有任何限制。 它有以下几种创建方式:◆创建索引CREATE INDEX indexName ON mytable(username(length));如果是 CHAR,VARCHAR类型,length可以小于字段实际长度;如果是BLOB和TEXT类型,必须指定 length,下同。 ◆修改表结构ALTER mytable ADD INDEX [indexName] ON (username(length))◆ 创建表的时候直接指定CREATE TABLE mytable( ID INT NOT NULL, username VARCHAR(16) NOT NULL, INDEX [indexName] (username(length)) );删除索引的语法:DROP INDEX [indexName] ON mytable;(2)唯一索引它与前面的普通索引类似,不同的就是:索引列的值必须唯一,但允许有空值。 如果是组合索引,则列值的组合必须唯一。 它有以下几种创建方式:◆创建索引CREATE UNIQUE INDEX indexName ON mytable(username(length))◆修改表结构ALTER mytable ADD UNIQUE [indexName] ON (username(length))◆创建表的时候直接指定CREATE TABLE mytable( ID INT NOT NULL, username VARCHAR(16) NOT NULL, UNIQUE [indexName] (username(length)) );(3)主键索引它是一种特殊的唯一索引,不允许有空值。 一般是在建表的时候同时创建主键索引:CREATE TABLE mytable( ID INT NOT NULL, username VARCHAR(16) NOT NULL, PRIMARY KEY(ID) );当然也可以用 ALTER 命令。 记住:一个表只能有一个主键。 (4)组合索引为了形象地对比单列索引和组合索引,为表添加多个字段:CREATE TABLE mytable( ID INT NOT NULL, username VARCHAR(16) NOT NULL, city VARCHAR(50) NOT NULL, age INT NOT NULL );为了进一步榨取MySQL的效率,就要考虑建立组合索引。 就是将 name, city, age建到一个索引里:ALTER TABLE mytable ADD INDEX name_city_age (name(10),city,age);建表时,usernname长度为 16,这里用 10。 这是因为一般情况下名字的长度不会超过10,这样会加速索引查询速度,还会减少索引文件的大小,提高INSERT的更新速度。 如果分别在 usernname,city,age上建立单列索引,让该表有3个单列索引,查询时和上述的组合索引效率也会大不一样,远远低于我们的组合索引。 虽然此时有了三个索引,但MySQL只能用到其中的那个它认为似乎是最有效率的单列索引。 建立这样的组合索引,其实是相当于分别建立了下面三组组合索引:usernname,city,age usernname,city usernname为什么没有 city,age这样的组合索引呢?这是因为MySQL组合索引“最左前缀”的结果。 简单的理解就是只从最左面的开始组合。 并不是只要包含这三列的查询都会用到该组合索引,下面的几个SQL就会用到这个组合索引:SELECT * FROM mytable WHREE username=admin AND city=郑州 SELECT * FROM mytable WHREE username=admin而下面几个则不会用到:SELECT * FROM mytable WHREE age=20 AND city=郑州 SELECT * FROM mytable WHREE city=郑州(5)建立索引的时机到这里我们已经学会了建立索引,那么我们需要在什么情况下建立索引呢?一般来说,在WHERE和JOIN中出现的列需要建立索引,但也不完全如此,因为MySQL只对<,<=,=,>,>=,BETWEEN,IN,以及某些时候的LIKE才会使用索引。 例如:SELECT FROM mytable t LEFT JOIN mytable m ON = WHERE =20 AND =郑州此时就需要对city和age建立索引,由于mytable表的 userame也出现在了JOIN子句中,也有对它建立索引的必要。 刚才提到只有某些时候的LIKE才需建立索引。 因为在以通配符%和_开头作查询时,MySQL不会使用索引。 例如下句会使用索引:SELECT * FROM mytable WHERE username likeadmin%而下句就不会使用:SELECT * FROM mytable WHEREt Name like%admin因此,在使用LIKE时应注意以上的区别。 (6)索引的不足之处上面都在说使用索引的好处,但过多的使用索引将会造成滥用。 因此索引也会有它的缺点:◆虽然索引大大提高了查询速度,同时却会降低更新表的速度,如对表进行 INSERT、UPDATE和DELETE。 因为更新表时,MySQL不仅要保存数据,还要保存一下索引文件。 ◆建立索引会占用磁盘空间的索引文件。 一般情况这个问题不太严重,但如果你在一个大表上创建了多种组合索引,索引文件的会膨胀很快。 索引只是提高效率的一个因素,如果你的 MySQL有大数据量的表,就需要花时间研究建立最优秀的索引,或优化查询语句。 (7)使用索引的注意事项使用索引时,有以下一些技巧和注意事项:◆索引不会包含有NULL值的列只要列中包含有NULL值都将不会被包含在索引中,复合索引中只要有一列含有 NULL值,那么这一列对于此复合索引就是无效的。 所以我们在数据库设计时不要让字段的默认值为NULL。 ◆使用短索引对串列进行索引,如果可能应该指定一个前缀长度。 例如,如果有一个CHAR(255)的列,如果在前10个或20个字符内,多数值是惟一的,那么就不要对整个列进行索引。 短索引不仅可以提高查询速度而且可以节省磁盘空间和I/O操作。 ◆索引列排序MySQL查询只使用一个索引,因此如果 where子句中已经使用了索引的话,那么order by中的列是不会使用索引的。 因此数据库默认排序可以符合要求的情况下不要使用排序操作;尽量不要包含多个列的排序,如果需要最好给这些列创建复合索引。 ◆like语句操作一般情况下不鼓励使用like操作,如果非使用不可,如何使用也是一个问题。 like “%aaa%” 不会使用索引而like “aaa%”可以使用索引。 ◆不要在列上进行运算select * from users where YEAR(adddate)<2007;将在每个行上进行运算,这将导致索引失效而进行全表扫描,因此我们可以改成select * from users where adddate<‘2007-01-01’;◆不使用NOT IN和<>操作以上,就对其中MySQL索引类型进行了介绍。 转自:

win7 怎么卸载mariadb

腾讯电脑管家这款管理软件你可以试试。 该软件的工具箱内提供的管理功能挺全的。 其中就提供软件卸载管理,而且该软件功能属于强力卸载,对于个别问题软件,还是挺有解决办法的。 在完成卸载后,你还可以通过垃圾清理功能清除卸载后留下的相关残留文件及注册表信息。 打开腾讯电脑管家——工具箱——软件卸载——强力删除打开腾讯电脑管家——工具箱——清理垃圾/注册表垃圾

linux 如何编译安装mysql?

展开全部不同linux版本,安装不同版本的mysql方法各不相同,下面以CentOS 6.5编译安装MySQL 5.6.16介绍:一.准备工作安装各个依赖包[root@WebServer ~]# yum -y install gcc gcc-devel gcc-c++ gcc-c++-devel autoconf* automake* zlib* libxml* ncurses-devel ncurses libgcrypt* libtool* cmake openssl openssl-devel bison bison-devel unzip 2.新建mysql组和用户[root@WebServer ~]# groupadd mysql[root@WebServer ~]# useradd -g mysql -s /sbin/nologin mysql 3.目录准备[root@WebServer ~]# mkdir -p /webserver/mysql/etc[root@WebServer ~]# mkdir -p /webserver/mysql/data[root@WebServer ~]# mkdir -p /webserver/mysql/tmp[root@WebServer ~]# chown -R /webserver/mysql 4.解压MySQL并进入安装目录[root@WebServer ~]# tar zxvf [root@WebServer ~]# cd mysql-5.6.16 二.编译并安装1.编译MySQL[root@WebServer mysql-5.6.16]# cmake -DCMAKE_INSTALL_PREFIX=/webserver/mysql \> -DSYSCONFDIR=/webserver/mysql/etc \> -DMYSQL_DATADIR=/webserver/mysql/data \> -DMYSQL_TCP_PORT=3306 \> -DMYSQL_UNIX_ADDR=/webserver/mysql/tmp/ \> -DMYSQL_USER=mysql \> -DEXTRA_CHARSETS=all \> -DWITH_READLINE=1 \> -DWITH_SSL=system \> -DWITH_EMBEDDED_SERVER=1 \> -DENABLED_LOCAL_INFILE=1 \> -DWITH_INNOBASE_STORAGE_ENGINE=1 \> -DENABLE_DOWNLOADS=1 2.如果出现以下错误则需要[root@WebServer mysql-5.6.16]# cd source_downloads/[root@WebServer source_downloads]# unzip [root@WebServer source_downloads]# ./configure[root@WebServer source_downloads]# make[root@WebServer source_downloads]# cd .. 然后删除mysql-5.6.16目录下的重新使用cmake进行编译安装2.安装[root@WebServer mysql-5.6.16]# make && make install 编译过程会比较漫长,编译时间取决于机器的性能三配置1.客户端库文件的链接(未执行此步骤的话,在PHP编译时会提示找不到MySQL文件)[root@WebServer mysql-5.6.16]# ln -s /webserver/mysql/lib/.18 /usr/lib64/.18 ps:我使用的是64位CentOS,如果使用的是32位请使用ln -s /webserver/mysql/lib/.18 /usr/lib/.18 启动文件的配置[root@WebServer mysql-5.6.16]# cp support-files/ /etc/init.d/mysqld[root@WebServer mysql-5.6.16]# chmod +x /etc/init.d/mysqld[root@WebServer mysql-5.6.16]# vim /etc/init.d/mysqldbasedir=/webserver/mysqldatadir=/webserver/mysql/data//修改以上这2行的路径即可 3.设置MySQL配置文件[root@WebServer mysql-5.6.16]# cp support-files/ /webserver/mysql/etc/[root@WebServer mysql-5.6.16]# rm -rf /etc/[root@WebServer mysql-5.6.16]# ln -s /webserver/mysql/etc/ /etc/ 4.初始化数据库[root@WebServer mysql-5.6.16]# cd /webserver/mysql[root@WebServer mysql]# ./scripts/mysql_install_db --user=mysql --basedir=/webserver/mysql --datadir=/webserver/mysql/data 5.链接MySQL命令(这一步可以让我们方便很多,可以不用写出命令的路径,也可以写入/etc/profile的PATH中)[root@WebServer ~]# cd /usr/sbin[root@WebServer sbin]# ln -s /webserver/mysql/bin/* . 6.启动MySQL并设置为开机启动[root@WebServer sbin]# service mysqld start ;chkconfig mysqld onStarting MySQL.. SUCCESS! 7.设置MySQL root用户的密码[root@WebServer ~]# mysqladmin -u root password 这里将MySQL的root密码设置为,强烈不建议将数据库的密码设的简单8.删除用户密码为空的用户[root@WebServer ~]# mysql -u root -pEnter password:mysql> use mysql;mysql> select Host,User,Password from user;+-----------+------+-------------------------------------------+| Host| User | Password|+-----------+------+-------------------------------------------+| localhost | root | *6BB4837EBEE4568DDA7DC67ED2CA2AD9 || webserver | root ||| 127.0.0.1 | root ||| ::1| root ||| localhost |||| webserver |||+-----------+------+-------------------------------------------+6 rows in set (0.00 sec)mysql> delete from user where password=;Query OK, 5 rows affected (0.00 sec)mysql> flush privileges;Query OK, 0 rows affected (0.00 sec)mysql> select Host,User,Password from user;+-----------+------+-------------------------------------------+| Host| User | Password|+-----------+------+-------------------------------------------+| localhost | root | *6BB4837EBEE4568DDA7DC67ED2CA2AD9 |+-----------+------+-------------------------------------------+1 row in set (0.00 sec)mysql> exit;完毕。

本文版权声明本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请联系本站客服,一经查实,本站将立刻删除。

发表评论

热门推荐