MySQL相关概念和易错知识点(6)(视图、用户管理)
目录
- 1.视图
- a.视图的理解和使用
- b.视图的使用规范
- 2.用户管理
- a.用户信息
- b.用户信息管理
- c.用户权限列表
- d.查看和刷新权限
- e.给用户授权
- f.回收用户权限
1.视图
a.视图的理解和使用
我们初次接触时,可以将建立视图理解成C++中赋值兼容转换,其中视图就是那个父类,子类就是张完整的表。可以说视图(父类)引用了部分表(子类)的内容,我们修改这个视图也能修改这张表,修改表也能同时修改视图。
因此,可以说视图就是一张虚拟表,其内容是所引用的表的子集。记得select吗?查找的结果就是一张表,我们就可以将这张查询的结果表定义为视图。同真实的表一样,视图包含列和行,视图的数据变化会影响到基表,基表的数据变化也会影响到视图。
-- 创建视图
create view view_name as select * from tb; # 之后show tables;也能像其他表那样显示,没有区别
-- 对视图进行CURD的操作和普通表一模一样
update view_name set name='小白' where name='小红';
-- 删除视图
drop view view_name;
b.视图的使用规范
1.视图名也不能和表名和其他视图名冲突
2.创建视图的数量无限制,并且复杂查询(包含内置函数等)的结果也能用做视图,但过多视图会对CURD的性能产生影响
3.视图不能添加索引,也不能有关联的触发器或者默认值
4.视图可以提高安全性,必须具有足够的访问权限
5.order by可以用在视图中(原则上不建议使用),但是如果从该视图中检索数据,即select中也含有order by,那么该视图中的 order by将被覆盖,以外侧select为准
6.视图可以和表一起使用
2.用户管理
a.用户信息
-- 查看用户信息
use mysql;
select host, user, authentication_string from user;
其中我们只需要关心host, user, authentication_string这三个字段:
1.host:表示这个用户可以从哪个主机登陆,如果是localhost,表示只能从本机登陆;如果是%,表示用户既可以本地登陆也可以远程登录
2.user:用户名,我们之前登陆的用户名就是root
3.authentication_string:用户密码,显示的密码都是通过password函数加密后的
b.用户信息管理
-- 增加用户
create user 'SGlow'@'localhost' identified by '12345678'; # 包含上述的三条信息
-- 删除用户
drop user 'SGlow'@'localhost';
-- 修改指定用户密码
alter user 'SGlow'@'localhost' identified by '123456789';
c.用户权限列表
权限 | 列 | 上下文 |
---|---|---|
create | Create_priv | 数据库、表或索引 |
drop | Drop_priv | 数据库或表 |
grant option | Grant_priv | 数据库、表或保存的程序 |
references | References_priv | 数据库或表 |
alter | Alter_priv | 表 |
delete | Delete_priv | 表 |
index | Index_priv | 表 |
insert | Insert_priv | 表 |
select | Select_priv | 表 |
update | Update_priv | 表 |
create view | Create_view_priv | 视图 |
show view | Show_view_priv | 视图 |
alter routine | Alter_routine_priv | 保存的程序 |
create routine | Create_routine_priv | 保存的程序 |
execute | Execute_priv | 保存的程序 |
file | File_priv | 服务器主机上的文件访问 |
create temporary tables | Create_tmp_table_priv | 服务器管理 |
lock tables | Lock_tables_priv | 服务器管理 |
create user | Create_user_priv | 服务器管理 |
process | Process_priv | 服务器管理 |
reload | Reload_priv | 服务器管理 |
replication client | Repl_client_priv | 服务器管理 |
replication slave | Repl_slave_priv | 服务器管理 |
show databases | Show_db_priv | 服务器管理 |
shutdown | Shutdown_priv | 服务器管理 |
super | Super_priv | 服务器管理 |
d.查看和刷新权限
-- 查看用户当前已有权限
show grants for 'SGlow'@'localhost';
-- 刷新权限,如果权限修改没有生效时
flush privileges;
e.给用户授权
-- 授予该用户所有数据库及其所有对象单个权限
grant select on *.* to 'SGlow'@'localhost'; # 前一个*代表数据库,后一个*代表数据库内的表
-- 授予该用户指定数据库下的所有对象多个权限
grant select, delete, create on db.* to 'SGlow'@'localhost';
-- 授予该用户在指定对象上的所有权限
grant all on db.tb to 'SGlow'@'localhost';
f.回收用户权限
回收用户权限和授权格式几乎一样,这里仅做一个示例
revoke all on db.* from 'SGlow'@'localhost';