# 用户创建、权限、删除操作
## 连接MySQL操作
> **mysql -h 主机地址 -u 用户名 -p 用户密码**
> 注:-u与root可以不用加空格,其它参数也一样。
### DEMO
打开电脑CMD,输入
```
mysql -h 127.0.0.1 -u root -p
```
回车,然后输入密码。就可以连接到本地的MySQL数据库。
![](https://box.kancloud.cn/2016-03-13_56e52e104a53b.png)
## 创建MySQL用户
> **CREATE USER 'username'@'host' IDENTIFIED BY 'password';**
**说明**
1. username - 你将创建的用户名,
2. host - 指定该用户在哪个主机上可以登陆,如果是本地用户可用localhost, 如果想让该用户可以从任意远程主机登陆,可以使用通配符%.
3. password - 该用户的登陆密码,密码可以为空,如果为空则该用户可以不需要密码登陆服务器。
### DEMO
```
CREATE USER 'test'@'localhost' IDENTIFIED BY '123456';
CREATE USER 'test'@'192.168.1.101_' IDENDIFIED BY '123456';
CREATE USER 'test'@'%' IDENTIFIED BY '123456';
CREATE USER 'test'@'%' IDENTIFIED BY '';
CREATE USER 'test'@'%';
```
![](https://box.kancloud.cn/2016-03-13_56e52e1063377.png)
## 授权用户操作权限
> **GRANT privileges ON databasename.tablename TO 'username'@'host';**
1. privileges - 用户的操作权限,如SELECT , INSERT , UPDATE 等(详细列表见该文最后面).如果要授予所的权限则使用ALL.;
2. databasename - 数据库名;
3. tablename-表名,如果要授予该用户对所有数据库和表的相应操作权限则可用*表示, 如*.*。
### DEMO
```
GRANT SELECT, INSERT ON school.* TO 'test' @'%';
GRANT ALL ON *.* TO 'test'@'%';
```
> 用以上命令授权的用户不能给其它用户授权,如果想让该用户可以授权,用以下命令:
> GRANT privileges ON databasename.tablename TO 'username'@'host' **WITH GRANT OPTION;**
## 撤销用户权限
> **REVOKE privilege ON databasename.tablename FROM 'username'@'host';**
1. privileges - 用户的操作权限,如SELECT , INSERT , UPDATE 等(详细列表见该文最后面).如果要授予所的权限则使用ALL.;
2. databasename - 数据库名;
3. tablename-表名,如果要授予该用户对所有数据库和表的相应操作权限则可用*表示, 如*.*。
### DEMO
~~~
REVOKE SELECT ON *.* FROM 'test'@'%';
~~~
> 假如你在给用户'test'@'%'授权的时候是这样的(或类似的):`GRANT SELECT ON test.user TO 'test'@'%'`, 则在使用`REVOKE SELECT ON *.* FROM 'test'@'%'`;命令并不能撤销该用户对test数据库中user表的SELECT 操作;
> 相反,如果授权使用的是`GRANT SELECT ON *.* TO 'test'@'%'`;则`REVOKE SELECT ON test.user FROM 'test'@'%'`;命令也不能撤销该用户对test数据库中user表的SELECT权限。
另外 具体信息可以用命令`SHOW GRANTS FOR 'test'@'%';`查看。
## 设置与更改用户密码
> **SET PASSWORD FOR 'username'@'host' = PASSWORD('newpassword');**
> **SET PASSWORD = PASSWORD("newpassword");** # 如果是当前登陆用户
### DEMO
```
SET PASSWORD FOR 'test'@'%' = PASSWORD("aaaaaa");
```
![](https://box.kancloud.cn/2016-03-13_56e52e1092f7b.png)
## 删除用户
>**DROP USER 'username'@'host';**
- 写在前面
- MySQL的使用
- MySQL多表同时删除方案
- MySQL跨表、多表更新SQL语句总结
- MySQL存储引擎
- 安装
- 常规方式编译安装MySQL
- 采用cmake方式编译安装MySQL
- 使用rpm包安装MySQL
- 使用yum方式安装MySQL
- 采用二进制方式免编译安装MySQL
- 多实例的安装
- 什么是多实例
- 多实例的作用、问题以及应用场景
- 多实例安装01【推荐】
- 多实例官方安装方案02
- 启动、用户和权限管理
- 单实例MySQL的启动和关闭的方法
- 设置及修改MySQL root用户密码
- 找回丢失的MySQL root用户密码
- 创建MySQL用户及用户权限管理
- 基础命令的操作
- MySQL库和表相关操作
- MySQL中的索引操作
- MySQL常用命令
- MySQL的错误代码
- MySQL复习秘籍
- 备份与恢复
- 备份
- 恢复
- mysqlbinlog命令
- 服务日志
- 主从复制
- 主从复制部署配置问题汇总
- 主从复制读写分离
- 灾难恢复
- 配置phpmyadmin连接多实例MySQL
- 其他相关
- Sphinx实验
- 中文分词技术
- MySQL语句大全
- 用户创建、权限、删除
- 数据库与表显示、创建、删除
- 表复制及备份还原
- 数据库表中数据操作
- 修改表的列与表名
- 修改表中的数据
- 查询表
- 日志
- 批量修改Mysql表引擎为InnoDB的方法
- 数据库抽象层 PDO
- PDO对象常用方法
- PDO 事务处理
- PDO 与 MySQLi 二者效率简单比较
- 大小写敏感性 lower_case_table_names
- CentOS7安装MySQL5.7密码查看与修改