索引
1 索引的分类
在一个表中,主键索引只能有一个,唯一索引可以有多个
- 主键索引(primary key)
- 唯一的表,主键不可重复,只能有一个列作为主键
- 唯一索引(unique key)
- 避免重复的列出现,唯一索引可以重复,多个列都可以标识为唯一索引
- 常规索引(key/index)
- 默认的,index,key关键字来设置
- 全文索引(fulltext)
- 在特定的数据库引擎下才有,myisam
- 快速定位数据
2 基础语法
-- 索引的引用
-- 1.在创建表的时候给字段增加索引
-- 2.创建完毕后,增加索引
-- 显示所有的索引信息
show index from student
-- 增加一个全文索引(索引名) 列名
alter table school.student add fulltext index `studentName`(`studentName`);
-- explain 分析sql执行的状况
explain select * from student;-- 非全文索引
explain select * from student where match(studentName) avginst('刘');
3 索引原则
- 索引不是越多越好
- 不要对进程变动数据加索引
- 小数据量的表不需要加索引
- 索引一般加在常用来查询的字段上
4 索引的数据结构
-
我们可以在创建上述索引的时候,为其指定索引类型,分两类
-
hash类型的索引:查询单条快,范围查询慢
-
btree类型的索引:b+树,层数越多,数据量指数级增长(我们就用它,因为innodb默认支持它)
-
-
不同的存储引擎支持的索引类型也不一样
-
InnoDB 支持事务,支持行级别锁定,支持 B-tree、Full-text 等索引,不支持 Hash 索引;
-
MyISAM 不支持事务,支持表级别锁定,支持 B-tree、Full-text 等索引,不支持 Hash 索引;
-
Memory 不支持事务,支持表级别锁定,支持 B-tree、Hash 等索引,不支持 Full-text 索引;
-
NDB 支持事务,支持行级别锁定,支持 Hash 索引,不支持 B-tree、Full-text 等索引;
-
Archive 不支持事务,支持表级别锁定,不支持 B-tree、Hash、Full-text 等索引;
-
权限
1 创建用户

2 权限用法
-- 创建用户 create user 用户名 identified by '密码'
create user wuming identified by '147258'
-- 修改密码 (当前用户)
set password = password('123456')
-- 修改密码 (指定用户)
set password for wuming = password('123456')
-- 重命名 rename user 原来的名字 to 新的名字
rename user wuming to wuming2
-- 用户授权 all privileges 全部的权限
-- all privileges 除了给别人授权,其它的都能干
grant all privileges on *.* wuming2
-- 查询权限
show grants for wuming2
show grants for root@localhost
-- 撤销权限 revoke 那些权限,在哪个库撤销,给谁撤销
revoke all privileges on *.* from wuming
-- 删除用户
drop user wuming

10万+

被折叠的 条评论
为什么被折叠?



