【MySQL基础-1】MySQL 用户管理指南:创建用户、修改密码与权限分配

MySQL 作为广泛使用的关系型数据库管理系统,用户管理和权限分配是其核心功能之一。合理创建用户、修改密码以及分配权限,不仅能保障数据库的安全性,还能有效控制用户的操作范围。本文将详细介绍如何在 MySQL 中创建用户、修改用户密码以及分配权限。


1. 创建用户

在 MySQL 中,创建用户主要通过 CREATE USER 语句实现。以下是创建用户的基本语法:

CREATE USER 'username'@'host' IDENTIFIED BY 'password';
  • username:要创建的用户名。
  • host:允许用户连接的主机名或 IP 地址。localhost 表示仅允许本地连接,% 表示允许任意主机连接。
  • password:用户的密码。

1.1 示例

创建一个名为 testuser 的用户,允许其从任意主机连接,并设置密码为 mypassword

sql

复制

CREATE USER 'testuser'@'%' IDENTIFIED BY 'mypassword';

2. 修改用户密码

MySQL 提供了多种修改用户密码的方式,以下是常用的两种方法:

2.1 方法 1:使用 ALTER USER 语句(推荐)

从 MySQL 5.7.6 开始,推荐使用 ALTER USER 语句修改用户密码:

ALTER USER 'username'@'host' IDENTIFIED BY 'new_password';
2.1.1 示例

testuser 用户的密码修改为 newpassword

ALTER USER 'testuser'@'%' IDENTIFIED BY 'newpassword';

2.2 方法 2:使用 SET PASSWORD 语句

在较早版本的 MySQL 中,可以使用 SET PASSWORD 语句修改密码:

SET PASSWORD FOR 'username'@'host' = PASSWORD('new_password');
2.2.1 示例

testuser 用户的密码修改为 newpassword

SET PASSWORD FOR 'testuser'@'%' = PASSWORD('newpassword');

注意PASSWORD() 函数在 MySQL 5.7.6 及以上版本中已被弃用,建议使用 ALTER USER


3. 分配权限

创建用户后,需要为其分配适当的权限。MySQL 提供了 GRANT 语句来分配权限。基本语法如下:

GRANT privileges ON database.table TO 'username'@'host';
  • privileges:要分配的权限,如 SELECTINSERTUPDATEDELETEALL PRIVILEGES 等。
  • database.table:权限作用的数据库和表。*.* 表示所有数据库和表。
  • usernamehost:要分配权限的用户和主机。

3.1 示例

testuser 用户分配对 mydatabase 数据库中所有表的 SELECTINSERT 权限:

GRANT SELECT, INSERT ON mydatabase.* TO 'testuser'@'%';

3.2 刷新权限

分配权限后,需使用 FLUSH PRIVILEGES 语句刷新权限,使更改立即生效:

FLUSH PRIVILEGES;

4. 查看用户权限

可以使用 SHOW GRANTS 语句查看用户的权限:

SHOW GRANTS FOR 'username'@'host';

4.1 示例

查看 testuser 用户的权限:

SHOW GRANTS FOR 'testuser'@'%';

5. 撤销权限

如果需要撤销用户的某些权限,可以使用 REVOKE 语句:

REVOKE privileges ON database.table FROM 'username'@'host';

5.1 示例

撤销 testuser 用户对 mydatabase 数据库的 INSERT 权限:

REVOKE INSERT ON mydatabase.* FROM 'testuser'@'%';

6. 删除用户

如果不再需要某个用户,可以使用 DROP USER 语句删除:

DROP USER 'username'@'host';

6.1 示例

删除 testuser 用户:

DROP USER 'testuser'@'%';

7. 最佳实践

  1. 最小权限原则:只授予用户完成其任务所需的最小权限,避免过度授权。
  2. 定期审查权限:定期检查用户权限,确保权限分配合理。
  3. 使用强密码:为用户设置强密码,防止密码被破解。
  4. 限制主机访问:尽量限制用户的主机访问范围,避免不必要的远程访问。
  5. 定期修改密码:建议定期修改用户密码,以增强安全性。

8. 总结

通过本文,您已经掌握了在 MySQL 中创建用户、修改用户密码、分配权限、查看权限、撤销权限以及删除用户的基本操作。合理管理用户和权限是保障数据库安全的重要措施,建议在实际操作中遵循最佳实践,确保数据库的安全与稳定。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/72928.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

影刀RPA编码版与流程版解析

影刀RPA编码版是影刀RPA的一个高级版本,它结合了流程版的可视化操作和编码版的强大灵活性,以下是对影刀RPA编码版的详细介绍: 1. 功能对比 流程版: 可视化操作:通过拖拽式流程设计器,用户可以像搭积木一样…

20天 - TCP 和 UDP 有什么区别?说说 TCP 的三次握手?TCP 是用来解决什么问题?

TCP 和 UDP 有什么区别? TCP(传输控制协议)和 UDP(用户数据报协议)都是传输层的网络协议,它们的主要区别如下: 连接方式 TCP:面向连接的协议,类似于打电话&#xff0c…

【MySQL_05】语法简述(是语法,不详细介绍各种语句)

文章目录 一、基本规则二、标识符规则三、数据类型四、运算符五、关键字六、SQL 语句的通用语法结构 历史文章点击👉:SQL 🐈‍⬛github:https://github.com/mysql 💻官网: https://www.mysql.com &#…

JavaScript中的生成器函数详解

在 JavaScript 中,生成器函数 Generator Function 是一种特殊的函数,它允许你在函数执行过程中暂停和恢复。生成器函数通过 function* 语法定义,并使用 yield 关键字来控制函数的执行流程。生成器函数返回一个生成器对象,该对象遵…

计算机网络——交换机

一、什么是交换机? 交换机(Switch)是局域网(LAN)中的核心设备,负责在 数据链路层(OSI第二层)高效转发数据帧。它像一位“智能交通警察”,根据设备的 MAC地址 精准引导数…

Git合并工具在开发中的使用指南

在团队协作开发中,Git 是最常用的版本控制工具,而代码合并(Merge)是多人协作不可避免的环节。当多个开发者同时修改同一文件的相同区域时,Git 无法自动完成合并,此时需要借助合并工具(Merge Too…

实现多语言适配

1.在res下创建多语言资源文件: 2.选择需要的语言 然后得到多种语言适配string文件: 3.代码设置多语言 object LanguageHelper {/*** 获取适配的 Context*/fun getAttachBaseContext(context: Context): Context {return if (Build.VERSION.SDK_INT > …

【学习方法一】

学习方法一 一、通用高效学习法二、学科专项方法三、工具与技术辅助四、习惯与心理策略五、避免常见误区总结六、进阶学习策略七、解决学习痛点八、场景化学习法九、资源与工具推荐十、个性化学习调整十一、长期学习心态十二、常见问题QA十三、应对特殊挑战的学习法十四、健康与…

Golang学习笔记_44——命令模式

Golang学习笔记_41——观察者模式 Golang学习笔记_42——迭代器模式 Golang学习笔记_43——责任链模式 文章目录 一、核心概念1. 定义2. 解决的问题3. 核心角色4. 类图 二、特点分析三、适用场景1. 事务管理系统2. 多媒体遥控器3. 操作审计系统 四、Go语言实现示例五、高级应用…

应急响应--流量分析

(一)Cobalt Strike流量特征分析 1.HTTP特征 源码特征: 在流量中,通过http协议的url路径,在checksum8解密算法计算后,32位的后门得到的结果是92,64位的后门得到的结果是93,该特征符…

CI/CD—Jenkins配置一次完整的jar自动化发布流程

背景: 实现设想: 要创建自动化发布,需要准备一台测试服务器提前安装好java运行所需的环境,JDK版本最好和Windows开发机器上的版本一致,在Jenkins上配置将构建好的jar上传到测试服务器上,测试服务器自动启动…

创建分区表ORA-14037

1、故障现象 在跑脚本的时候创建物化试图提示分区界限过高 2、解决方法 最终原因是:缺少了 这个 r34411分区,加上就好。 判断是物化视图创建的时候需要兼容所有分区的数据,所以报错,而分区表则不存在这种情况 3、测试验证 分区…

转和git subtree管理方式为git submodule的管理方式

将 Git 子树(subtree)转换为子模块(submodule)的步骤如下: 1. 确定子树的路径和对应的远程仓库地址 找到当前项目中子树的路径以及对应的远程仓库地址。例如,假设子树的路径为 subtree-folder&#xff0c…

基于51单片机多功能防盗报警系统

基于51单片机多功能防盗报警系统( proteus仿真程序设计报告原理图讲解视频) 1. 主要功能:2. 讲解视频:3. 仿真4. 程序代码5. 设计报告6. 原理图7. 设计资料内容清单&&下载链接 仿真图proteus8.9及以上 程序编译器:keil 4/…

R语言和RStudio安装

整体还是比较简单的,主要是记录个流程。 官方镜像站列表R语言官网 1 安装R(2025/3/6) R语言官网:The R Project for Statistical Computing 打开之后就Hello world一下吧 配置环境变量 2 安装RStudio 下载地址:htt…

Ubuntu 22.04 升级到 Ubuntu 24.04 全流程指南

📌 1. 前言 Ubuntu 24.04 是最新的 LTS 版本,带来了内核更新、性能优化以及更强的安全性。本指南详细记录了从 Ubuntu 22.04 升级到 24.04 的完整过程,包括 升级前的准备、遇到的问题及如何选择最佳选项,避免升级失败或系统损坏。…

【每日学点HarmonyOS Next知识】Web跨域资源、Web长按菜单、Web拦截请求、禁止录屏、Base64图片宽高

1、HarmonyOS Web组件本地资源跨域问题? 关于资源跨域问题的解决,可以参考以下官网文档:https://developer.huawei.com/consumer/cn/doc/harmonyos-guides-V5/web-cross-origin-V5 方法一 为了使Web组件能够成功访问跨域资源,开…

数据库查问题常用OS命令汇总

1、内存使用情况查看 top //查看活跃进程占用情况 free -mh //查看操作系统当前可用内存 2、cpu使用情况 lscpu //查看os cpu情况 sar -u -f sar文件名 -s hh:mm:ss -e hh:mm:ss //查看对应日期的历史cpu情况 top //查看当前活跃进程使用cpu情况 3、io情况 iostat …

nlp培训重点-5

1. LoRA微调 loader: # -*- coding: utf-8 -*-import json import re import os import torch import numpy as np from torch.utils.data import Dataset, DataLoader from transformers import BertTokenizer """ 数据加载 """cl…

CI/CD—Jenkins配置Maven+GitLab自动构建jar包

一、安装Maven插件通过Maven构建项目 1、在Jenkins上安装Maven Integration plugin插件 2、创建一个maven项目 2.1、填写构建的名称和描述等 2.2、填写连接git的url 报错:无法连接仓库:Error performing git command: git ls-remote -h http://192.168.…