MySQL数据库管理员(DBA)

文章目录

数据库管理员 (DBA)

新建用户

sql 复制代码
创建本地用户
create user '用户名'@'localhost' identified by '密码'

创建外网用户
create user '用户名'@'%' identified by '密码';

默认没有任何权限


使用 root 用户查看系统中当前用户有哪些

sql 复制代码
select user, host from mysql.user


给用户授权

sql 复制代码
授权语法
GRANT 权限,权限2... on 库名.表名 to '用户名'@'主机名/ip地址'

给本地用户授权
grant 权限1,权限2... on 库名.表名 to '用户名'@'localhost'/127.0.0.1;

给外网用户授权
grant [权限1,权限2...] on 库名.表名 to '用户名'@'外网ip';
外网ip如果是%: 这个用户可以从任何地方连接到数据库服务器

权限:
所有权限:all privileges

单个权限:select、insert、delete、update、alter、create、drop、index(索引)、usage(登录权限)......

库名可以使用 * ,它代表所有数据库
表名可以采用 * ,它代表所有表
也可以提供具体的数据库和表,例如:powernode.emp (powernode数据库的emp表)

授权后必须刷新权限,才能生效:flush privileges


查看某个用户有哪些权限

sql 复制代码
show grants for '用户名'@'主机名/ip地址'

最后带上 with grant option的作用是:这个用户也可以把自己有的权限授权给别的用户


撤销用户权限

sql 复制代码
revoke 权限 on 数据库名.表名 from '用户'@'ip地址'

撤销权限后也需要刷新权限:flush privileges

注意:撤销权限时 "数据库名.表名" 不能随便写,要求和授权语句时的 "数据库名.表名" 一致。



修改用户的密码

SQL 复制代码
alter user '用户名'@'主机名/ip地址' identified by '新密码';

修改密码后,也需要刷新权限才能生效:flush privileges
以上是MySQL8版本以后修改用户密码的方式。



修改用户名

sql 复制代码
rename user '原始用户名'@'主机名/ip地址' to '新用户名'@'主机名/ip地址'

需要 flush privileges



删除用户

sql 复制代码
drop user '用户名'@'主机名/ip地址'

==需要 flush privileges



数据备份

导出数据(在登录mysql数据库之前进行)

sql 复制代码
mysqldump 库名 [表名] > 地址 -u用户 -p密码 --default-character-set = 字符集
每表名就是导出整个库的数据


例如:
# 导出powernode中emp表的数据
mysqldump powernode emp > e:/powernode.sql -uroot -p1234 --default-character-set=utf8

导入数据第一种方式(在登录mysql数据库之前进行)

sql 复制代码
就是
mysqldump 库名 [表名] < 地址 -u用户 -p密码 --default-character-set = 字符集
#没表名就是导入整个库的数据

例如:
# 现在登录mysql状态下新建一个数据库
create database powernode;
# 在登录mysql之前执行以下命令
mysql powernode < e:/powernode.sql -uroot -p1234 --default-character-set=utf8

导入第二种方式(在登录mysql数据库之前进行)

sql 复制代码
create  database 库;
use 库;
source sql文件地址【或者直接拖进来】
相关推荐
ldj20204 分钟前
SpringBoot为什么使用new RuntimeException() 来获取调用栈?
java·spring boot·后端
超龄超能程序猿5 分钟前
Spring 应用中 Swagger 2.0 迁移 OpenAPI 3.0 详解:配置、注解与实践
java·spring boot·后端·spring·spring cloud
会编程的林俊杰14 分钟前
MySQL中的锁有哪些
数据库·mysql
cts61815 分钟前
Milvus分布式数据库工作职责
数据库·分布式·milvus
周胡杰15 分钟前
鸿蒙加载预置数据库-关系型数据库-如何读取本地/预制数据库
数据库·华为·harmonyos·鸿蒙
风象南17 分钟前
SpringBoot配置属性热更新的轻量级实现
java·spring boot·后端
洛阳泰山18 分钟前
Spring Boot 整合 Nacos 实战教程:服务注册发现与配置中心详解
java·spring boot·后端·nacos
Y40900118 分钟前
C语言转Java语言,相同与相异之处
java·c语言·开发语言·笔记
YuTaoShao19 分钟前
【LeetCode 热题 100】994. 腐烂的橘子——BFS
java·linux·算法·leetcode·宽度优先
布朗克16819 分钟前
java常见的jvm内存分析工具
java·jvm·数据库