MySQL用户及权限

1.创建用户:

指定ip:192.118.1.1的user1用户登录

create user 'user1'@'192.118.1.1' identified by '123';

指定ip:192.118.1.开头的user1用户登录

create user 'user1'@'192.118.1.%' identified by '123';

指定任何ip的user1用户登录

create use 'user1'@'%' identified by '123';

创建新用户

CREATE USER 'user1'@'%' IDENTIFIED BY '123';

'%' - 所有情况都能访问
'localhost' - 本机才能访问
'111.222.33.44' - 指定 ip 才能访问

2.删除用户

drop user '用户名'@'IP地址';

3.修改用户

rename user '用户名'@'IP地址' to '新用户名'@'IP地址';

4.修改密码

set password for '用户名'@'IP地址'=Password('新密码');

给该用户添加权限

#查看权限

show grants for '用户'@'IP地址'

#授权

grant select ,insert,update on db1.t1 to "user1"@'%';

# 表示有所有的权限,除了grant这个命令,这个命令是root才有的。

grant all privileges on db1.t1 to "user1"@'%';

#取消权限

取消来自远程服务器的user1用户对数据库db1的所有表的所有权限

revoke all on db1.* from 'user1'@"%";

取消来自远程服务器的user1用户所有数据库的所有的表的权限

revoke all privileges on '*' from 'user1'@'%';

复制代码
grant all privileges on 想授权的数据库.* to 'user1'@'%';

all 可以替换为 select,delete,update,create,drop

grant select,insert,update,delete on springmvc2.* to 'sgyx'@'localhost';

可能遇到的问题

复制代码
flush privileges;

在操作 mysql 库做用户的增删修改的时候,操作完毕的时候最好使用 flush privilege 命令刷新一下权限。否则可能会修改不生效。

相关推荐
十五年专注C++开发26 分钟前
hiredis: 一个轻量级、高性能的 C 语言 Redis 客户端库
开发语言·数据库·c++·redis·缓存
憨堡包^—^38 分钟前
Docker —— MySQL主从复制集群
mysql·docker·容器
bianguanyue2 小时前
SQLite密码修改故障排查:RSA加密随机性导致的数据库匹配问题
数据库·sqlite·c#
亚马逊云开发者2 小时前
将 Go 应用从 x86 平台迁移至 Amazon Graviton:场景剖析与最佳实践
linux·数据库·golang
凉拌青瓜哈2 小时前
DVWA-LOW级-SQL手工注入漏洞测试(MySQL数据库)+sqlmap自动化注入-小白必看(超详细)
mysql·安全·网络安全
张先shen3 小时前
亿级流量下的缓存架构设计:Redis+Caffeine多级缓存实战
数据库·redis·缓存
二楼后座。3 小时前
Golang操作MySQL json字段优雅写法
mysql·golang·json
~ 小团子3 小时前
每日一SQL 【各赛事的用户注册率】
数据库·sql
llm2009093 小时前
Jmeter的JDBC数据库连接
数据库·jmeter
lilian1294 小时前
linux系统mysql性能优化
linux·运维·mysql