MySQL视图、用户管理

目录

一、视图

二、用户管理

2.1、用户

1、用户信息

2、创建用户

3、删除用户

4、修改用户密码

2.2、数据库的权限


一、视图

视图就是由基表导出的一张表 和普通的表一样

修改视图也会影响到基表 同样地 修改基表也会影响到视图

创建视图:create view 视图名 as select语句;

示例:

修改视图 基表记录也会发生相应改变:

修改基表 视图也会发生相应变化:

删除视图 :drop view 视图名;

视图的规则和限制:

  • 必须唯一命名
  • 创建视图没有数量限制 但是要考虑之后复杂查询的性能影响
  • 视图不能添加索引 也不能有关联的触发器和默认值
  • 视图可以提高安全性 必须要有足够的访问权限
  • order by可以用在视图中 但是若是在视图中的select中也含有order by 那么该视图中的order by会被覆盖

二、用户管理

若是只是用root用户 会出现安全问题 所以具备需要创建普通用户的功能 因为root用户无视权限 而可以给创建的普通用户限制权限 从而保证安全性

2.1、用户

1、用户信息

mysql中的用户信息都存放在MySQL系统数据库的user表中 可以查看一下

host表示可以从那个主机登录 若是localhost表示只能本机登录 若是%表示任何主机都能登录

user表示用户名称

authentication_string表示用户加密之后的密码

2、创建用户

create user ' 用户名 ' @ ' 登陆主机 /ip' identified by ' 密码 ' ; 若是@后面接上'%'则表示从任何主机都能登上这个用户的mysql 一般来说为了安全是不会这样设置的
例子:
创建一个只允许本地登录的用户并且设置密码为123456 之后查看user表中的host user 以及加密之后的密码记录 然后新开一个终端 以zhangsan登录mysql
create user 'zhangsan'@'localhost' identified by '123456';


新建终端并且输入密码登录zhangsan用户下的mysql

3、删除用户

drop user ' 用户名 ' @ ' 主机名 '

4、修改用户密码

自己该自己的密码:ALTER USER USER() IDENTIFIED BY '新密码';或者SET PASSWORD = '...密码';

root下修改某个用户的密码:ALTER USER '用户名'@'主机名' IDENTIFIED BY '密码';

zhangsan登陆下的mysql

root下的mysql 发现密码改变

2.2、数据库的权限

刚刚创建的用户没有任何权限 需要我们手动授予权限

在root权限下创建一个数据库user并且在里面创建一个表id_name 会发现在zhangsan下的mysql看不这个数据库这是因为权限不够

授予权限语法以及注意点
grant 权限列表 on 库 . 对象名 to ' 用户名 ' @ ' 登陆位置 ' [identified by ' 密码 ' ] 表示将库下表的某些全选授予用户 在这里可以设置密码 一般在创建用户的时候就设置好
每次授予权限之后要 flush privileges 让授予的权限立即生效
可以一次性授予全部权限 也可以授予部分权限
grant select on ...
grant select , delete , create on ....
grant all [privileges] on ... -- 表示赋予该用户在该对象上的所有权限
查看用户的权限 :show grants for '用户名'@'主机名'

例:

给zhangsan授予user库下id_name 的全部权限

root下

查看zhangsan的权限 发现全部都有

zhangsan

插入或者删除记录试试

回收权限:revoke 权限列表 on 库.对象名 from '用户名'@'登陆位置';

在root下回收zhangsan的修改权限并且查看zhangsan的剩余权限 之后在zhangsan下尝试修改记录 发现不可行

相关推荐
weelinking20 小时前
【产品】00_产品经理用Claude实现产品系列介绍
数据库·人工智能·sql·数据挖掘·github·产品经理
2301_8039346121 小时前
Go语言如何做网络爬虫_Go语言爬虫开发教程【指南】
jvm·数据库·python
秋921 小时前
windows中安装redis
数据库·redis·缓存
Cosolar1 天前
万字详解:RAG 向量索引算法与向量数据库架构及实战
数据库·人工智能·算法·数据库架构·milvus
想唱rap1 天前
IO多路转接之poll
服务器·开发语言·数据库·c++
小江的记录本1 天前
【Java基础】泛型:泛型擦除、通配符、上下界限定(附《思维导图》+《面试高频考点清单》)
java·数据结构·后端·mysql·spring·面试·职场和发展
SeaTunnel1 天前
AI 让 SeaTunnel 读源码和调试过时了吗?
大数据·数据库·人工智能·apache·seatunnel·数据同步
凯瑟琳.奥古斯特1 天前
数据冗余与规范化的本质[数据库原理]
开发语言·数据库·职场和发展
_ku_ku_1 天前
数据库系统原理 · SQL 数据定义、更新及数据库编程 · 自学总结
数据库·oracle
Mortalbreeze1 天前
深度理解文件系统 ---- 从磁盘存储到内核存储
大数据·linux·数据库