[MySQL] MySQL中的用户管理

 

文章目录

一、用户

1、1 用户信息

1、2 创建用户

1、3 删除用户

1、4 修改用户密码 

二、数据库的权限

2、1 用户权限

2、2 回收权限


🙋‍♂️ 作者:@Ggggggtm 🙋‍♂️

👀 专栏:MySQL 👀

💥 标题:MySQL中的用户管理💥

 ❣️ 寄语:与其忙着诉苦,不如低头赶路,奋路前行,终将遇到一番好风景 ❣️

  MySQL中的用户管理是指对数据库用户进行创建、授权、修改和删除等操作的过程。用户是MySQL数据库的访问身份,它们定义了连接到数据库的权限和限制。

  MySQL中也是有root用户和普通用户之分的。跟Linux一样,root用户就是所谓的超级用户,权限较大且基本上没有限制。普通用户都是我们自己后期创建的,权限相对较小且较多限制。 

一、用户

1、1 用户信息

  MySQL中的用户,都存储在系统数据库mysqluser表中。如下图:

   我们不妨来看看user表的表结构,如下图:

  说明一下,在"mysql"数据库中,有一个名为"user"的表,该表记录了MySQL服务器上的用户账户信息。下面是对"user"表重要字段的详解:

  1. user字段:这是用户账户的名称,用于登录MySQL服务器时使用。每个用户账户都必须具有唯一的用户名。

  2. host字段:表示允许该用户从哪个主机连接到MySQL服务器。可以使用具体的主机名,也可以使用通配符%,表示允许来自任意主机的连接。

  3. authentication_string字段:用于存储用户账户的密码。在MySQL 8.0版本之前,密码以明文形式存储在该字段中。而在MySQL 8.0版本之后,密码以加密形式存储,并且采用了更安全的认证方式。

  4. select_priv、insert_priv、update_priv、delete_priv等权限字段:这些字段用于记录用户账户具有的数据库操作权限。例如,select_priv字段表示用户是否具有查询数据的权限,insert_priv字段表示用户是否具有插入数据的权限,依此类推。

  5. grant_priv字段:表示用户是否具有赋予其他用户权限的能力。如果该字段值为'Y',则表示该用户具有授权权限。

  从上述的表结构我们能够看到,USER和HOST字段一同构成主键,这也就意味着可以有相同的用户名,只需要登录的主机限制不同即可!下面我们再看一下该表中的数据,如下图:

  从上图中,我们也能大概的看出来root用户的权限是较高的。由于字段较多,现在我们就挑选出我们需要的字段,如下图:

  从上图中能够看到,现在是有三个用户,均为系统自带的。接下来我们看怎么自己创建用户。

1、2 创建用户

  创建用户的语法:

create user '用户名'@'登陆主机/ip' identified by '密码';

   下面我们就来创建一个用户,具体如下:

  这里有几点需要解释:

  • 登陆主机为localhost,代表着该用户只允许在当前主机登录;
  • 登陆主机也可以为 %,代表着该用户可以在任意主机登录。但是,不要轻易添加一个可以从任意地方登陆的user
  • 从上述例子中我们也能发现,对用户的增删查改操作本质上就是在修改user表。可以直接对user表操作,但是不建议这样做!

  下面我们登陆一下这个用户,具体如下图:

  当我们设置了登陆主机位 % 时,同时也在本主机上安装了MySQL,那么就可以使用cmd命令窗口进行登录。具体用到的指令为:mysql -u 用户名 -h IP地址 -P 端口号 -p。这里就不再演示。

1、3 删除用户

  删除用户语法:

drop user '用户名'@'主机名'

  当我们处于普通用户时,并不能删除其他用户。原因很简单,权限不够。具体如下图:

  现在我们切换到root用户。在进行删除用户,具体如下:

  注意:当我们在删除用户时如果不指明待用户的登录地址,则默认删除的是登录地址为%的用户。

1、4 修改用户密码 

   修改用户密码语法:

--自己改自己密码
set password=password('新的密码');--root用户修改指定用户的密码
set password for '用户名'@'主机名'=password('新的密码');

  当用户相对自己修改密码时,可用到上述的第一条语句中。第二条语句可用于root用户对其他普通用户做修改。下面我们要试一下第二条语句。具体如下图:

  注意:创建用户的SQL当中包含用户的密码,因此该SQL不会被历史记录下来,所以不能通过上下键进行追溯。

二、数据库的权限

2、1 用户权限

  MySQL中的权限是与用户关联的。每个用户都有自己的用户名和密码,并且可以被分配不同的权限。

  MySQL提供了各种权限,包括SELECT(查询)、INSERT(插入)、DELETE(删除)、UPDATE(更新)、CREATE(创建)、DROP(删除)、GRANT(授权)、REVOKE(撤销授权)等。具体可结合下图:

  但是刚创建的用户没有任何权限。需要给用户授权。 授权语法:

grant 权限列表 on 库.对象名 to '用户名'@'登陆位置' [identified by '密码']

   说明一下:

  1. 权限列表,多个权限用逗号分开
    grant select on ...grant select, delete, create on ....grant all [privileges] on ... -- 表示赋予该用户在该对象上的所有权限
  2. *.* : 代表本系统中的所有数据库的所有对象(表,视图,存储过程等)。
  3. .* : 表示某个数据库中的所有数据对象(表,视图,存储过程等)。
  4. identified by 可选。 如果用户存在,赋予权限的同时修改密码 , 如果该用户不存在,就是创建用户。
  或许你到这里就会明白了,我们不建议使用root的用户的原因之一是因为root用户的权限太大了,可以操作任何表。但是我们可以创建普通用户,然后给普通用户赋予对某个数据库中表的操作权限。这样就可以很好的将整个数据库管理起来。

  我们先来看一下普通用户ggg中可以对哪些库进行操作,如下图:

  我们看到,只有一个系统自带的数据库,其他的并没有任何数据库。同时只有一个 USAGE 权限,就是登录的权限,相当于刚创建的用户没有任何权限。现在我们通过root用户给ggg用户赋予权限。具体如下:

  说明一下:上述的语句是给用户ggg 能够查询staff库中所有表信息的权限。具体如下图:

  我们再看ggg用户,如下图:

  我们看到有staff库了。现在我们可以进入到staff库中进行查看其中所有表以及表中的信息。具体如下:

  但是由于只赋予了select权限,所以只能查看,并不能对表进行修改操作。具体如下图:

  现在我们将所有的权限赋给用户ggg,具体操作如下:

  这时用户ggg 可以对staff中的表进行修改操作了。具体如下:

2、2 回收权限

  回收权限语法:

revoke 权限列表 on 库.对象名 from '用户名'@'登陆位置';

  现在是用户ggg 拥有所有对staff库中表操作的权限。现在我们想收回一些权限,可以用到revoke。具体如下:

  我们可以看到,用户ggg的权限只有UASGE,也就是只有登陆权限了。

  注意:回收用户在某一数据库下的权限后,在该用户下一次进入该数据库时才会起作用。也就是如果回收权限时该用户正在使用对应数据库,那么回收权限后该用户仍然拥有对应的权限。

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

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

相关文章

SpringBoot+WebSocket

SpringBootWebSocket 1.导入依赖&#xff1a; -- Spring Boot 2.x 使用 javax.websocket-- Spring Boot 3.x 使用 jakarta.websocket<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId&g…

国产Apple Find My认证芯片哪里找,伦茨科技ST17H6x芯片可以帮到您

深圳市伦茨科技有限公司&#xff08;以下简称“伦茨科技”&#xff09;发布ST17H6x Soc平台。成为继Nordic之后全球第二家取得Apple Find My「查找」认证的芯片厂家&#xff0c;该平台提供可通过Apple Find My认证的Apple查找&#xff08;Find My&#xff09;功能集成解决方案。…

使用java获取nvidia显卡信息

前言 AI开发通常使用到GPU&#xff0c;但通常使用的是python、c等语言&#xff0c;java用的则非常少。这也导致了java在gpu相关的库比较少。现在的需求是要获取nvidia显卡的使用情况&#xff0c;如剩余显存。这里给出两种较简单的解决方案。 基于nivdia-smi工具 显卡是硬件&a…

算法(1)——双指针

双指针 我们常见的双指针的形式有两种&#xff0c;一种是对撞指针&#xff0c;一种是快慢指针&#xff01; 对撞指针&#xff1a;一般用于顺序结构中&#xff0c;也称左右指针。 1、对撞指针从两端向中间移动。一个指针从最左端开始&#xff0c;另一个从最右端开始&#xff0c…

2024年【起重机司机(限门式起重机)】考试题库及起重机司机(限门式起重机)模拟考试题

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 起重机司机(限门式起重机)考试题库考前必练&#xff01;安全生产模拟考试一点通每个月更新起重机司机(限门式起重机)模拟考试题题目及答案&#xff01;多做几遍&#xff0c;其实通过起重机司机(限门式起重机)复审模拟…

21 3GPP中 5G NR高速列车通信标准化

文章目录 信道模型实验——物理层设计相关元素μ(与子载波间隔有关)设计参考信号(DMRS) 本文提出初始接入、移动性管理、线性小区设计等高层技术。描述3GPP采用HST场景的评估参数&#xff0c;阐释了HST应用的物理层技术&#xff0c;包括数字通信和参考信号设计&#xff0c;链路…

互联网中的商品超卖问题及其解决方案:Java中Redis结合UUID的应用

前言 在设计商品下单和库存扣减&#xff0c;你一定遇到过这样的问题&#xff0c;库存扣减为0了&#xff0c;可是消费者还能下单&#xff0c;并将订单信息保存到了数据库里&#xff0c;针对商品超卖问题&#xff0c;作此篇以解决。 随着互联网商业的飞速发展&#xff0c;商品超…

移动云捐赠三款开源项目,加速新一代基础软件生态繁荣

随着云计算、大数据、人工智能等新领域新信息技术的发展&#xff0c;我国基础软件的自主可控极大程度地影响着产业链上下游的多样性和技术创新的发展空间。移动云作为中国移动涉云业务的主入口&#xff0c;一直坚持共享开源价值&#xff0c;积极推动中国开源软件生态的繁荣发展…

SpringData JPA 整合Springboot

1.导入依赖 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/POM/4.0…

7-1 单身狗(PTA - 数据结构)

由于这道题在留的作业中&#xff0c;排序和查找都有&#xff0c;所以我先写这道题&#xff08;图的先放放&#xff09; “单身狗”是中文对于单身人士的一种爱称。本题请你从上万人的大型派对中找出落单的客人&#xff0c;以便给予特殊关爱。 输入格式&#xff1a; 输入第一行…

域架构下的功能安全思考

来源&#xff1a;联合电子 随着整车电子电气架构的发展&#xff0c;功能域控架构向整车集中式区域控制演进。新的区域控制架构下&#xff0c;车身控制模块(BCM)&#xff0c;整车控制单元&#xff08;VCU&#xff09;&#xff0c;热管理系统&#xff08;TMS&#xff09;和动力底…

python实现贪吃蛇游戏

文章目录 1、项目说明2、项目预览3、开发必备4、贪吃蛇代码实现4.1、窗口和基本参数实现4.2、绘制背景4.3、绘制墙壁4.4、绘制贪吃蛇4.5、绘制食物4.6、实现长度信息显示4.7、定义游戏暂停界面4.8、定义贪吃蛇死亡界面4.9、实现贪吃蛇碰撞效果4.10、实现添加食物功能4.11、实现…

elementui中的el-table,当使用fixed属性时,table主体会遮挡住滚动条的大半部分,导致很难选中。

情况&#xff1a; 解决&#xff1a; el-table加个类&#xff0c;这里取为class"table" 然后是样式部分&#xff1a; <style scoped lang"scss"> ::v-deep.table {// 滚动条高度调整::-webkit-scrollbar {height: 15px;}// pointer-events 的基本信…

处理HTTP响应状态码和错误处理

在Web开发的世界里&#xff0c;HTTP响应状态码和错误处理是不可或缺的一部分。它们就像是道路上的交通信号灯&#xff0c;指导着我们前进的方向&#xff0c;确保我们的应用程序能够正常运行。 HTTP响应状态码是Web服务器返回给客户端的数字代码&#xff0c;用于表示请求的处理…

以编程方式向 App 设计工具添加 UI 组件

App 设计工具组件库中提供了大多数 UI 组件&#xff0c;可以将它们拖放到画布上。有时&#xff0c;可能需要在代码视图中以编程方式添加组件。以下是一些常见情况&#xff1a; 创建在组件库中未提供的组件。例如&#xff0c;用于显示某对话框的 App 必须调用适当的函数来显示该…

Volta简单介绍

Volta是一款强大的JavaScript工具管理器&#xff0c;它简化了命令行工具的安装和管理。通过Volta&#xff0c;开发者可以轻松地在多个项目中切换和配置Node.js、npm以及其它JavaScript工具版本&#xff0c;提高开发效率和环境一致性。 什么是 Volta Volta 是一种管理 JavaScri…

数据之门:使用IPIDEA开启网络自由之旅~

本文目录 前言一、网络代理IP简介二、IPIDEA 优势2.1 多种类型IP代理2.2 海量纯净代理池2.3 稳定高效数据收集架构2.4 个人IP管理中心 三、IP代理实操小Tips3.1 查看本地网络IP3.2 使用浏览器IP代理3.3 使用IPIDEA进行爬虫实操 四、总结 前言 各位友友&#xff0c;大家好&…

ASP.NET MVC+EntityFramework图片头像上传

1&#xff0c;先展示一下整体的效果 2&#xff0c;接下来展示用户添加以及上传头像代码、添加用户界面 前端代码如下&#xff1a; <div class"form-group">Html.LabelFor(model > model.img, "头像&#xff1a;", htmlAttributes: new { class &…

【计算机组成与体系结构Ⅱ】多处理器部分讨论题目

多处理机课堂讨论 1.并行计算体系结构有哪些? SIMD、MIMD 2.多处理机的存储结构有哪些? 对称式共享存储器结构、分布式共享存储结构 3.什么是多处理机的一致性? 如果对某个数据项的任何读操作均可得到其最新写入的值&#xff0c;则认为这个存储系统是一致的。 4.监听协议的工…

UCloud + 宝塔 + PHP = 个人网站

UCloud 宝塔 PHP 个人网站 文章目录 1.概要2.UCloud使用教程&#xff08;租用云端服务器&#xff09;3.宝塔使用教程&#xff08;免费服务器运维面板&#xff09;4.总结 1.概要 今天主要是想教大家如何将在网络上白嫖到源码&#xff08;特指PHP源码!!!&#xff09;搭建运行…