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新建数据库、新建用户及授权操作的更多相关文章

  1. MySQL/MariaDB数据库的用户和权限管理

    MySQL/MariaDB数据库的用户和权限管理 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.元数据数据库(mysql) 系统授权表(均在mysql数据库中): db hos ...

  2. dotnetcore ef 调用多个数据库时用户命令执行操作报错

    dotnetcore ef 调用多个数据库时用户命令执行操作报错 1.多个DbContext 时报错: 报错: More than one DbContext was found. Specify w ...

  3. oracle 数据库创建用户并授权

    oracle 数据库创建用户并授权 备注: userName 为用户名,123456 为密码 drop user userName cascade; create user userName iden ...

  4. MySQL/MariaDB数据库的多表查询操作

    MySQL/MariaDB数据库的多表查询操作 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.单表查询小试牛刀 [root@node105.yinzhengjie.org.cn ...

  5. mysql 创建数据库,添加用户,用户授权

    一.创建mysql数据库 1.创建数据库语法 --创建名称为"testdb"数据库,并设定编码集为utf8 CREATE DATABASE IF NOT EXISTS testdb ...

  6. MySQL创建数据库与用户

    root远程访问授权 mysql> SHOW DATABASES; +--------------------+ | Database           | +---------------- ...

  7. mysql创建、删除用户与授权(linux測试)

    注:我的执行环境是SUSE Linux + mysql5.6 一.创建用户:  命令:CREATE USER 'username'@'host' IDENTIFIED BY 'password';  ...

  8. Mysql创建数据库以及用户分配权限

    一.创建mysql数据库 1.创建数据库语法 --创建名称为“testdb”数据库,并设定编码集为utf8 CREATE DATABASE IF NOT EXISTS testdb DEFAULT C ...

  9. mysql创建远程登陆用户并授权

    在创建安装微擎的过程中,针对第四步 创建远程登陆用户并授权        > grant all PRIVILEGES on database.* to root@'127.0.0.1'  id ...

随机推荐

  1. 【Python】解析Python的缩进规则

    Python中的缩进(Indentation)决定了代码的作用域范围.这一点和传统的c/c++有很大的不同(传统的c/c++使用花括号花括号{}符决定作用域的范围:python使用缩进空格来表示作用域 ...

  2. 【C#】C#线程_基元线程的同步构造

    目录结构: contents structure [+] 简介 为什么需要使用线程同步 线程同步的缺点 基元线程同步 什么是基元线程 基元用户模式构造和内核模式构造的比较 用户模式构造 易变构造(Vo ...

  3. Spark性能优化指南——基础篇

    本文转自:http://tech.meituan.com/spark-tuning-basic.html 感谢原作者 前言 在大数据计算领域,Spark已经成为了越来越流行.越来越受欢迎的计算平台之一 ...

  4. go语言字符串的连接和截取

    字符串的连接: https://studygolang.com/articles/12281?fr=sidebar 字符串的截取: https://studygolang.com/articles/9 ...

  5. 解决mybatis generator无法覆盖XML

    今天发现mybatis generator maven plugin在重复生成的时候xml文件只会merge,不会覆盖. 明明在pom.xml中配置了如下: <configuration> ...

  6. 基金 、社保和QFII等机构的重仓股排名评测

    基金前15大重仓股持仓股排名 基金重仓前15大个股,相较于同期沪深300的平均收益, 近1月:2.45%, 近3月:10.0%, 近1年:11.22%, 近3年:105.23%. 1,中国平安(SH6 ...

  7. box-shadow比较美观的阴影

    无奈每次调阴影都特别丑,这次我把它记下来,下次不调了 box-shadow: 0 5px 15px -5px rgba(0,0,0,.5);

  8. pymysql操作mysql

    一.使用PyMySQL操作mysql数据库 适用环境 python版本 >=2.6或3.3 mysql版本>=4.1 安装 可以使用pip安装也可以手动下载安装.使用pip安装,在命令行执 ...

  9. kafka---->kafka stream的使用(一)

    kafka stream的简单使用,这里是官方文档上面的例子. kafka的简单使用 一.启动Kafka server huhx@gohuhx:~/server/kafka_2.11-1.1.0$ b ...

  10. phantomjs 是什么?----主要是mac下面

    phantomjs 是什么? PhantomJS是一个无界面的,可脚本编程的WebKit浏览器引擎.它原生支持多种web 标准:DOM 操作,CSS选择器,JSON,Canvas 以及SVG. pha ...