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下尝试修改记录 发现不可行

相关推荐
NineData12 小时前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
赵渝强老师15 小时前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
全栈老石19 小时前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
倔强的石头_2 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou643 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北3 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤4 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12025 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区5 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1775 天前
《从零搭建NestJS项目》
数据库·typescript