mysql读库怎么建索引 mysql如何创建索引sql语句

MySQL如何为表字段添加索引1.添加PRIMARY KEY(主键索引)mysql读库怎么建索引:
2.添加UNIQUE(唯一索引) mysql读库怎么建索引:
3.添加INDEX(普通索引) mysql读库怎么建索引:
4.添加FULLTEXT(全文索引) :
5.添加多列索引:
如何创建mysql索引以及索引的优缺点mysql教程:索引的使用以及索引的优缺点
1. 索引(index)是帮助MySQL高效获取数据的数据结构 。
它对于高性能非常关键,但人们通常会忘记或误解它 。
索引在数据越大的时候越重要 。规模小、负载轻的数据库即使没有索引,也能有好的性能,但是当数据增加的时候,性能就会下降很快 。
Tip:蠕虫复制,可以快速复制大量的数据
例:insert into emp select * from emp;
2. MySQL中常见的索引
◆普通索引 ◆唯一索引 ◆主键索引◆组合索引 ◆全文索引◆外键 (只有innodb存储引擎才支持)
2.1普通索引:
这是最基本的索引,它没有任何限制 。有以下几种创建方式:
有以下几种创建方式:
◆创建索引
CREATE INDEX indexName ON tablename(username(length));
◆修改表结构
ALTER tablenameADD INDEX indexName (username(length))
Tip:length可以小于字段实际长度;如果是BLOB 和 TEXT 类型,必须指定length ,下同
◆创建表的时候直接指定
CREATE TABLE mytableuuu(ID INT NOT NULL, username VARCHAR(16) NOT NULL,INDEX indexName (username(length)));
CREATE TABLE mytable(id INT NOT NULL,username VARCHAR(16) NOT NULL);
create index index1 on mytable(id);//创建普通索引
◆删掉索引:
drop index index1 on mytable;
有一个概念,
行定义:在声明字段(列)的时候定义的,比如primary key
表定义:在所有字段(列)声明完之后定义的 , 比如primary key,index
CREATE TABLE mytable(id INT NOT NULL,username VARCHAR(16) NOT NULL,index index1(username));
3.0唯一索引(unique)
索引列的值必须唯一 , 但允许有空值 。
1)创建索引:Create UNIQUE INDEX indexName ON tableName(tableColumns(length))
2)修改表结构:Alter tableName ADD UNIQUE [indexName] ON (tableColumns(length)
3)创建表的时候直接指定:Create TABLE tableName ( [...], UNIQUE [indexName](tableColumns(length));
4.0主键索引(primarykey)
mysql如何建立索引我们可以通过查看索引的属性来判断创建索引的方法 。
查看索引的语法格式如下:
SHOW INDEX FROM 表名 [ FROM 数据库名]
语法说明如下:
表名:指定需要查看索引的数据表名 。
数据库名:指定需要查看索引的数据表所在的数据库,可省略 。比如,SHOW INDEX FROM student FROM test; 语句表示查看 test 数据库中 student 数据表的索引 。
示例
使用 SHOW INDEX 语句查看《MySQL创建索引》一节中 tb_stu_info2 数据表的索引信息,SQL 语句和运行结果如下所示 。
mysql SHOW INDEX FROM tb_stu_info2\G
1. row
Table: tb_stu_info2
Non_unique: 0
Key_name: height
Seq_in_index: 1
Column_name: height
Collation: A
Cardinality: 0
Sub_part: NULL
Packed: NULL
Null: YES
Index_type: BTREE
Comment:
Index_comment:
1 row in set (0.03 sec)
其中各主要参数说明如下:
参数 说明
Table 表示创建索引的数据表名,这里是 tb_stu_info2 数据表 。
Non_unique 表示该索引是否是唯一索引 。若不是唯一索引,则该列的值为 1;若是唯一索引,则该列的值为 0 。
Key_name 表示索引的名称 。
Seq_in_index 表示该列在索引中的位置,如果索引是单列的,则该列的值为 1;如果索引是组合索引,则该列的值为每列在索引定义中的顺序 。
Column_name 表示定义索引的列字段 。
Collation 表示列以何种顺序存储在索引中 。在 MySQL 中,升序显示值“A”(升序) , 若显示为 NULL,则表示无分类 。
Cardinality 索引中唯一值数目的估计值 。基数根据被存储为整数的统计数据计数,所以即使对于小型表,该值也没有必要是精确的 。基数越大 , 当进行联合时,MySQL 使用该索引的机会就越大 。
Sub_part 表示列中被编入索引的字符的数量 。若列只是部分被编入索引,则该列的值为被编入索引的字符的数目;若整列被编入索引 , 则该列的值为 NULL 。
Packed 指示关键字如何被压缩 。若没有被压缩,值为 NULL 。
Null 用于显示索引列中是否包含 NULL 。若列含有 NULL , 该列的值为 YES 。若没有 , 则该列的值为 NO 。
Index_type 显示索引使用的类型和方法(BTREE、FULLTEXT、HASH、RTREE) 。
Comment 显示评注 。
mysql数据库怎么创建索引普通索引添加INDEX
ALTER TABLE `table_name` ADD INDEX index_name ( `column` )
下面演示下给user表mysql读库怎么建索引的name字段添加一个索引
mysql数据库如何创建索引
mysql数据库如何创建索引
主键索引添加PRIMARY KEY
ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` )
mysql数据库如何创建索引
mysql数据库如何创建索引
唯一索引添加UNIQUE
ALTER TABLE `table_name` ADD UNIQUE ( `column` )
mysql数据库如何创建索引
全文索引添加FULLTEXT
ALTER TABLE `table_name` ADD FULLTEXT ( `column`)
mysql数据库如何创建索引
如何添加多列索引
ALTER TABLE `table_name` ADD INDEX index_name ( `column1`, `column2`, `column3` )
mysql数据库如何创建索引
Mysql建立索引经验在实际开发中使用数据库时mysql读库怎么建索引,难免会遇到一些大表数据mysql读库怎么建索引,对这些数据进行查询时 , 有时候SQL会查询得特别慢,这时候,有经验的老师傅会告诉mysql读库怎么建索引你,mysql读库怎么建索引你看一下哪几个字段查的多,加一个索引就好mysql读库怎么建索引了 。
那么,怎么合理地建立索引呢?这里分享一下我的一些经验,如有不妥之处,欢迎批评指正 。
1、不要盲目建立索引,先分析再创建
索引虽然能大幅度提升我们的查询性能 , 但也要知道,在你进行增删改时,索引树也要同样地进行维护 。所以,索引不是越多越好,而是按需建立 。最好是在一整块模块开发完成后 , 分析一下,去针对大多数的查询,建立联合索引 。
2、使用联合索引尽量覆盖多的条件
这是说在一个慢sql里假如有五个where , 一个 order by,那么我们的联合索引尽量覆盖到这五个查询条件,如果有必要,order by 也覆盖上。
3、小基数字段不需要索引
这个意思是,如果一张表里某个字段的值只有那么几个,那么你针对这个字段建立的索引其实没什么意义,比如说,一个性别字段就两种结果,你建了索引,排序也没什么意思(也就是索引里把男女给分开了)
所以说,索引尽量选择基数大的数据去建立,能最大化地利用索引
4、长字符串可以使用前缀索引
我们建立索引的字段尽量选择字段类型较小的,比如一个varchar(20)和varchar(256)的,我们在20的上面建立的索引和在256上就有明显的差距(字符串那么长排序也不好排呀,唉) 。
当然,如果一定是要对varchar(256)建立索引,我们可以选择里面的前20个字符放在索引树里(这里的20不绝对,选择能尽量分辨数据的最小字符字段设计) , 类似这样KEY index(name(20),age,job),索引只会对name的前20个字符进行搜索,但前缀索引无法适用于order by 和 group by 。
5、对排序字段设计索引的优先级低
如果一个SQL里我们出现了范围查找,后边又跟着一个排序字段,那么我们优先给范围查找的字段设置索引,而不是优先排序 。
6、如果出现慢SQL,可以设计一个只针对该条SQL的联合索引 。
不过慢SQL的优化,需要一步步去进行分析,可以先用explain查看SQL语句的分析结果,再针对结果去做相应的改进 。explain的东西我们下次再讲 。
PS:在 select 语句之前增加 explain 关键字 , MySQL 会在查询上设置一个标记,执行查询会返回执行计划的信息,而不是 执行这条SQL 。
mysql创建索引的三种办法一、CREATE INDEX方法
CREATE INDEX 索引名 ON 表名 (列名 [长度] [ ASC | DESC])
限制mysql读库怎么建索引:只能增加普通索引INDEX和UNIQUE INDEX索引这两种mysql读库怎么建索引;不能创建PRIMARY KEY索引
二、ALTER TABLE方法
ALTER TABLE 表名 ADD INDEX [索引名] (列名,…)
ALTER TABLE 表名 ADD UNIQUE [ INDEX | KEY] [索引名] (列名,…)
ALTER TABLE 表名 ADD PRIMARY KEY (列名,…)
ALTER TABLE 表名 ADD FOREIGN KEY [索引名] (列名,…)
三、CREATE TABLE时候指定
创建一般索引
CREATE TABLE tb_stu_info
(
id INT NOT NULL,
name CHAR(45) DEFAULT NULL,
dept_id INT DEFAULT NULL,
age INT DEFAULT NULL,
height INT DEFAULT NULL,
INDEX(height)
);
创建唯一索引
mysql CREATE TABLE tb_stu_info2
(
id INT NOT NULL,
name CHAR(45) DEFAULT NULL,
dept_id INT DEFAULT NULL,
age INT DEFAULT NULL,
height INT DEFAULT NULL,
UNIQUE INDEX(height)
);
创建主键(虽然ALTER TABLE也能创建mysql读库怎么建索引,但主键一般都在创表时建立)
CREATE TABLE mytable(
ID INT NOT NULL,
username VARCHAR(16) NOT NULL,
PRIMARY KEY(ID)
);
【mysql读库怎么建索引 mysql如何创建索引sql语句】关于mysql读库怎么建索引和mysql如何创建索引sql语句的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息 , 记得收藏关注本站 。

    推荐阅读