当前位置: 首页 > news >正文

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.用户权限列表

权限上下文
createCreate_priv数据库、表或索引
dropDrop_priv数据库或表
grant optionGrant_priv数据库、表或保存的程序
referencesReferences_priv数据库或表
alterAlter_priv
deleteDelete_priv
indexIndex_priv
insertInsert_priv
selectSelect_priv
updateUpdate_priv
create viewCreate_view_priv视图
show viewShow_view_priv视图
alter routineAlter_routine_priv保存的程序
create routineCreate_routine_priv保存的程序
executeExecute_priv保存的程序
fileFile_priv服务器主机上的文件访问
create temporary tablesCreate_tmp_table_priv服务器管理
lock tablesLock_tables_priv服务器管理
create userCreate_user_priv服务器管理
processProcess_priv服务器管理
reloadReload_priv服务器管理
replication clientRepl_client_priv服务器管理
replication slaveRepl_slave_priv服务器管理
show databasesShow_db_priv服务器管理
shutdownShutdown_priv服务器管理
superSuper_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';
http://www.dtcms.com/a/328952.html

相关文章:

  • Java 大视界 -- 基于 Java 的大数据可视化在能源互联网全景展示与能源调度决策支持中的应用
  • 深度学习与遥感入门(七)|CNN vs CNN+形态学属性(MP):特征工程到底值不值?
  • 一键自动化:Kickstart无人值守安装指南
  • 【unitrix数间混合计算】2.20 比较计算(cmp.rs)
  • Spring Boot (v3.2.12) + application.yml + jasypt 数据源加密连接设置实例
  • 25个自动化办公脚本合集(覆盖人工智能、数据处理、文档管理、图片处理、文件操作等)
  • 【电气】NPN与PNP
  • [C语言]第二章-从Hello World到头文件
  • 四分位数与箱线图
  • Redis持久化机制详解:RDB与AOF的全面对比与实践指南
  • 动静态库
  • FPGA的PS基础1
  • 【FPGA】初始Verilog HDL
  • c++编程题-笔记
  • kali linux 2025.2安装Matlab的详细教程
  • 通过限制网络访问来降低服务器被攻击风险的方法
  • 服务器如何应对SYN Flood攻击?
  • FluxApi - 使用Spring进行调用Flux接口
  • Gradle(三)创建一个 SpringBoot 项目
  • 深度学习(3):全连接神经网络构建
  • mysql的快照读与当前读的区别
  • 11G RAC数据文件创建到本地如何处理
  • 【C语言强化训练16天】--从基础到进阶的蜕变之旅:Day3
  • 《算法导论》第 22 章 - 基本的图算法
  • [AXI5]AXI协议中的Scalar atomic和Vector atomic有什么区别?
  • 【算法】位运算经典例题
  • BM25:概率检索框架下的经典相关性评分算法
  • ADB 无线调试连接(Windows + WSL 环境)
  • 如何在VS里使用MySQL提供的mysql Connector/C++的debug版本
  • C++ 优选算法 力扣 209.长度最小的子数组 滑动窗口 (同向双指针)优化 每日一题 详细题解