zoukankan      html  css  js  c++  java
  • mysql权限管理

    mysql权限管理

    MySQL的权限系统围绕着两个概念:

    1:认证->确定用户是否允许连接数据库服务器

    2:授权->确定用户是否拥有足够的权限执行查询请求等。

    显然从上面可知,如果认证不成功的话,哪么授权肯定是无法进行的。在这里我们要关注两个表,分别是在MySQL数据库中user表和db表。

    user表在某种程度上是独一无二的,因为它是唯一一个在权限请求的认证和授权阶段都起作用的表,也是唯一一个存MySQL服务器相关权限的权限表。在认证阶段,它只是负责为用户授权访问MySQL服务器,确定用户每小时的最大连接数和最大并发数;在授权阶段,user确定允许访问服务器的用户是否被赋予了操作数据库的全局权限,确定用户每小时的最大查询数和更新数。

    db表用于为每个用户针对每个数据库赋予权限。具体的可以查看db的字段。

    用户和权限管理命令:

    create user :用于创建新的用户账户(从5.0版本开始有这个命令),在创建这个用户的时候不分配任何权限,需要在创建之后通过grant命令来给改用户分配相应的权限。

    eg

    create user guest@localhost identified by '123456'

    grant select on mydb.* to guest@localhost;

    drop user:删除一个用户账户(注意在4.1.1版本之前只能删除没有任何权限的账户,5.0.2之后可以删除任何账户)

    egdrop user guest;

    rename user:可以实现重命名一个用户账号。

    grant:用于管理访问权限,也就是给用户账号授权。当然它同样可以创建一个新的用户账户。

    eggrant select, insert, update, delete on new_db.* to guest@'%' identified by '88888888';

    grant 权限 on 数据库.to 用户 @ 访问方式 identified by 密码

    grant select on mydb.* to guest@localhost identified by '123456';

    BTW:如果需要一个空密码或者无密码的账户,必须先用Create User命令,然后通过grant来分配权限。如果如下操作:

    grant all privileges on mydb.* to visitor@'%' ;而在数据库user表中没有先创建visitor 用户,则会发生1133错误"Can't find any matching row in the user table"grant只能创有密码的账户。

    revoke:删除一个账户,具体查看MySQL的文档。

    原文

    http://www.cnblogs.com/yangy608/archive/2011/01/22/1942099.html

  • 相关阅读:
    linux上java和golang环境变量的设置
    MySQL踩坑及MySQL解压版安装
    Mysql踩坑 自动更新的时间只允许有一个
    从零开始学习PYTHON3讲义(十五)让画面动起来
    从零开始学习PYTHON3讲义(十四)写一个mp3播放器
    从零开始学习PYTHON3讲义(十三)记事本的升级版:网络记事本
    从零开始学习PYTHON3讲义(十二)画一颗心送给你
    从零开始学习PYTHON3讲义(十一)计算器升级啦
    从零开始学习PYTHON3讲义(十)自己做一个“电子记事本”
    从零开始学习PYTHON3讲义(九)字典类型和插入排序
  • 原文地址:https://www.cnblogs.com/mydomain/p/3168730.html
Copyright © 2011-2022 走看看