MySQL用户管理:添加用户、受权、删除用户

添加用户

以root用户登陆数据库,运行如下命令:html

create user zhangsan identified by 'zhangsan';

上面的命令建立了用户zhangsan,密码是zhangsan。在mysql.user表里能够查看到新增用户的信息:mysql

受权

命令格式:grant privilegesCode on dbName.tableName to username@host identified by "password";sql

grant all privileges on zhangsanDb.* to zhangsan@'%' identified by 'zhangsan'; flush privileges;

上面的语句将zhangsanDb数据库的全部操做权限都受权给了用户zhangsan。数据库

在mysql.db表里能够查看到新增数据库权限的信息:服务器

也能够经过show grants命令查看权限授予执行的命令:markdown

show grants for 'zhangsan';

privilegesCode表示授予的权限类型,经常使用的有如下几种类型[1]:app

  • all privileges:全部权限。
  • select:读取权限。
  • delete:删除权限。
  • update:更新权限。
  • create:建立权限。
  • drop:删除数据库、数据表权限。

dbName.tableName表示授予权限的具体库或表,经常使用的有如下几种选项:ide

  • .:授予该数据库服务器全部数据库的权限。
  • dbName.*:授予dbName数据库全部表的权限。
  • dbName.dbTable:授予数据库dbName中dbTable表的权限。

username@host表示授予的用户以及容许该用户登陆的IP地址。其中Host有如下几种类型:post

  • localhost:只容许该用户在本地登陆,不能远程登陆。
  • %:容许在除本机以外的任何一台机器远程登陆。
  • 192.168.52.32:具体的IP表示只容许该用户从特定IP登陆。

password指定该用户登陆时的面。spa

flush privileges表示刷新权限变动。

文章首发于【博客园-陈树义】,请尊重原创保留原文连接。

修改密码

运行如下命令能够修改用户密码

update mysql.user set password = password('zhangsannew') where user = 'zhangsan' and host = '%'; flush privileges;

删除用户

运行如下命令能够删除用户:

drop user zhangsan@'%';

drop user命令会删除用户以及对应的权限,执行命令后你会发现mysql.user表和mysql.db表的相应记录都消失了。

经常使用命令组

建立用户并授予指定数据库所有权限:适用于Web应用建立MySQL用户

create user zhangsan identified by 'zhangsan'; grant all privileges on zhangsanDb.* to zhangsan@'%' identified by 'zhangsan'; flush privileges;

建立了用户zhangsan,并将数据库zhangsanDB的全部权限授予zhangsan。若是要使zhangsan能够从本机登陆,那么能够多赋予localhost权限:

grant all privileges on zhangsanDb.* to zhangsan@'localhost' identified by 'zhangsan';

参考资料

相关文章
相关标签/搜索