MySQL、Maria数据库用户管理(创建、修改、删除用户)常用操作

一. 前言

MySQL 在安装时,会默认创建一个名为 root 的用户,该用户拥有超级权限,可以控制整个 MySQL 服务器。

在对 MySQL 的日常管理和操作中,为了避免有人恶意使用 root 用户控制数据库,我们通常创建一些具有适当权限的用户,尽可能地不用或少用 root 用户登录系统,以此来确保数据的安全访问。

二. 常用操作

2.1. 数据库操作

2.1.1. 创建数据库

要创建一个新的数据库,你可以使用以下SQL命令:

CREATE DATABASE database_name;

将database_name替换为你想要创建的数据库的名称。

2.1.2. 选择数据库

在对数据库进行操作之前,你需要先选择数据库:

USE database_name;

2.2. 用户管理操作

2.2.1 创建数据库用户

创建一个新的数据库用户,你可以使用以下命令:

CREATE USER 'username'@'localhost' IDENTIFIED BY 'password';
  • 将username替换为新用户的用户名。
  • host指定了用户可以从哪些主机连接到数据库服务器。如果你想允许从任何主机连接,可以使用通配符%。
  • password是用户的密码。

2.2.2 授权

要给用户权限,以允许他们对数据库进行操作,可以使用GRANT语句:

GRANT ALL PRIVILEGES ON database_name.* TO 'username'@'localhost';
  • 这将授予usernamedatabase_name数据库上的所有权限。
  • 如果你只想授予特定的权限(如SELECT, INSERT, UPDATE等),可以将ALL PRIVILEGES替换为相应的权限列表。

授权
确保在授权之后执行FLUSH PRIVILEGES;命令,以使更改生效。

FLUSH PRIVILEGES;

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

REVOKE ALL PRIVILEGES ON database_name.* FROM 'username'@'localhost';

这将从database_name数据库上撤销username用户的所有权限。

查看用户权限
要查看特定用户的权限,可以使用以下命令:

SHOW GRANTS FOR 'username'@'host';

2.2.3. 修改用户

1.修改用户名称
在MySQL中直接修改用户名的操作并不像修改密码那样直接。通常,修改用户名实际上涉及到创建一个新的用户,然后将旧用户的权限复制给新用户,最后删除旧用户。但是,从MySQL 5.7.6版本开始,可以使用RENAME USER命令直接修改用户名。

RENAME USER 'old_username'@'localhost' TO 'new_username'@'localhost';

在这里,需要将old_usernamenew_username替换成实际的用户名,完成操作后,建议执行FLUSH PRIVILEGES;命令来刷新权限。
2.修改密码
修改MySQL用户密码,可以使用ALTER USER命令,这是推荐的方式。以下是修改密码的一个例子:

ALTER USER 'username'@'localhost' IDENTIFIED BY 'new_password';

username替换为实际的用户名,host替换成用户所能连接的主机,new_password替换成新的密码。完成后,同样建议执行FLUSH PRIVILEGES;以确保更改立即生效。

对于早期版本的MySQL,可能需要使用SET PASSWORD命令:

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

这里的PASSWORD('new_password')是一个函数,用于加密新密码。不过,从MySQL 5.7.6开始,推荐使用ALTER USER命令,因为它更直接且符合SQL标准。

注意

  • 在执行任何修改前,确保你有足够的权限来更改用户的用户名和密码。
  • 修改完成后,被影响的用户需要使用新的用户名或密码重新连接数据库。
  • 出于安全考虑,定期更新数据库密码是一个好习惯,但要避免使用简单易猜的密码。
  • 如果你在操作过程中遇到权限不足的问题,请确保你以具有足够权限的用户(如root)登录MySQL进行操作。

2.2.4. 删除用户

删除数据库用户,可以使用以下命令:

DROP USER 'username'@'localhost';

2.2.5. 查看当前所有用户

要查看MySQL服务器上的所有用户,可以执行以下查询:

SELECT user FROM mysql.user;

以上就是关于MySQL、Maria数据库用户管理(创建、修改、删除用户)常用操作,希望对你有帮助!

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

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

相关文章

(78)删除有序数组中的重复项(79)排序矩阵查找

文章目录 1. 每日一言2. 题目(78)删除有序数组中的重复项2.1 解题思路2.2 代码 3. 题目(79)排序矩阵查找3.1 解题思路3.1.1 暴力查找暴力查找代码 3.1.2 二分查找二分查找代码 3.1.3 贪心贪心代码 4. 结语 1. 每日一言 水晶帘动微风起,满架蔷薇一院香。 —高骈- 2.…

minio-docker单节点部署SDK测试文件上传下载

目录 一,docker部署minio单节点单磁盘 二,SDK测试上传下载 一,docker部署minio单节点单磁盘 1.拉取镜像 # 下载镜像 docker pull minio/minio 2.查看镜像 docker images 3.启动minio(新版本) 创建本机上的挂载目录,这个可以…

Java中Runnable和Callable有什么不同?(企业真题)

Java中Runnable和Callable有什么不同? 与之前的方式的对比:与Runnable方式的对比的好处 call()可以有返回值,更灵活 call()可以使用throws的方式处理异常,更灵活 Callable使用了泛型参数,可以指明具体的call()的返回值…

NetSuite 销售订单页面选择客户后停滞问题研究

随着用户环境中定制内容的增加,用户会发现Sales Order中选择Customer时的页面停滞时间会变长。这让用户感到很疑惑。 我们初步研究了一下这个问题,两个变量比较显著: •Form的页签数量•脚本的挂载数量 试验数据 1. 多页签,无…

二维相位解包理论算法和软件【全文翻译- 非加权多网格算法解包裹(5.3.3)】

5.3.3 非加权多网格算法 在本节中,我们将介绍第四种非加权最小二乘相位解包算法。与前三种算法不同,这是一种迭代算法,是第 5.4 节介绍的加权最小二乘相位解包多网格技术的基础。本节开始将详细介绍多网格方法,包括典型多网格算法的伪代码。由于多网格算法是以递归方式自然…

潍微科技-水务信息管理平台 ChangePwd SQL注入漏洞复现(CNVD-2024-14945)

0x01 产品简介 水务信息管理平台主要帮助水务企业实现水质状态监测、管网运行监控、水厂安全保障、用水实时监控以及排放有效监管,确保居民安全稳定用水、环境有效保护,全面提升水务管理效率。由山东潍微科技股份有限公司研发,近年来,公司全力拓展提升水务、水利信息化业务…

nginx工作原理解析

目录 1、master-workers 的工作机制介绍 2、master-workers 的机制的好处 3、设置多少个 worker 4、最大连接数和支持的最大并发数的计算 1、master-workers 的工作机制介绍 nginx在启动后,会有一个master进程和一个或者多个相互独立的worker进程 过来的请求由…

数字化时代:IT界的致富秘籍 —— 策略×态度×机遇

🌟 数字化时代:IT界的致富秘籍🚀 —— 策略态度机遇 在数字化浪潮中冲浪🏄‍♂️,IT行业犹如一片无限可能的蓝海。想要在这片汹涌的海洋中捕获财富,不是一件轻而易举的事。让我们一起深入探索,如…

对给定向量旋转

对给定向量旋转 顺时针&#xff1a; 逆时针&#xff1a; 源码&#xff1a; QPointF rotateVector(const QPointF& dir, double angle, bool flag){double rad (angle * M_PI) / 180;QPointF res;if (flag){float x static_cast<float>(dir.x() * std::cos(rad) …

redisson实现的分布式锁是可重入的吗?

首先理解可重入锁&#xff1a; 可重入锁&#xff0c;又叫做递归锁&#xff0c;是指在同一个线程在外层方法获取锁的时候&#xff0c;再进入该线程的内层方法会自动获取锁&#xff08;前提是同一个对象或者class&#xff09;&#xff0c;不会因为之前已经获取过锁而导致锁的阻塞…

网络知识 | IP地址与MAC地址,TCP三次握手与四次挥手

IP地址与MAC地址 MAC地址&#xff08;Media Access Control Address&#xff09;&#xff0c;又称物理地址&#xff0c;用来标识网络中的设备&#xff0c;出厂时由生产网商写到网卡的BIOS中&#xff0c;具有唯一性&#xff0c;不可更改。 IP地址&#xff08;Internet Protoco…

日期统计(蓝桥杯)

文章目录 日期统计问题描述答案&#xff1a;235回溯算法暴力枚举 日期统计 问题描述 小蓝现在有一个长度为 100 的数组&#xff0c;数组中的每个元素的值都在 0 到 9 的范围之内。数组中的元素从左至右如下所示&#xff1a; 5 6 8 6 9 1 6 1 2 4 9 1 9 8 2 3 6 4 7 7 5 9 5 …

【2024年5月备考新增】《软考真题分章练习(含答案解析) - 17 管理科学-运筹学基础 (1)》

管理科学-运筹学基础 1、小李作为项目经理需要从以下四个项目方案中选择项目,已知项目周期均为 2 年且期初投资额都是30.000 元,折现均为 10%。项目情况如下: 方案 A:第一年现金流为 14,000 元,第二年现金流 19,000 元 方案 B:第一年现金流为 23,000 元,第二年现金流…

rust学习笔记

一、常用trait Clone&Copy pub trait Clone: Sized {fn clone(&self) -> Self; }pub trait Copy: Clone { } Clone Copy let y x;let y x.clone();发生移动编译报错√发生移动发生拷贝√√发生拷贝发生拷贝 Clone&#xff1a;可以理解为深拷贝&#xff0c;例如…

【前端】layui table表格勾选事件,以及常见模块

欢迎来到《小5讲堂》&#xff0c;大家好&#xff0c;我是全栈小5。 这是《前端》系列文章&#xff0c;每篇文章将以博主理解的角度展开讲解&#xff0c; 温馨提示&#xff1a;博主能力有限&#xff0c;理解水平有限&#xff0c;若有不对之处望指正&#xff01; 目录 表格勾选事…

java基础-chapter16(动态代理)

动态代理 特点&#xff1a;无侵入式的给代码增加额外的功能 在Java中&#xff0c;动态代理是一种在运行时动态生成代理对象的机制&#xff0c;而不需要在编译时确定代理类。它允许在运行时创建一个实现了一组特定接口的代理类&#xff0c;这些代理类可以将方法调用转发到实际…

面试-数据库基础以及MySql、ClickHost、Redis简介

面试-数据库基础以及MySql、ClickHost、Redis简介 0.数据完整性1.数据库并发控制1.1事物1.2 并发读写错误1.3 锁1.3.1 乐观锁与悲观锁1.3.2 共享锁和排他锁1.3.3 行锁与表锁1.3.4 意向锁 1.4 封锁协议与隔离级别1.5 MVCC1.5.1 概念1.5.2 当前读与快照读1.5.3 MVCC in InnoDB 2.…

pytest常用钩子函数

1、什么叫钩子函数 在Pytest框架中&#xff0c;钩子函数是一种允许用户扩展或者自定义测试执行过程的机制。钩子函数允许用户在测试的不同阶段插入自定义的代码&#xff0c;以实现特定的行为&#xff0c;操作或处理。这种插入式的机制使得Pytest具有高度的灵活性和扩展性。 如…

Linux软件包管理器yum—5

一、Linux下软件安装的方式 ①源代码安装&#xff1a; ②rmp包安装&#xff1a; 本质是拷贝可执行程序到系统目录下。 ③yum一键下载&#xff0c;安装&#xff0c;卸载。相当于手机的应用商店。 二、yum 2.1查看yum已配置的源&#xff1a; ls /etc/yum.repos.d/ 2.2查看yum…

环信 IM 客户端将适配鸿蒙 HarmonyOS

自华为推出了自主研发操作系统鸿蒙 HarmonyOS 后&#xff0c;国内许多应用软件开始陆续全面兼容和接入鸿蒙操作系统。环信 IM 客户端计划将全面适配统鸿蒙 HarmonyOS &#xff0c;助力开发者快速实现社交娱乐、语聊房、在线教育、智能硬件、社交电商、在线金融、线上医疗等广泛…