时间:2021-07-01 10:21:17 帮助过:25人阅读
or
create table in1(
nid int not null auto_increment ,
name varchar(32) not null,
email varchar(64) not null,
primary key(nid)
)
2.table创建好后添加(必须符合索引条件)
alter table table_name add primary key(nid);
删除主键
alter table 表名 drop primary key;
alter table 表名 modify 列名 int, drop primary key;
组合索引
组合索引又叫联合(普通,唯一)索引。其实就是创建索引时变为多列。
功能:加速查找
条件:根据创建形式
创建方法:
1.创建table时创建
create table in1(
nid int not null auto_increment primary key,
name varchar(32) not null,
email varchar(64) not null,
extra text,
unique ix_name (name,nid) ) # 联合唯一索引,也别的是两列的唯一指的是合起来的唯一。
(“ccc”,3)和(“ccc”,4)可以存在。
其中ix_name 为索引的名字
2.table创建好后添加(必须符合索引条件)
create unique index index_name on table_name(column_name);
注意:
组合索引遵循最左匹配。即(nid,name,addr)在这个组合索引中,若是有
select * from table_name where name = "fff" and addr = "seatle"
这样的语句中不会走索引。而nid和 addr会走索引。
删除办法 (除主键)
drop index_name on table_name;
查看查询
show index from table_name;
注意
列的类型为 blob和text时必须指定长度。两者太长没必要。
create index ix_extra on in1(extra(32));
=====================分割(都是概念)=======================
覆盖索引
覆盖索引时一种概念,指的是在索引时没有进行第二步在数据表中取数据,直接在索引表中取到了。
如 select nid from table_name where nid >10;
由于nid就是主键或者索引,并且取的数据都是索引的值。那程序只要将B-tree的值转化成数据就成。没有第二步步骤。
索引合并
索引合并是在索引过程中,运用到了两列以上作为条件限制。区别于组合索引。
select * from table_name where nid = 23 and name = "ccc";
nid是主键,name是普通索引。这样的索引形式成为索引合并。
那么组合的仍有最左前缀的限制,为什么还存在组合索引?
因为,有种情况是组合索引的最左是根。比如用户名和密码,没有人会脱离用户名去索引密码。
并且,组合索引在这种索引多列的情况下优于索引合并的速率
其他
条件语句
delimiter \
CREATE PROCEDURE proc_if ()
BEGIN
declare i int default 0;
if i = 1 THEN SELECT 1;
ELSEIF i = 2 THEN SELECT 2;
ELSE SELECT 7;
END IF;
END\
delimiter ;
循环语句
动态执行SQL语句
# 将传送过来的数据输入某些sql语句中。
动态执行SQLmysql重点--索引
标签:表名 prim 取数 数据 联合 primary 过程 alt 匹配