【转载】MySQL5.7 添加用户、删除用户与授权

mysql -uroot -proot

MySQL5.7 mysql.user表没有password字段改 authentication_string;

一. 创建用户:

命令:CREATE USER username‘@‘host‘ IDENTIFIED BY ‘password‘;

例子: CREATE USER dog‘@‘localhost‘ IDENTIFIED BY ‘123456‘;

CREATE USER ‘dog2‘@‘localhost‘ IDENTIFIED BY ‘‘;

PS:username - 你将创建的用户名,

host - 指定该用户在哪个主机上可以登陆,此处的"localhost",是指该用户只能在本地登录,不能在另外一台机器上远程登录,如果想远程登录的话,将"localhost"改为"%",表示在任何一台电脑上都可以登录;也可以指定某台机器可以远程登录;

password - 该用户的登陆密码,密码可以为空,如果为空则该用户可以不需要密码登陆服务器。

二.授权:

命令:GRANT privileges ON databasename.tablename TO ‘username‘@‘host‘

PS: privileges - 用户的操作权限,如SELECT , INSERT , UPDATE 等(详细列表见该文最后面).如果要授予所的权限则使用ALL.;databasename - 数据库名,tablename-表名,如果要授予该用户对所有数据库和表的相应操作权限则可用*表示, 如*.*.

例子: GRANT SELECT, INSERT ON mq.* TO ‘dog‘@‘localhost;

三.创建用户同时授权

mysql> grant all privileges on mq.* to [email protected] identified by ‘1234‘;
Query OK, 0 rows affected, 1 warning (0.00 sec)

mysql> flush privileges;
Query OK, 0 rows affected (0.01 sec)

PS:必须执行flush privileges; 

否则登录时提示:ERROR 1045 (28000): Access denied for user ‘user‘@‘localhost‘ (using password: YES ) 

四.设置与更改用户密码

命令:SET PASSWORD FOR ‘username‘@‘host‘ = PASSWORD(‘newpassword‘);

例子: SET PASSWORD FOR dog2‘@‘localhost‘ = PASSWORD("dog");

五.撤销用户权限

命令: REVOKE privilege ON databasename.tablename FROM ‘username‘@‘host‘;

说明: privilege, databasename, tablename - 同授权部分.

例子: REVOKE SELECT ON mq.* FROM dog2‘@‘localhost‘;

PS: 假如你在给用户‘dog‘@‘localhost授权的时候是这样的(或类似的):GRANT SELECT ON test.user TO ‘dog‘@‘localhost, 则在使用REVOKE SELECT ON *.* FROM ‘dog‘@‘localhost;命令并不能撤销该用户对test数据库中user表的SELECT 操作.相反,如果授权使用的是GRANT SELECT ON *.* TO ‘dog‘@‘localhost;则REVOKE SELECT ON test.user FROM ‘dog‘@‘localhost;命令也不能撤销该用户对test数据库中user表的Select 权限.

具体信息可以用命令SHOW GRANTS FOR ‘dog‘@‘localhost; 查看.

六.删除用户

命令: DROP USER ‘username‘@‘host‘;

七.查看用户的授权

mysql> show grants for [email protected];
+---------------------------------------------+
| Grants for [email protected] |
+---------------------------------------------+
| GRANT USAGE ON *.* TO ‘dog‘@‘localhost‘ |
| GRANT INSERT ON `mq`.* TO ‘dog‘@‘localhost‘ |
+---------------------------------------------+
2 rows in set (0.00 sec)

PS:GRANT USAGE:mysql usage权限就是空权限,默认create user的权限,只能连库,啥也不能干

【原文地址】https://www.cnblogs.com/xujishou/p/6306765.html

原文地址:https://www.cnblogs.com/xunzhiyou/p/8443573.html

时间: 2024-08-30 01:25:14

【转载】MySQL5.7 添加用户、删除用户与授权的相关文章

Ansible 从MySQL数据库添加或删除用户

mysql_user - 从MySQL数据库添加或删除用户. 概要 要求(在执行模块的主机上) 选项 例子 笔记 状态 支持 概要 从MySQL数据库添加或删除用户. 要求(在执行模块的主机上) MySQLdb的 选项 参数 需要 默认 选择 注释 append_privs (1.4 加入) no no yes no 将priv定义的权限附加到此用户的现有权限,而不是覆盖现有的权限. check_implicit_admin (1.3 加入) no no yes yes 检查mysql是否允许以

批量添加或删除用户

========================================================================================== #!/bin/bash # if [ ! $# -eq 1 ];then echo './user.sh --add|--del' exit 1 fi case "$1" in --add) for i in {1..10} do if id user$i &>/dev/null ;then

MySql中添加用户/删除用户

MySql中添加用户,新建数据库,用户授权,删除用户,修改密码(注意每行后边都跟个;表示一个命令语句结束): 1.新建用户 登录MYSQL: @>mysql -u root -p @>密码 创建用户: mysql> insert into mysql.user(Host,User,Password) values("localhost","test",password("1234")); 这样就创建了一个名为:test 密码为:

mysql、添加和删除用户、添加权限

创建用户 mysql>insert into mysql.user(Host,User,Password) values("localhost","test",password("1234")); 添加了一个username为test.password为1234用户.但该用户仅仅能在本地登陆,若想远程登陆的话可将localhost改为%表示不论什么一台电脑都能够登陆.或改为特定的ip表示仅仅能在特定的ip地址上登陆. 为用户加入权限 mys

centos添加和删除用户及 xxx is not in the sudoers file.This incident will be reported.的解决方法

1.添加用户,首先用adduser命令添加一个普通用户,命令如下: #adduser tommy //添加一个名为tommy的用户 #passwd tommy   //修改密码 Changing password for user tommy. New UNIX password:     //在这里输入新密码 Retype new UNIX password:  //再次输入新密码 passwd: all authentication tokens updated successfully.

Shell 脚本添加或删除用户及命令使用方法

Shell 要求:写一个脚本 一.添加10个用户user1到user10,密码同用户名,,若用户存在,但要求只有用户不存在的情况下才能添加,格式为/useradd.sh 解答思路:1.使用for 循环语句添加用户 user1 到user 10 2.判断用户是否存在,若存在,则echo 用户已存在 ,若不存在,添加用户 ,并设置密码与用户名相同 . 脚本: vim useradd.sh  并赋予+x权限. #!/bin/bash # for I in{1..10};do      if id us

自动添加和删除用户

#!/bin/bash # #添加10个用户user1到user10,密码同用户名:但要求只有在用户不存在的情况下才能添加; #删除10个用户user1到user10 if [ $# -lt 1 ];then echo "Usage:`basename $0` ARG" exit 7 fi if [ $1 == add ];then for I in {1..10};do if id user$I &> /dev/null then echo "the user

Ubuntu 添加或者删除用户

关于在Ubuntu系统中如何添加(或删除)用户和用户组,这里做了一些整理.常用的一些命令和参数如下: 1.建用户: adduser user1 //新建用户user1 passwd 12345 //给user1用户设置密码12345 2.建工作组 groupadd group1 //新建工作组group1 3.新建用户同时增加工作组 useradd -g group1 user1 //新建用户user1并增加到工作组group1 4.给已有的用户增加工作组 usermod -G groupnam

saltstack批量添加批量删除用户

批量添加用户 [[email protected] init]# cat useradds.sls{% set users = ['name1,name2'] %}{% for user in users %}{{ user }}:user.present:- shell: /bin/bash- home: /home/{{ user }}- password: '$1$sbvWg7.V$r/nWDs7g0YynB1CVsfUPA/'- groups:- {{ user }}- require:

shell脚本添加用户删除用户删除文件的脚本实现

#/bin/bash # DEBUG=0 ADD=0 DEL=0 RM=0 while [ $# -gt 0 ] do case $1 in -v|-verbose) DEBUG=1 shift ;; -h|--help) #帮助文档 echo "`basename $0` --add LIST --del LIST -h|--help --rm LIST" exit 0 ;; --add) #添加用户 ADD=1 ADDUSER=$2 shift 2 ;; --del) #删除用户