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

相关推荐
计算机安禾18 小时前
【数据库系统原理】第19篇:计算机存储层次结构与数据库文件的物理组织
数据库·oracle
JAVA面经实录91719 小时前
操作系统面试题
java·服务器·数据库·计算机网络·面试
摇滚侠19 小时前
mariadb-libs 被 mysql-community-libs-5.7.28-1.el7.x86_64 取代
数据库·mysql·mariadb
DIY源码阁20 小时前
JavaSwing饮品管理系统 - MySQL版
java·数据库·mysql·eclipse
专注搞钱20 小时前
GPT-4o写设备Recipe:从3小时到10分钟
数据库·人工智能·gpt·半导体
东风破13721 小时前
达梦数据库实战:备份恢复与数据迁移全攻略(实例初始化、服务注册、路径迁移)
数据库·chrome
SelectDB技术团队21 小时前
2026 SelectDB AI 产品发布会:Agent Native 数据基础设施能力全景发布
数据库·人工智能·agent·apache doris·selectdb
爱吃羊的老虎21 小时前
【数据库】模块一:数据库基础与关系代数
数据库
dishugj1 天前
iSCSI + Multipath + ASM:Oracle RAC 共享存储技术链详解
数据库·oracle
yoothey1 天前
MySQL事务机制解析 - 面试高分知识点
数据库·mysql·面试