当前位置:Gxlcms > 数据库问题 > MySQL创建用户与授权

MySQL创建用户与授权

时间:2021-07-01 10:21:17 帮助过:3人阅读

CURRENT_USER();

技术图片

CREATE USER 语法

CREATE USER [IF NOT EXISTS]
    user [auth_option] [, user [auth_option]] ...
    DEFAULT ROLE role [, role ] ...
    [REQUIRE {NONE | tls_option [[AND] tls_option] ...}]
    [WITH resource_option [resource_option] ...]
    [password_option | lock_option] ...

user:
    (see Section 6.2.4, “Specifying Account Names”)

auth_option: {
    IDENTIFIED BY auth_string
  | IDENTIFIED WITH auth_plugin
  | IDENTIFIED WITH auth_plugin BY auth_string
  | IDENTIFIED WITH auth_plugin AS hash_string
}

tls_option: {
   SSL
 | X509
 | CIPHER cipher
 | ISSUER issuer
 | SUBJECT subject
}

resource_option: {
    MAX_QUERIES_PER_HOUR count
  | MAX_UPDATES_PER_HOUR count
  | MAX_CONNECTIONS_PER_HOUR count
  | MAX_USER_CONNECTIONS count
}

password_option: {
    PASSWORD EXPIRE [DEFAULT | NEVER | INTERVAL N DAY]
  | PASSWORD HISTORY {DEFAULT | N}
  | PASSWORD REUSE INTERVAL {DEFAULT | N DAY}
  | PASSWORD REQUIRE CURRENT [DEFAULT | OPTIONAL]
}

lock_option: {
    ACCOUNT LOCK
  | ACCOUNT UNLOCK
}

user 即账户名称,语法是  ‘user_name‘@‘host_name‘ ,其中主机地址可以写为 ‘%‘表示接受任何地址的连接。

auth_option 即身份验证方式,可以指定密码以及认证插件(mysql_native_password、sha256_password、caching_sha2_password)。

tls_option 即加密连接选项

resource_option 即用户资源限制,比如每小时最大连接数

password_option 即密码额外的控制,比如设定失效时间

lock_option 账户锁定选项,由管理员上锁或者解锁(ACCOUNT LOCK | ACCOUNT UNLOCK)。

 

最简单的就是指定账户名+密码

CREATE USER jeffrey@localhost IDENTIFIED BY password;

 

加上认证插件

CREATE USER jeffrey@localhost IDENTIFIED WITH sha256_password BY password;

 

指定密码过期,以便用户第一次使用的时候需要修改密码

CREATE USER jeffrey@localhost IDENTIFIED BY new_password PASSWORD EXPIRE;

 

也可以指定每隔一段时间修改一次新密码

CREATE USER jeffrey@localhost IDENTIFIED BY new_password PASSWORD EXPIRE INTERVAL 180 DAY;

 

可以指定加密连接

-- 不使用加密连接
CREATE USER jeffrey@localhost REQUIRE NONE;
-- 使用加密连接
CREATE USER jeffrey@localhost REQUIRE SSL;
-- 使用加密连接,并要求客户端提供有效证书
CREATE USER jeffrey@localhost REQUIRE X509;

CREATE USER jeffrey@localhost REQUIRE ISSUER CA颁发的有效X.509证书;

CREATE USER jeffrey@localhost REQUIRE SUBJECT 包含主题的有效X.509证书;

CREATE USER jeffrey@localhost REQUIRE CIPHER 指定的加密方法;

 

可以指定资源控制

-- 单位小时内,账户被允许查询500次,更新100次,单位小时内最大连接数不限制。最大并发连接数不限制
CREATE USER jeffrey@localhost WITH MAX_QUERIES_PER_HOUR 500 MAX_UPDATES_PER_HOUR 100 MAX_CONNECTIONS_PER_HOUR 0 MAX_USER_CONNECTIONS 0

 

可以锁定账户

-- 锁定
CREATE USER jeffrey@localhost ACCOUNT LOCK
-- 解锁
ALTER USER jeffrey@localhost ACCOUNT UNLOCK

 

最后完整的命令选项大概这个样子

CREATE USER user_name@host_name IDENTIFIED [WITH auth_plugin] BY auth_string [REQUIRE NONE(SSL,X509)] [WITH MAX_QUERIES_PER_HOUR count | MAX_UPDATES_PER_HOUR count | MAX_CONNECTIONS_PER_HOUR count | MAX_USER_CONNECTIONS count] [PASSWORD EXPIRE] [ACCOUNT LOCK]

 

ALTER USER语法

ALTER USER [IF EXISTS]
    user [auth_option] [, user [auth_option]] ...
    [REQUIRE {NONE | tls_option [[AND] tls_option] ...}]
    [WITH resource_option [resource_option] ...]
    [password_option | lock_option] ...

ALTER USER [IF EXISTS] USER() user_func_auth_option

ALTER USER [IF EXISTS]
    user DEFAULT ROLE
    {NONE | ALL | role [, role ] ...}

user:
    (see Section 6.2.4, “Specifying Account Names”)

auth_option: {
    IDENTIFIED BY auth_string
        [REPLACE ‘current_auth_string‘]
        [RETAIN CURRENT PASSWORD]
  | IDENTIFIED WITH auth_plugin
  | IDENTIFIED WITH auth_plugin BY auth_string
        [REPLACE ‘current_auth_string‘]
        [RETAIN CURRENT PASSWORD]
  | IDENTIFIED WITH auth_plugin AS auth_string
  | DISCARD OLD PASSWORD
}

user_func_auth_option: {
    IDENTIFIED BY auth_string
        [REPLACE ‘current_auth_string‘]
        [RETAIN CURRENT PASSWORD]
  | DISCARD OLD PASSWORD
}

tls_option: {
   SSL
 | X509
 | CIPHER cipher
 | ISSUER issuer
 | SUBJECT subject
}

resource_option: {
    MAX_QUERIES_PER_HOUR count
  | MAX_UPDATES_PER_HOUR count
  | MAX_CONNECTIONS_PER_HOUR count
  | MAX_USER_CONNECTIONS count
}

password_option: {
    PASSWORD EXPIRE [DEFAULT | NEVER | INTERVAL N DAY]
  | PASSWORD HISTORY {DEFAULT | N}
  | PASSWORD REUSE INTERVAL {DEFAULT | N DAY}
  | PASSWORD REQUIRE CURRENT [DEFAULT | OPTIONAL]
}

lock_option: {
    ACCOUNT LOCK
  | ACCOUNT UNLOCK
}

选项和创建的差不多,这里不做解释了。

修改自己当前的密码

ALTER USER USER() IDENTIFIED BY ‘new_password;

 

修改账户密码

ALTER USER jeffrey@localhost IDENTIFIED BY new_password;

 

修改认证插件

ALTER USER jeffrey@localhost IDENTIFIED WITH mysql_native_password;

 

修改密码和插件

ALTER USER jeffrey@localhost IDENTIFIED WITH mysql_native_password BY new_password;

 

修改角色

-- 授予自定义角色
ALTER USER jeffrey@localhost DEFAULT ROLE your_role_name;
-- 无角色
ALTER USER jeffrey@localhost DEFAULT ROLE NONE;
-- 所有角色
ALTER USER jeffrey@localhost DEFAULT ROLE ALL;

 

修改加密方式

-- 只有账户密码正确,无须加密连接
ALTER USER jeffrey@localhost REQUIRE NONE;
-- 需要加密连接
ALTER USER jeffrey@localhost REQUIRE SSL;
...

 

修改资源访问

-- 单位小时内,最大查询数量和更新数量
ALTER USER jeffrey@localhost WITH MAX_QUERIES_PER_HOUR 500 MAX_UPDATES_PER_HOUR 100;

 

指定密码过期

ALTER USER jeffrey@localhost PASSWORD EXPIRE;

 

修改锁定解锁

ALTER USER jeffrey@localhost ACCOUNT LOCK;
ALTER USER jeffrey@localhost ACCOUNT UNLOCK;

 

GRANT语法

GRANT
    priv_type [(column_list)]
      [, priv_type [(column_list)]] ...
    ON [object_type] priv_level
    TO user_or_role [, user_or_role] ...
    [WITH GRANT OPTION]
    [AS user
        [WITH ROLE
            DEFAULT
          | NONE
          | ALL
          | ALL EXCEPT role [, role ] ...
          | role [, role ] ...
        ]
    ]
}

GRANT PROXY ON user_or_role
    TO user_or_role [, user_or_role] ...
    [WITH GRANT OPTION]

GRANT role [, role] ...
    TO user_or_role [, user_or_role] ...
    [WITH ADMIN OPTION]

object_type: {
    TABLE
  | FUNCTION
  | PROCEDURE
}

priv_level: {
    *
  | *.*
  | db_name.*
  | db_name.tbl_name
  | tbl_name
  | db_name.routine_name
}

user_or_role: {
    user
  | role
}

user:
    (see Section 6.2.4, “Specifying Account Names”)

role:
    (see Section 6.2.5, “Specifying Role Names”)

GRANT语法使得管理员能够授予账户权限或者角色,但是GRANT不能再一个语句中同时授予权限和角色。

  • 有ON,是授予权限
  • 无ON,是授予角色
-- 授予数据库db1的所有权限给指定账户
GRANT ALL ON db1.* TO jeffrey@localhost;
-- 授予角色给指定的账户
GRANT role1, role2 TO user1@localhost, user2@localhost;
-- 授予数据库world的SELECT权限给指定的角色
GRANT SELECT ON world.* TO role3;

 

 基本语法

GRANT [权限] ON [数据库名].[表名] TO user_name@localhost ...;
-- 授予所有数据库的权限
GRANT [权限] ON *.* TO user_name@localhost ...;

 

注:全局权限是管理或适用于给定服务器上的所有数据库。要分配全局权限,请使用 ON *.*语法

下面是权限列表

技术图片 

权限范围示例

-- 数据库权限
GRANT ALL ON mydb.* TO user_name@host_name;
-- 表权限
GRANT ALL ON mydb.mytable TO user_name@host_name;
-- 列权限
GRANT SELECT (col1), INSERT (col1, col2) ON mydb.mytable TO user_name@host_name;

-- 存储过程权限
GRANT CREATE ROUTINE ON mydb.* TO user_name@host_name;
GRANT EXECUTE ON PROCEDURE mydb.myproc TO user_name@host_name;

 

MySQL创建用户与授权

标签:列表   技术   简单   数据   ide   alt   控制   option   hash   

人气教程排行