mysql新建数据库、新建用户及授权操作
1、创建数据库
create database if not exists test176 default charset utf8 collate utf8_general_ci;
#utf8_general_cs 大小写敏感
#如果数据库test176不存在,则创建数据库test76;charset utf8 字符集默认utf8,collate utf8_general_ci 大小写不敏感
2、创建用户
create user 'username'@'ip' identified by 'password' #创建用户名username,密码为password的用户,只能在该IP电脑上登录
create user 'username'@'localhost' identified by 'password' #创建用户名username,密码为password的用户,只能本地登录
create user 'username'@'%' identified by 'password' #创建用户名username,密码为password的用户,无IP限制
create user 'username'@'%' identified by - #创建密码为空的用户,不用密码可以登录
示例:
create user 'test'@'%' identified by 'ios' #创建用户名为test,密码为ios的用户
3、查看执行的用户是否有放开授权的权限
select host,user,password,Grant_priv,Super_priv from mysql.user; #查看所有用户是否有授权的权限
#给root用户放开授权的权限并提交刷新生效,客户端执行的话,执行后要重新打开一个客户端才能开始授权
UPDATE mysql.user SET Grant_priv='Y', Super_priv='Y' WHERE User='root';
FLUSH PRIVILEGES; #提交刷新权限
4、用户授权
grant privileges on databasename.tablename to 'username'@'host' #给用户授权,授权后的用户无给其他用户授权的权限
或者
grant privileges on databasename.tablename to 'username'@'host' with grant option; #授权后的用户有给其他用户授权的权限
#privileges表示权限,如select,insert,update,delete,alter,drop,create,all
#databasename.tablename 表示授权的数据库名和表名,也可以是#databasename.*(所有表)或者*.*(所有库的所有表)
示例:
grant select,insert,update,delete,create,drop,alter on localmysql.* to 'test'@'%' #%表示所有可登录的ip
#把数据库localmysql所有表的增删改查权限赋给test,不限制登录ip
grant select,insert,update on localmysql.* to 'test'@'%' with grant option;
#with grant option表示授权后的用户能授权其他用户
grant select on localmysql.* to 'test'@'%' #%表示所有可登录的ip,表示只赋查询的权限给test用户
grant all on *.* to 'test'@'%' #表示把所有数据库和表的所有操作权限赋权给test
#all是所有权限,*.*是所有数据库和表,test表示数据库用户,%表示不限登录IP
注意:用以上命令授权的用户无权限给其它用户授权,如果想让该用户可以授权,用以下命令:
grant privileges on databasename.tablename to 'username'@'host' WITH GRANT OPTION;
示例:
grant all on *.* to 'test'@'%' with grant option; #授权后,用户test也有权限授权给其他用户权限
5、修改用户名或者用户密码
修改用户名:
update mysql.user set user='testing' where user='test';
FLUSH PRIVILEGES;
#修改非当前登录用户密码
set password for 'username'@'ip'=password('newpassword');
FLUSH PRIVILEGES;
示例:
set password for 'iosgd'@'%'=password('ios'); #把用户iosgd的密码修改为ios
FLUSH PRIVILEGES;
#修改当前登录用户密码
set password=password('newpassword');
示例:
set password=password('abc123'); #把当前登录的用户密码修改为abc123
6、撤销用户权限:
revoke privileges on databasename.tablename from 'username'@'host' #与授权是一样
示例:
revoke update,delete on localmysql.* from 'test'@'%'; #表示撤销test用户localmysql数据库所有表的修改、删除权限
revoke all on *.* from 'test'@'%' ; #表示撤销test用户所有数据库、表的所有操作权限
注意点:给用户授权了select某个数据库或表的select权限时,是无法撤销的
7、删除用户
drop user 'username'@'ip'; #删除用户
示例:
drop user 'test'@'%'; #删除用户test
参考博客:https://www.cnblogs.com/zeroone/articles/2298942.html
mysql新建数据库、新建用户及授权操作的更多相关文章
- MySQL/MariaDB数据库的用户和权限管理
MySQL/MariaDB数据库的用户和权限管理 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.元数据数据库(mysql) 系统授权表(均在mysql数据库中): db hos ...
- dotnetcore ef 调用多个数据库时用户命令执行操作报错
dotnetcore ef 调用多个数据库时用户命令执行操作报错 1.多个DbContext 时报错: 报错: More than one DbContext was found. Specify w ...
- oracle 数据库创建用户并授权
oracle 数据库创建用户并授权 备注: userName 为用户名,123456 为密码 drop user userName cascade; create user userName iden ...
- MySQL/MariaDB数据库的多表查询操作
MySQL/MariaDB数据库的多表查询操作 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.单表查询小试牛刀 [root@node105.yinzhengjie.org.cn ...
- mysql 创建数据库,添加用户,用户授权
一.创建mysql数据库 1.创建数据库语法 --创建名称为"testdb"数据库,并设定编码集为utf8 CREATE DATABASE IF NOT EXISTS testdb ...
- MySQL创建数据库与用户
root远程访问授权 mysql> SHOW DATABASES; +--------------------+ | Database | +---------------- ...
- mysql创建、删除用户与授权(linux測试)
注:我的执行环境是SUSE Linux + mysql5.6 一.创建用户: 命令:CREATE USER 'username'@'host' IDENTIFIED BY 'password'; ...
- Mysql创建数据库以及用户分配权限
一.创建mysql数据库 1.创建数据库语法 --创建名称为“testdb”数据库,并设定编码集为utf8 CREATE DATABASE IF NOT EXISTS testdb DEFAULT C ...
- mysql创建远程登陆用户并授权
在创建安装微擎的过程中,针对第四步 创建远程登陆用户并授权 > grant all PRIVILEGES on database.* to root@'127.0.0.1' id ...
随机推荐
- java maven通过SMTP发送QQ邮件的完全步骤
1.首先打开QQ邮箱的SMTP服务,因为QQ邮箱对于一般的用户都是默认关闭SMTP服务的. 找到SMTP服务的选项,可以看到此处默认是关闭的,点击开启,然后腾讯会进行一些身份验证,身份验证通过以后,腾 ...
- 单表40G,不要吃惊,还能往里面插入数据,哈哈
单表40G,不要吃惊,还能往里面插入数据,哈哈 上图:
- 史上最简单的 SpringCloud 教程 | 终章
https://blog.csdn.net/forezp/article/details/70148833转载请标明出处:http://blog.csdn.net/forezp/article/det ...
- Oracle null判断并替换空值
可用 NVL(), IFNULL() ,COALESCE(),DECODE() 函数 1.NVL() 从两个表达式返回一个非 null 值.语法NVL(eExpression1, eExpress ...
- Java编程的逻辑 (92) - 函数式数据处理 (上)
本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http:/ ...
- Android 获取外网IP,实测有效
网上有很多获取IP的例子,不过都是获取到的本地ip,还有的是因为走不通了,获取到的ip为空,下面看实测获取到外网IP的代码,注意需要在线程里面执行 /** * 获取外网的IP(要访问Url,要放到后台 ...
- Swing与AWT在事件模型处理上是一致的。
Swing与AWT在事件模型处理上是一致的. Jframe实际上是一堆窗体的叠加. Swing比AWT更加复杂且灵活. 在JDK1.4中,给JFRAME添加Button不可用jf.add(b).而是使 ...
- 通用 正则表达式 C# (.NET)Regex 总结
[参考]C#正则表达式Regex类的用法 语法: 1. new System.Text.RegularExpressions.Regex("\\$\\d{1,2}\\}"). ...
- springboot2.x版本整合redis(单机/集群)(使用lettuce)
在springboot1.x系列中,其中使用的是jedis,但是到了springboot2.x其中使用的是Lettuce. 此处springboot2.x,所以使用的是Lettuce.关于jedis跟 ...
- vMware 按装 MacOs
大概思路:1.vMware11 下载以管理员运行2.服务项按名称排序把四荐停止运行3.插件unlock 以管理员运行4.载入apple Mac os x 10.11文件5.打开虚拟机 wzfou如果报 ...