MySQL 安全机制全面解析
在如今的数字化时代,数据库安全 变得越来越重要。为了防止对数据库进行非法操作,MySQL 定义了一套完整的安全机制,包括用户管理、权限管理 和 角色管理。本文将为你深入浅出地介绍这三大安全机制,帮助你轻松掌握MySQL的安全管理。
7.3.1 用户管理:从创建到删除,全面掌握用户管理
用户管理 是MySQL安全机制的基础,涉及到用户的创建、修改、删除等操作。每个MySQL用户账号由用户名 和 主机名 组成,表示形式为 USER@HOST,如 root@localhost。
1. 查询用户
在MySQL中,所有用户账号及相关信息都存储在 mysql 数据库的 user 表中。你可以使用以下命令查看所有用户:
SELECT user, host FROM mysql.user;
示例结果:

主机名(Host) 可以为以下三种形式:
- localhost:表示用户只能在MySQL服务器所在的机器上登录。
- % :表示用户可以在MySQL服务器以外的其他机器上登录(默认选项)。
- 指定IP或网段:表示用户只能在指定机器或网段内的机器上登录。
2. 创建用户
使用 CREATE USER 语句可以创建新用户。示例: 创建用户 usera,主机名为 localhost,密码为 a123:
CREATE USER 'usera'@'localhost' IDENTIFIED BY 'a123';

3. 修改用户名
使用 RENAME USER 语句可以修改已有用户的用户名。示例: 将 usera 改为 userb:
RENAME USER 'usera'@'localhost' TO 'userb'@'localhost';

4. 修改用户密码
在MySQL 8.0及以上版本中,使用 ALTER USER 语句修改用户密码。示例: 将 userb 的密码修改为 b123:
ALTER USER 'userb'@'localhost' IDENTIFIED WITH mysql_native_password BY 'b123';
5. 删除用户
使用 DROP USER 语句删除不再需要的用户。示例: 删除用户 userb:
DROP USER IF EXISTS 'userb'@'localhost';
7.3.2 权限管理:精细化控制用户操作权限
权限管理 通过为用户分配权限来控制他们对数据库的操作能力。MySQL的权限分为管理权限、数据库权限、表权限 和 列权限。
常见权限类型
- 管理权限:作用于所有数据库,如创建用户、关闭数据库等。
- 数据库权限:作用于指定数据库中的所有对象,如创建和删除表的权限。
- 表权限:作用于指定表,如对表进行增、删、改、查的权限。
- 列权限:作用于指定表的指定列,如更新某一列的权限。
示例: 授予 usera 在所有数据库中创建表的权限:
GRANT CREATE ON *.* TO 'usera'@'localhost';

授予权限
使用 GRANT 语句授予用户权限。示例: 授予 usera 在 Teach 数据库中查询 Student 表的权限,并允许将此权限转授给他人:
GRANT SELECT ON Teach.Student TO 'usera'@'localhost' WITH GRANT OPTION;

回收权限
使用 REVOKE 语句回收用户的权限。示例: 回收 usera 查询 Teach 数据库中 Student 表的权限:
REVOKE SELECT ON Teach.Student FROM 'usera'@'localhost';

注意: MySQL中的权限不能级联回收,即用户A将权限授予用户B,用户B又将此权限授予用户C。当用户A回收B的权限时,用户C的权限不会自动被回收。
7.3.3 角色管理:简化权限管理的利器
角色管理 是MySQL中简化权限管理的工具。角色是一组与数据库操作相关的权限,当将角色授予用户时,相当于为用户授予了多个权限,极大地简化了权限管理。
1. 创建角色
使用 CREATE ROLE 语句创建新角色。示例: 创建两个角色 rstudent 和 rteacher:
CREATE ROLE 'rstudent', 'rteacher';
2. 为角色授权
使用 GRANT 语句为角色授权。示例: 授予 rstudent 查询 Teach 数据库中所有表的权限,授予 rteacher 查询并更新 Teach 数据库中所有表的权限:
GRANT SELECT ON Teach.* TO 'rstudent';
GRANT SELECT, UPDATE ON Teach.* TO 'rteacher';
3. 将角色授予用户
使用 GRANT 语句将角色授予用户。示例: 将 rstudent 授予 usera,将 rteacher 授予 userb:
GRANT 'rstudent' TO 'usera'@'localhost';
GRANT 'rteacher' TO 'userb'@'localhost';
4. 设置默认角色
使用 SET DEFAULT ROLE 语句设置用户的默认角色。示例: 设置 rstudent 为 usera 的默认角色:
SET DEFAULT ROLE 'rstudent' TO 'usera'@'localhost';
5. 启用和禁用角色
使用 SET ROLE 语句启用或禁用角色。示例: 启用 usera 的 rstudent 角色:
SET ROLE 'rstudent';
6. 回收角色权限
使用 REVOKE 语句回收角色的权限。示例: 回收 rstudent 查询 Teach 数据库中所有表的权限:
REVOKE SELECT ON Teach.* FROM 'rstudent';
7. 撤销角色
使用 REVOKE 语句撤销用户的角色。示例: 撤销 usera 的 rstudent 角色:
REVOKE 'rstudent' FROM 'usera'@'localhost';
8. 删除角色
使用 DROP ROLE 语句删除不再需要的角色。示例: 删除 rstudent 和 rteacher 角色:
DROP ROLE 'rstudent', 'rteacher';
总结:全面掌握MySQL安全机制
通过本文的讲解,你应该对MySQL的安全机制 有了更深入的理解。用户管理、权限管理 和 角色管理 共同构成了MySQL的安全防线,帮助你有效地管理和保护数据库。
相关文章:
MySQL 安全机制全面解析
在如今的数字化时代,数据库安全 变得越来越重要。为了防止对数据库进行非法操作,MySQL 定义了一套完整的安全机制,包括用户管理、权限管理 和 角色管理。本文将为你深入浅出地介绍这三大安全机制,帮助你轻松掌握MySQL的安全管…...
vue原理分析(十四)研究new Vue()中的 initProvide
在Vue.prototype._init 中有一些init函数,今天我们来研究这些init函数 Vue.prototype._init function (options) {......{initProxy(vm);}......initLifecycle(vm);initEvents(vm);initRender(vm);callHook$1(vm, beforeCreate, undefined, false /* setContext *…...
Qt控制开发板的LED
Qt控制开发板的LED 使用开发板的IO接口进行控制是嵌入式中非常重要的一点,就像冯诺依曼原理说的一样,一个计算机最起码要有输入输出吧,我们有了信息的接收和处理,那我们就要有输出。 我们在开发板上一般都是使用开发板的GPIO接口…...
S3C2440开发板点亮LED灯+PWM定时器
目录 GPIO引脚和寄存器概述 点亮LED灯步骤 1.配置GPIO 2.点亮LED 设置引脚为输出 控制引脚电平 完整代码 PWM GPIO引脚和寄存器概述 GPIO端口: S3C2440的GPIO引脚可被配置为输入或输出(控制LED的引脚通常配置为输出模式)。寄存器&#…...
S-Procedure的基本形式及使用
理论 Lemma 1. ( S- Procedure[ 34] ) : Define the quadratic func- \textbf{Lemma 1. ( S- Procedure[ 34] ) : Define the quadratic func- } Lemma 1. ( S- Procedure[ 34] ) : Define the quadratic func- tions w.r.t. x ∈ C M 1 \mathbf{x}\in\mathbb{C}^M\times1 x…...
free -h 查看内存free空间不足
free空间不足 大部分被buff/cache占用 解决办法一: 手动释放缓存 释放页缓存 sudo sync; sudo sysctl -w vm.drop_caches1 释放目录项和inode缓存 sudo sync; sudo sysctl -w vm.drop_caches2 释放所有缓存(页缓存、目录项和inode缓存) sudo sync…...
rust学习笔记
参考资料:https://doc.rust-lang.org/book/ch01-02-hello-world.html 一、 编译与运行 在 Rust 中,编译和运行代码的常用命令是使用 cargo,这是 Rust 的包管理和构建工具。以下是使用 cargo 和 rustc(Rust 编译器)的具…...
【有啥问啥】复习变分下界即证据下界(Evidence Lower Bound, ELBO):原理与应用
复习变分下界即证据下界(Evidence Lower Bound, ELBO):原理与应用 变分下界(Variational Lower Bound),也称为“证据下界”(Evidence Lower Bound, ELBO),是概率模型中的…...
Linux shell编程学习笔记78:cpio命令——文件和目录归档工具(上)
0 前言 在Linux系统中,除了tar命令,我们还可以使用cpio命令来进行文件和目录的归档。 1 cpio命令的功能,帮助信息,格式,选项和参数说明 1.1 cpio命令的功能 cpio 名字来自 "copy in, copy out"…...
为什么在 JSON 序列化中不使用 transient
有些小伙伴发现了,明明在返回的实体类中指定了属性为transient。为什么前端得到的返回json中还是有这个属性的值? 类: private String name; private transient String password;返回结果: { name:"刘大大", password:…...
K8S - Volume - NFS 卷的简介和使用
在之前的文章里已经介绍了 K8S 中两个简单卷类型 hostpath 和 emptydir k8s - Volume 简介和HostPath的使用 K8S - Emptydir - 取代ELK 使用fluentd 构建logging saidcar 但是这两种卷都有同1个限制, 就是依赖于 k8s nodes的空间 如果某个service pod中需要的vol…...
IO模型---BIO、NIO、IO多路复用、AIO详解
本篇将想给详细解释一下什么是BIO、NIO、IO多路复用以及AIO~ 同步的阻塞(BIO)和非阻塞(NIO)的区别 BIO:线程发来IO请求后,一直阻塞着IO线程,需要缓冲区这边数据准备好之后,才会进行下一步的操作。 举个🌰࿱…...
蓝桥杯真题——约翰的牛奶
输入样例: 8 9 10 输出样例: 1 2 8 9 10 本题是宽搜的模版题,不论怎么倒牛奶,A,B,C 桶里的牛奶可以看做一个三元点集 我们只要找到A桶是空的,B,C桶中的状态即可 #include <iostream> #include <cstring…...
单机docker-compose部署minio
单机多副本docker-compose部署minio 简单介绍 如果服务器有限可以单机挂载多硬盘实现多副本容错(生产不推荐) 部署好的文件状态 有两个重要文件 docker-compose.yaml和nginx.conf docker-compose.yaml是docker部署容器的配置信息包括4个minio和1个ng…...
Winform实现弹出定时框功能
1、程序 private void TimeDialogInitialize(){for(int i1; i<30;i){cbbTimeDialog.Items.Add(i);}}private void cbbTimeDialog_SelectedIndexChanged(object sender, EventArgs e){foreach(int i in cbbTimeDialog.Items){if(cbbTimeDialog.SelectedItem!null &&…...
【机器学习(四)】分类和回归任务-梯度提升决策树(GBDT)-Sentosa_DSML社区版
文章目录 一、算法概念一、算法原理(一) GBDT 及负梯度拟合原理(二) GBDT 回归和分类1、GBDT回归1、GBDT分类二元分类多元分类 (三)损失函数1、回归问题的损失函数2. 分类问题的损失函数: 三、G…...
Mini-Omni 语言模型在流式传输中边思考边听说应用
引入简介 Mini-Omni 是一个开源的多模态大语言模型,能够在思考的同时进行听觉和语言交流。它具有实时端到端语音输入和流媒体音频输出的对话能力。 语言模型的最新进展取得了显著突破。GPT-4o 作为一个新的里程碑,实现了与人类的实时对话,展示了接近人类的自然流畅度。为了…...
vue devtools的使用
vue devtools的使用 Vue Devtools 是一个强大的浏览器扩展,旨在帮助你调试和开发 Vue.js 应用。它支持 Chrome 和 Firefox 浏览器,并提供了一些工具和功能,可以让你更轻松地查看和调试 Vue 应用的状态和行为。以下是如何安装和使用 Vue Devtools 的详细指南。 安装 Vue De…...
无人机培训:无人机维护保养技术详解
随着无人机技术的飞速发展,其在航拍、农业、救援、环境监测等领域的应用日益广泛。然而,要确保无人机安全、高效地执行任务,定期的维护保养至关重要。本文将深入解析无人机维护保养的核心技术,涵盖基础构造理解、清洁与防尘、电机…...
Mac 创建 Python 虚拟环境
在 macOS 上,您可以使用以下步骤使用 virtualenv 创建虚拟环境: 首先,确保您已经安装了 Python 和 virtualenv。您可以在终端中运行以下命令来检查它们是否已安装: python --version virtualenv --version如果这些命令没有找到&am…...
Chapter03-Authentication vulnerabilities
文章目录 1. 身份验证简介1.1 What is authentication1.2 difference between authentication and authorization1.3 身份验证机制失效的原因1.4 身份验证机制失效的影响 2. 基于登录功能的漏洞2.1 密码爆破2.2 用户名枚举2.3 有缺陷的暴力破解防护2.3.1 如果用户登录尝试失败次…...
Ubuntu系统下交叉编译openssl
一、参考资料 OpenSSL&&libcurl库的交叉编译 - hesetone - 博客园 二、准备工作 1. 编译环境 宿主机:Ubuntu 20.04.6 LTSHost:ARM32位交叉编译器:arm-linux-gnueabihf-gcc-11.1.0 2. 设置交叉编译工具链 在交叉编译之前&#x…...
SkyWalking 10.2.0 SWCK 配置过程
SkyWalking 10.2.0 & SWCK 配置过程 skywalking oap-server & ui 使用Docker安装在K8S集群以外,K8S集群中的微服务使用initContainer按命名空间将skywalking-java-agent注入到业务容器中。 SWCK有整套的解决方案,全安装在K8S群集中。 具体可参…...
实现弹窗随键盘上移居中
实现弹窗随键盘上移的核心思路 在Android中,可以通过监听键盘的显示和隐藏事件,动态调整弹窗的位置。关键点在于获取键盘高度,并计算剩余屏幕空间以重新定位弹窗。 // 在Activity或Fragment中设置键盘监听 val rootView findViewById<V…...
【HarmonyOS 5 开发速记】如何获取用户信息(头像/昵称/手机号)
1.获取 authorizationCode: 2.利用 authorizationCode 获取 accessToken:文档中心 3.获取手机:文档中心 4.获取昵称头像:文档中心 首先创建 request 若要获取手机号,scope必填 phone,permissions 必填 …...
GitFlow 工作模式(详解)
今天再学项目的过程中遇到使用gitflow模式管理代码,因此进行学习并且发布关于gitflow的一些思考 Git与GitFlow模式 我们在写代码的时候通常会进行网上保存,无论是github还是gittee,都是一种基于git去保存代码的形式,这样保存代码…...
云原生安全实战:API网关Kong的鉴权与限流详解
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、基础概念 1. API网关(API Gateway) API网关是微服务架构中的核心组件,负责统一管理所有API的流量入口。它像一座…...
零知开源——STM32F103RBT6驱动 ICM20948 九轴传感器及 vofa + 上位机可视化教程
STM32F1 本教程使用零知标准板(STM32F103RBT6)通过I2C驱动ICM20948九轴传感器,实现姿态解算,并通过串口将数据实时发送至VOFA上位机进行3D可视化。代码基于开源库修改优化,适合嵌入式及物联网开发者。在基础驱动上新增…...
Monorepo架构: Nx Cloud 扩展能力与缓存加速
借助 Nx Cloud 实现项目协同与加速构建 1 ) 缓存工作原理分析 在了解了本地缓存和远程缓存之后,我们来探究缓存是如何工作的。以计算文件的哈希串为例,若后续运行任务时文件哈希串未变,系统会直接使用对应的输出和制品文件。 2 …...
何谓AI编程【02】AI编程官网以优雅草星云智控为例建设实践-完善顶部-建立各项子页-调整排版-优雅草卓伊凡
何谓AI编程【02】AI编程官网以优雅草星云智控为例建设实践-完善顶部-建立各项子页-调整排版-优雅草卓伊凡 背景 我们以建设星云智控官网来做AI编程实践,很多人以为AI已经强大到不需要程序员了,其实不是,AI更加需要程序员,普通人…...
