一、授权语法格式 
grant 权限列表 on 数据库名.表名 to '用户名'@'客户端主机' [identified by '密码'];

单词: privileges [ˈprivilidʒz] 权限
单词: identified [aɪ'dentɪfaɪd] 认出( identify的过去式和过去分词 ),身份验证

@ 权限列表:
all 所有权限(不包括授权权限)
select,update 查询,更新权限
select(name,address) 只查询name,address字段的权限
create create权限

@ 数据库.表名:
*.* 所有库下的所有表
web.* web库下的所有表
web.stu_info web库下的stu_info表

@ 客户端主机:
% 所有主机
192.168.2.168 主机
192.168.2.% 192.168.2.0网段的所有主机

二、登录MySQL主(master)数据库服务器
1.直接登录到主机的某个数据库中(如:zyyshop数据库)
[root@CentOS5 ~]# /usr/local/mysql/bin/mysql -uroot -p123456 zyyshop
mysql>

2.登录主机:隐式输入密码,进入之后再选择数据库
[root@CentOS5 ~]# /usr/local/mysql/bin/mysql -uroot -p
Enter password:
mysql> use zyyshop

三、用户授权
1.向主(master)数据库创建授权用户slave1,使之可由从任何主机(%)登录到主(master)服务器

mysql> grant all on *.* to 'slave1'@'%' identified by '123';

@ 权限列表: all 所有权限(其中,关键字 “privileges” 可以省略)
@ 数据库.表名:*.* 所有库的所有表
@ 授权用户: slave1
@ 客户端主机: % 所有主机
@ 登录密码: 123

2.向主(master)数据库创建授权用户slave2,使之可由从主机(192.168.137.%)登录到主(master)服务器:

mysql> grant select(name,classid),insert on zyyshop.stu to 'slave2'@'192.168.137.%' identified by '456';

@ 权限列表: select(name,classid),insert
@ 数据库.表名:zyyshop.stu 即zyyshop数据库的stu表
@ 授权用户: slave2
@ 客户端主机: 192.168.137.0网段的所有主机
@ 登录密码: 456

3.向主(master)数据库创建授权用户slave3,使之可由从主机(192.168.137.202)登录到主(master)服务器:

mysql> grant all on zyyshop.stu to 'slave3'@'192.168.137.202' identified by '789';

@ 权限列表: all 所有权限
@ 数据库.表名:zyyshop.stu 即zyyshop数据库的stu表
@ 授权用户: slave3
@ 客户端主机: 192.168.137.202
@ 登录密码: 789

4.刷新授权表
mysql> flush privileges;

总结: 1.不要使用系统自带的test数据库做实验,这是个开放测试库对权限设置通常不起作用致实验不成功,应该自己建立一个库。
2.对用户授权之后,会在mysql数据库的 mysql.user 表里存储当前用户信息;在 mysql.columns_priv 表里存储详细的权限字段;
3.grant, revoke 用户权限调整后,如果发现没有生效可尝试重新连接并登录MySQL主机。
4.如果想让被授权的用户可以将“获得的权限”也授予其他用户,需要加选项 “with grant option”(通常很少这样用,一般是DBA自个搞定授权)
@ user1还可以将获得的 testdb.stu 的 select,update 权限授权其它用户
mysql> grant select,update on testdb.stu to 'user1'@'localhost' with grant option;

四、客户端登录

# /usr/local/mysql/bin/mysql -uslave3 -p789 -h192.168.137.201 zyyshop

@ 用户名: slave3
@ 密码: 789
@ 主服务器地址: 192.168.137.201
@ 数据库名: zyyshop

五、查看权限
1.用户远程用户登录后,查看自己当前的权限(只能查看自己的权限):
mysql> show grants;

2.主(master)数据库的管理员DBA,查看系统中任一用户的权限列表(DBA用的操作命令)
@ 查看slave2用户的权限情况:
mysql> show grants for 'slave3'@'192.168.137.202';

六、收回权限
格式:revoke {权限列表} on {数据库名} from '用户名'@'客户端主机'

mysql> revoke all on *.* from 'slave1'@'%'; //收回 slave1 所有权限
mysql> revoke select(classid) on zyyshop.stu from 'slave2'@'192.168.137.%'; //收回 slave2 对stu表classid的查询权限

注: 1.权限收回之后,但对应的用户仍然存在于mysql.user表中;
2.如果只删除用户,不会删除用户的权限,权限记录仍存于msyql.columns_priv表中;
mysql> delete from mysql.user where user='slave3' and host='192.168.137.202'; //从用户表中删除
mysql> delete from msyql.columns_priv where user='slave3'; //从字段权限明细表中删除

七、修改密码
@ 用户自己修改自己的密码
mysql> set password=password('123456');

@ DBA管理员为用户修改密码1:
mysql> set password for 'slave3'@'192.168.137.202' = password('123');

@ DBA管理员为用户修改密码2:
mysql> update mysql.user set password = password('123') where host='192.168.137.202' and user='slave1';

刷新授权表:
mysql> flush privileges;

MySQL用户授权的更多相关文章

  1. mysql用户授权、数据库权限管理、sql语法详解

    mysql用户授权.数据库权限管理.sql语法详解 —— NiceCui 某个数据库所有的权限 ALL 后面+ PRIVILEGES SQL 某个数据库 特定的权限SQL mysql 授权语法 SQL ...

  2. MySQL用户授权 和 bin-log日志 详解和实战(http://www.cnblogs.com/it-cen/p/5234345.html)

    看 了上一篇博文的发布时间,到目前已经有三个月没更新博文了.这三个月经历了很多事情,包括工作.生活和感情等等.由于个人发展的原因,这个月准备换工作 啦.在这段时间,我会把Web大型项目中所接触到的技术 ...

  3. MySQL用户授权 和 bin-log日志 详解和实战

    看了上一篇博文的发布时间,到目前已经有三个月没更新博文了.这三个月经历了很多事情,包括工作.生活和感情等等.由于个人发展的原因,这个月准备换工作啦.在这段时间,我会把Web大型项目中所接触到的技术都总 ...

  4. mysql用户授权及数据备份恢复

    用户授权与权限撤销 修改数据库管理员从本机登陆的密码测试: mysqladmin -hlocalhost -uroot -p password "新密码" Enter passwo ...

  5. MySQL用户授权【转】

    MySQL 赋予用户权限命令的简单格式可概括为:grant 权限 on 数据库对象 to 用户 一.grant 普通数据用户,查询.插入.更新.删除 数据库中所有表数据的权利. grant selec ...

  6. mysql用户授权以及权限收回

    语法 GRANT privileges [(columns)] ON DATABASE.TABLE TO 'username'@'hostname' [IDENTIFIED BY [PASSWORD] ...

  7. MySQL用户授权与权限

    MySQL权限如下表 权限名字 权限说明 Context CREATE 允许创建新的数据库和表 Databases, tables, or indexes DROP 允许删除现有数据库.表和视图 Da ...

  8. mysql 用户授权命令

    mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'your_root_password' WITH GRANT OP ...

  9. python mysql 视图 触发器 事物 存储过程 用户授权 数据备份还原

    ###################总结########### 视图是一个虚拟表(非真实存在) 是跑在内存中的表,真实表是在硬盘上的表 使用视图我们可以把查询过程中的临时表摘出来,保存下来,用视图去 ...

随机推荐

  1. Karma与TSLint

    TSLint TSLint是一个可扩展的静态分析工具,用于检查TypeScript代码的可读性,可维护性和功能性错误.收到现代编辑和构建系统的广泛支持,并且可以使用您自己的路由,配置和格式化. 安装 ...

  2. .net core 部署 Docker 所遇到的几个问题

    1.Connection reset by peer 造成这个问题的主要原因是在program.cs 文件中,未加入端口: public static IWebHostBuilder CreateWe ...

  3. Python爬虫初探 - selenium+beautifulsoup4+chromedriver爬取需要登录的网页信息

    目标 之前的自动答复机器人需要从一个内部网页上获取的消息用于回复一些问题,但是没有对应的查询api,于是想到了用脚本模拟浏览器访问网站爬取内容返回给用户.详细介绍了第一次探索python爬虫的坑. 准 ...

  4. TensorFlow(实战深度学习框架)----深层神经网络(第四章)

    深层神经网络可以解决部分浅层神经网络解决不了的问题. 神经网络的优化目标-----损失函数 深度学习:一类通过多层非线性变化对高复杂性数据建模算法的合集.(两个重要的特性:多层和非线性) 线性模型的最 ...

  5. selenium自动化之元素高亮显示

    目的: 在UI自动化的时候,有时候我们需要查看运行的过程.为了更好的显示这个过程,可以进行元素高亮,以显眼的颜色来提示测试人员目前的操作在哪一步. 解决办法: 使用js代码来将元素的背景颜色和边框颜色 ...

  6. AWS探索及创建一个aws EC2实例

    一.AWS登陆 1.百度搜索aws,或者浏览器输入:http://aws.amazon.com 2.输入账户及密码登陆(注册流程按照提示走即可) 二.创建EC2实例(相当于阿里云的ecs) 1.找到E ...

  7. Java EE JSP编程基础

    一.JSP编程介绍 JSP是实现普通静态HTML和动态HTML混合编码的技术,可以说是Servlet的一种变形,相比Servlet它更像普通的Web页面.JSP在第一次运行时会花费很长时间,原因在与其 ...

  8. Phaser3 屏幕适配iPhoneX、iPhoneXs的坑 -- JavaScript Html5 游戏开发

      PhaserJS 坑:在config内不要把 width 设为 window.innnerWidth在config内不要把 width 设为 window.innnerWidth在config内不 ...

  9. eos TODO EOS区块链上EOSJS和scatter开发dApp

    由于我一直在深入研究EOS dApp的开发,我看了不少好文章.在这里,我汇总了下做一些研究后得到的所有知识.在本文中,我将解释如何使用EOSJS和scatter.我假设你对智能合约以及如何在EOS区块 ...

  10. “Hello World!团队”Beta发布—视频链接+文案+美工

    视频链接:http://v.youku.com/v_show/id_XMzE3MjEyMzkyMA==.html?spm=a2h3j.8428770.3416059.1 文案+美工:http://ww ...