MySQL的权限管理与远程访问

MySQL的权限管理

1、授予权限

授权命令: grant 权限1,权限2,...权限n on 数据库名称.表名称 to 用户名@用户地址 identified by '连接口令';

该权限如果发现没有该用户,则会直接新建一个用户。

java 复制代码
比如  
grant select,insert,delete,drop on atguigudb.* to li4@localhost  ;
 #给li4用户用本地命令行方式下,授予atguigudb这个库下的所有表的插删改查的权限。
java 复制代码
grant all privileges on *.* to joe@'%'  identified by '123'; 
#授予通过网络方式登录的的joe用户 ,对所有库所有表的全部权限,密码设为123。

2、收回权限

1)查看当前用户权限

java 复制代码
show grants;

2)收回权限命令:

java 复制代码
revoke  权限1,权限2,...权限n on 数据库名称.表名称  from用户名@用户地址 ; 
java 复制代码
REVOKE ALL PRIVILEGES ON mysql.* FROM joe@localhost;
#收回全库全表的所有权限。
java 复制代码
REVOKE select,insert,update,delete ON mysql.* FROM joe@localhost;
#收回mysql库下的所有表的插删改查权限。
 必须用户重新登录后才能生效。

3、查看权限

1)查看当前用户权限

java 复制代码
show grants; 

2)查看某用户的全局权限

java 复制代码
select  * from user ;

3)查看某用户的某个表的权限

java 复制代码
select * from tables_priv;

4、远程访问

(1)先 ping 一下数据库服务器的ip 地址确认网络畅通。

(2)关闭数据库服务的防火墙

java 复制代码
 service iptables stop 

(3) 确认Mysql中已经有可以通过远程登录的账户

select * from mysql.user where user='li4' and host='%';

(4)如果没有用户,先执行如下命令:

java 复制代码
 grant all privileges on *.*  to li4@'%'  identified by '123123'; 

(5)测试连接:

相关推荐
xifangge20251 分钟前
【2026终极解法】彻底解决“由于找不到 msvcp140.dll,无法继续执行代码”报错(附微软运行库一键修复包)
windows·mysql·microsoft·报错·开发环境
维齐洛波奇特利(male)18 分钟前
@Pointcut(“execution(* com.hdzx..*(..))“)切入点与aop 导致无限循环
java·开发语言
色空大师19 分钟前
【日志文件配置详解】
java·logback·log4j2·日志
treacle田20 分钟前
达梦数据库-达梦数据库中link链接访问远程Sql Sever-记录总结
数据库·达梦-sqlserver
神奇小汤圆20 分钟前
Spring-Boot-泛型封装-这8个坑让我调了3天
后端
深挖派21 分钟前
GoLand 2026.1 安装配置与环境搭建 (保姆级图文教程)
后端·golang·编辑器·go·goland
ClouGence22 分钟前
不用搭复杂系统,也能做跨地域数据迁移?
大数据·数据库·saas
IT枫斗者22 分钟前
构建具有执行功能的 AI Agent:基于工作记忆的任务规划与元认知监控架构
android·前端·vue.js·spring boot·后端·架构
xcjbqd024 分钟前
SQL中视图能否嵌套存储过程_实现复杂自动化报表逻辑
jvm·数据库·python
神奇小汤圆26 分钟前
一文吃透 MySQL 性能优化:从执行计划到架构设计
后端