MySQL基础关键_013_常用 DBA 命令

目 录

[一、MySQL 用户信息存储位置](#一、MySQL 用户信息存储位置)

二、新建用户

1.创建本地用户

2.创建外网用户

三、用户授权

1.说明

2.实例

四、撤销授权

五、修改用户密码

六、修改用户名、主机名/IP地址

七、删除用户

八、数据备份

1.导出数据

2.导入数据

(1)方式一

(2)方式二


一、MySQL 用户信息存储位置

存储在 mysql 数据库下的 user 表内。

sql 复制代码
-- 展示数据库
 show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
5 rows in set (0.00 sec)

-- 使用 mysql 数据库
use mysql;

-- 展示表
show tables;

-- 查询 user 表信息
select user, host from user;
+------------------+-----------+
| user             | host      |
+------------------+-----------+
| mysql.infoschema | localhost |
| mysql.session    | localhost |
| mysql.sys        | localhost |
| root             | localhost |
+------------------+-----------+
4 rows in set (0.00 sec)

二、新建用户

1.创建本地用户

sql 复制代码
-- 创建用户名为"java01",密码为"javagood"的本地用户
create user 'java01'@'localhost' identified by 'javagood';

2.创建外网用户

sql 复制代码
-- 创建用户名为"java02",密码为"javagood"的外网用户
create user 'java02'@'%' identified by 'javagood';

三、用户授权

1.说明

  1. 语法格式 :【grant[权限1, 权限2,...] on 数据库名.表名 to '用户名'@'主机名/IP地址';】;
  2. 权限
    1. 所有权限:all privileges;
    2. 细粒度权限:select、insert、update、delete、create、alert、drop、index、usage(登录权限)、reload。
  3. 数据库名和表名可以使用【*】,分别代表:所有数据库、所有表;
  4. 授权后,使用【flush privileges刷新权限
  5. 查看某用户权限:【show grants for '用户名'@'主机名/IP地址';】;
  6. 允许被授权用户再为其他用户授权 :【grant[权限1, 权限2,...] on 数据库名.表名 to '用户名'@'主机名/IP地址' with grant option;】。

2.实例

sql 复制代码
-- 为"java01"用户授予对所有库、表的"select、insert、update、delete、create"权限
grant select, insert, update, delete, create on *.* to 'java01'@'localhost';

-- 刷新权限
flush privileges;

-- 查看"java01"的权限
show grants for 'java01'@'localhost';

四、撤销授权

  1. 语法格式:【revoke [权限1, 权限2,...] on 数据库名.表名 from '用户名'@'主机名/IP地址';】;
  2. 撤销后,使用【flush privileges刷新权限
  3. 撤销时的数据库名和表名需要与授权时一致。
sql 复制代码
-- 撤销"java01"的 create 和 delete 权限
revoke create, delete on *.* from 'java01'@'localhost';

-- 刷新权限
flush privileges;

-- 查看"java01"的权限
show grants for 'java01'@'localhost';

五、修改用户密码

  1. MySQL 8 语法格式:【alter user '用户名'@'主机名/IP地址' identified by '新密码';】;
  2. 修改密码后,使用【flush privileges刷新权限。
sql 复制代码
-- 将"java01"的密码修改为"123"
alter user 'java01'@'localhost' identified by '123';

-- 刷新权限
flush privileges;

六、修改用户名、主机名/IP地址

  1. 语法格式:【rename user '原用户名'@'主机名/IP地址' to '新用户名'@'主机名/IP地址';】;
  2. 修改用户名后,使用【flush privileges刷新权限。
sql 复制代码
-- 修改"java01"用户名为"jason"
rename user 'java01'@'localhost' to 'jason'@'localhost';

-- 刷新权限
flush privileges;

七、删除用户

  1. 语法格式:【drop user '用户名'@'主机名/IP地址';】;
  2. 删除用户后,使用【flush privileges刷新权限。
sql 复制代码
-- 删除"java02"和"jason"用户
drop user "java02"@"%";
drop user "jason"@"localhost";

-- 刷新权限
flush privileges;

八、数据备份

1.导出数据

  1. 登录 MySQL 之前操作
  2. 语法格式 :【mysqldump 数据库名 表名 > 路径+文件名.sql -u用户名 -p密码 --default-character-set=utf8】;
  3. 导出数据库中的全部表,则不写表名。
sql 复制代码
-- 导出 test 数据库中的全部表
mysqldump test > D:/test.sql -uroot -proot --default-character-set=utf8

-- 为保证之后的导入,在此处先删除 MySQL 内的 test 数据库
drop database if exists test;

2.导入数据

(1)方式一

  1. 登录 MySQL 之前操作
  2. 需要事前建立好对应数据库;
  3. 语法格式 :【mysql 数据库名 < 路径+文件名.sql -u用户名 -p密码 --default-character-set=utf8】。
sql 复制代码
-- 事先在 MySQL 内建立 test 空白数据库
create database test;

-- 然后退出 MySQL 
quit

-- 导入 test.sql
mysql test < D:/test.sql -uroot -proot --default-character-set=utf8

-- 为保证之后的导入,在此处先删除 MySQL 内的 test 数据库
drop database if exists test;

(2)方式二

  1. 登录 MySQL 之后操作
  2. 语法格式:【source 路径+文件名.sql;】。
sql 复制代码
-- 创建 test 空白数据库
create database test;

-- 使用 test
use test

-- 导入 test.sql
source D:/test.sql;
相关推荐
赵文宇2 小时前
站在MySQL肩膀上快速入门PostgreSQL,开源社区最喜爱的关系数据库
mysql·postgresql
wei_shuo2 小时前
全场景自动化 Replay 技术:金仓 KReplay 如何攻克数据库迁移 “难验证“ 难题
数据库·自动化·king base
葡萄城技术团队2 小时前
打破误解!MongoDB 事务隔离级别深度实测:快照隔离竟能防住 8 种异常?
数据库
Gold Steps.2 小时前
数据库正常运行但是端口变成了0?
数据库·mysql
杂亿稿2 小时前
增删改查操作
数据库
Code_Geo2 小时前
在postgres数据库中Postgres FDW 全面详解
数据库·fdw
QT 小鲜肉2 小时前
【个人成长笔记】将Try Ubuntu里面配置好的文件系统克隆在U盘上(创建一个带有持久化功能的Ubuntu Live USB系统)
linux·开发语言·数据库·笔记·ubuntu
LWy6104262 小时前
数据库库、表的创建及处理
数据库
Jay_Franklin2 小时前
Python中使用sqlite3模块和panel完成SQLite数据库中PDF的写入和读取
数据库·笔记·python·pycharm·sqlite·pdf·py
愤怒的苹果ext3 小时前
MySQL JSON查询与索引
mysql·json·虚拟列·多值索引