数据库基?。航步釳ySQL索引的概念及数据库索引的应用[2] 五 索引分类
直接创建索引和间接创建索引
直接创建索引 CREATE INDEX mycolumn_index ON mytable (myclumn)
间接创建索引 定义主键约束或者唯一性键约束 可以间接创建索引
普通索引和唯一性索引
普通索引 CREATE INDEX mycolumn_index ON mytable (myclumn)
【mysql创建索引怎么用 mysql中创建索引】 唯一性索引 保证在索引列中的全部数据是唯一的 对聚簇索引和非聚簇索引都可以使用
CREATE UNIQUE COUSTERED INDEX myclumn_cindex ON mytable(mycolumn)
单个索引和复合索引
单个索引 即非复合索引
复合索引 又叫组合索引 在索引建立语句中同时包含多个字段名 最多 个字段
CREATE INDEX name_index ON username(firstname lastname)
聚簇索引和非聚簇索引(聚集索引 群集索引)
聚簇索引 物理索引 与基表的物理顺序相同 数据值的顺序总是按照顺序排列
CREATE CLUSTERED INDEX mycolumn_cindex ON mytable(mycolumn) WITH
ALLOW_DUP_ROW(允许有重复记录的聚簇索引)
非聚簇索引 CREATE UNCLUSTERED INDEX mycolumn_cindex ON mytable(mycolumn)
六 索引的使用
当字段数据更新频率较低 查询使用频率较高并且存在大量重复值是建议使用聚簇索引
经常同时存取多列 且每列都含有重复值可考虑建立组合索引
复合索引的前导列一定好控制好 否则无法起到索引的效果 如果查询时前导列不在查询条件中则该复合索引不会被使用 前导列一定是使用最频繁的列
多表操作在被实际执行前 查询优化器会根据连接条件 列出几组可能的连接方案并从中找出系统开销最小的最佳方案 连接条件要充份考虑带有索引的表 行数多的表;内外表的选择可由公式 外层表中的匹配行数*内层表中每一次查找的次数确定 乘积最小为最佳方案
where子句中对列的任何操作结果都是在sql运行时逐列计算得到的 因此它不得不进行表搜索 而没有使用该列上面的索引;如果这些结果在查询编译时就能得到 那么就可以被sql优化器优化 使用索引 避免表搜索(例 select * from record where substring(card_no )=
select * from record where card_no like % )任何对列的操作都将导致表扫描 它包括数据库函数 计算表达式等等 查询时要尽可能将操作移至等号右边
where条件中的 in 在逻辑上相当于 or 所以语法分析器会将in ( ′ ′)转化为column= ′ or column= ′来执行 我们期望它会根据每个or子句分别查找 再将结果相加 这样可以利用column上的索引;但实际上它却采用了 or策略 即先取出满足每个or子句的行 存入临时数据库的工作表中 再建立唯一索引以去掉重复行 最后从这个临时表中计算结果 因此 实际过程没有利用column上索引 并且完成时间还要受tempdb数据库性能的影响 in or子句常会使用工作表 使索引失效;如果不产生大量重复值 可以考虑把子句拆开;拆开的子句中应该包含索引
要善于使用存储过程 它使sql变得更加灵活和高效
lishixinzhi/Article/program/MySQL/201311/29603
「进阶」MySQL中如何使用索引1、普通索引
这是最基本的索引 , 它没有任何限制 。
2、唯一索引
它与前面的普通索引类似,不同的就是:索引列的值必须唯一 , 但允许有空值 。如果是组合索引 , 则列值的组合必须唯一 。
3、主键索引
它是一种特殊的唯一索引,不允许有空值 。一般是在建表的时候同时创建主键索引 。
4、聚簇索引
聚簇索引的索引顺序就是数据存储的物理存储顺序,这样能保证索引值相近的元组所存储的物理位置也相近 。
5、全文索引(FULLTEXT)
全文索引只能创建在数据类型为VARCHAR或TEXT的列上,建立全文索引后,能够在建立了全文索引的列上进行全文查找 。全文索引只能在MyISAM存储引擎的表中创建 。
实际工作使用中,索引可以建立在单一列上,称为单列索引,也可以建立在多个列上,称为组合索引 。
mysql索引的创建和使用我们可以通过查看索引的属性来判断创建索引的方法 。
查看索引的语法格式如下:
SHOW INDEX FROM 表名 [ FROM 数据库名]
语法说明如下:
表名:指定需要查看索引的数据表名 。
数据库名:指定需要查看索引的数据表所在的数据库mysql创建索引怎么用,可省略 。比如mysql创建索引怎么用,SHOW INDEX FROM student FROM test; 语句表示查看 test 数据库中 student 数据表的索引 。
示例
使用 SHOW INDEX 语句查看《MySQL创建索引》一节中 tb_stu_info2 数据表的索引信息mysql创建索引怎么用,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创建索引怎么用的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于mysql中创建索引、mysql创建索引怎么用的信息别忘了在本站进行查找喔 。
推荐阅读
- 直播设备调试课程设计,直播调试设备的步骤
- 横版日本风格斗游戏大全,横版格斗的游戏
- 铭瑄显卡维修怎么查询进度,铭瑄显卡维修怎么查询进度信息
- python内置函数元组 python 元组函数
- 包含jqueryfnupdate的词条
- 幼儿篮球体育游戏大全,幼儿篮球小游戏大全
- 办公楼毕业设计计算书模版,办公建筑设计毕业设计作品
- C语言图书查询函数 c语言查询函数怎么写
- 为什么qq小视频打不开,为什么小视频打不开了