用户管理(MySQL)

news/2024/11/29 23:31:34/

目录

1用户管理(MySQL)

1.1 用户

1.1.1 用户信息

1.1.2 创建用户(@后'%'是可以任意远端登录)

1.1.3 刷新一下

1.1.4 删除用户

1.1.5 修改用户密码

1.2 数据库的权限

1.2.1 登录创建用户

1.2.2给权限

1.2.2.1 把jj数据库中uu表的权限给woaini这个用户

1.2.2.2 --给用户woaini赋予jj数据库下所有文件的select权限

1.2.2.3 注意:如果发现赋权限后,没有生效,执行如下指令:

1.2.3 回收权限


1用户管理(MySQL)

如果我们只能使用root用户,这样存在安全隐患。这时,就需要使用MySQL的用户管理

1.1 用户

1.1.1 用户信息

MySQL中的用户,都存储在系统数据库mysql的user表中

mysql> use mysql;
Database changed
mysql> select host,user,authentication_string from user;
+-----------+---------------+-------------------------------------------+
| host     | user         | authentication_string                     |
+-----------+---------------+-------------------------------------------+
| localhost | root         | *81F5E21E35407D884A6CD4A731AEBFB6AF209E1B |
| localhost | mysql.session | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE |
| localhost | mysql.sys     | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE |
+-----------+---------------+-------------------------------------------+--可以通过desc user初步查看一下表结构

字段解释:

host: 表示这个用户可以从哪个主机登陆,如果是localhost,表示只能从本机登陆
user: 用户名
authentication_string: 用户密码通过password函数加密后的
*_priv: 用户拥有的权限

1.1.2 创建用户(@后'%'是可以任意远端登录)

语法:

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

案例:

mysql> create user 'woaini'@'localhost' identified by '12345678';

1.1.3 刷新一下

1.1.4 删除用户

语法:

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

示例:

1.1.5 修改用户密码

语法:

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

1.2 数据库的权限

MySQL数据库提供的权限列表:

刚创建的用户没有任何权限。需要给用户授权。

语法:

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

说明:

  • 权限列表,多个权限用逗号分开
grant select on ...
grant select, delete, create on ....
grant all [privileges] on ... -- 表示赋予该用户在该对象上的所有权限
  • *.* : 代表本系统中的所有数据库的所有对象(表,视图,存储过程等)
  • 库.* : 表示某个数据库中的所有数据对象(表,视图,存储过程等)
  • identified by可选。 如果用户存在,赋予权限的同时修改密码,如果该用户不存在,就是创建用户

案例: --使用root账号

先创建一个表

1.2.1 登录创建用户

1.2.2给权限

1.2.2.1 把jj数据库中uu表的权限给woaini这个用户

grant all on jj.uu to 'woaini'@'localhost';

1.2.2.2 --给用户woaini赋予jj数据库下所有文件的select权限

然后就不可以删除了

1.2.2.3 注意:如果发现赋权限后,没有生效,执行如下指令:
flush privileges;

1.2.3 回收权限

语法:

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

示例:

-- 回收woaini对jj数据库的所有权限

--root身份


http://www.ppmy.cn/news/1551024.html

相关文章

如何处理vue项目中的错误的?都有哪些错误类型?

在 Vue 项目中,错误的处理至关重要,它帮助开发者捕捉并修复应用中的问题。Vue.js 提供了多种机制来帮助我们处理和调试错误,包括 Vue 的内置错误处理机制和常见的 JavaScript 错误处理方式。本文将分析 Vue 中错误的分类以及如何在 Vue 项目中进行处理,结合源码来理解其内部…

Java基础 设计模式——针对实习面试

目录 Java基础 设计模式单例模式工厂模式观察者模式策略模式装饰器模式其他设计模式 Java基础 设计模式 单例模式 单例模式(Singleton Pattern) 定义:确保一个类只有一个实例,并提供一个全局访问点来访问这个实例。适用场景&…

群控系统服务端开发模式-应用开发-邮箱配置功能开发

邮箱配置主要是将管理员数据做归属。具体见下图: 一、创建表 1、语句 CREATE TABLE cluster_control.nc_param_mail (id int(11) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT 编号,title varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT…

List集合的进一步学习:性能优化

|| 持续分享系列教程,关注一下不迷路 || || B站视频教程:墨轩大楼 || || 知识星球:墨轩编程自习室 || 在Java集合框架中,选择合适的集合类型和使用正确的操作…

Flink四大基石之Window

为什么要用WIndow 在流处理应用中,数据是连续不断的,有时我们需要做一些聚合类的处理,例如:在过去的1分钟内有多少用户点击了我们的网页。 在这种情况下,我们必须定义一个窗口(window),用来收集最近1分钟内…

论文笔记 SliceGPT: Compress Large Language Models By Deleting Rows And Columns

欲买桂花同载酒,终不似,少年游。 数学知识 秩: 矩阵中最大线性无关的行/列向量数。行秩与列秩相等。 线性无关:对于N个向量而言,如果任取一个向量 v \textbf{v} v,不能被剩下的N-1个向量通过线性组合的方式…

SplatFormer: Point Transformer for Robust3D Gaussian Splatting 论文解读

目录 一、概述 二、相关工作 1、NVI新视角插值 2、稀疏视角重建 3、OOD-NVS 4、无约束重建下的正则化技术 5、基于学习的2D-to-3D模型 6、3D点云处理技术 三、SplatFormer 1、Point Transformer V3 2、特征解码器 3、损失函数 四、数据集 五、实验 一、概述 该论…

shell编程(8)

目录 一、until循环 示例 until 和 while 的区别 二、case语句 基本语法 示例 1. 简单的 case 语句 2. 使用通配符 3. 处理多个匹配 case 和 if 的比较 case 语句: if 语句: 三、基本函数 基本函数定义和调用 1. 定义一个简单的函数 2. …