MySQL数据库 管理与维护

目录

数据备份与还原

数据的备份

数据的还原

用户管理

user表

创建用户

删除用户

修改用户密码

权限管理

授予权限

查看权限

收回权限


数据备份与还原

数据的备份

mysqldump命令:能够将数据库导出成SQL脚本,可以直接在命令行窗口执行不用登录数据库

①备份单个数据库
mysqldump -u username -p password dbname tbname1 \[bname2...] > filename.sql

username为用户名,password为登录密码

dbname为需要备份的数据库

tbname为数据库中需要备份的数据表,可以指定一张或多张表,数据表名称之间使用空格隔开

filename.sql为保存的备份文件,可以使用绝对路径保存

②备份多个数据库
mysqldump -u username -p password --database dbname1 dbname2... > filename.sql

dbname为需要备份的数据库,需要至少指定一个数据库,多个数据库名称之间使用空格隔开

③备份所有数据库
mysqldump -u username -p password --all-databases > filename.sq

备份文件中包含CREATE DATABASE语句和USE语句

备份文件内容:

mysqldump的版本号、MySQL的版本号、主机名称、备份的数据库名称等

-- 字符开头的语句是SQL语言的注释

/*! 开头,*/结尾的语句是可执行的MySQL语句

数据的还原

使用mysql命令和source命令,执行备份文件中的SQL语句将数据库数据还原

mysql命令:在命令行窗口中使用mysql命令不需要登录数据库
mysql -u username -p password dbname < filename.sql

如果备份文件中不包含创建和选择数据库的语句,则需要先手动创建和选择将接收还原数据的数据库

source命令:在命令行窗口中使用source命令需要先登录数据库
source filename.sql

只需要指定备份文件的名称和文件路径

用户管理

MySQL是一个多用户数据库管理系统

|---------------|-------------|
| 用户(大致分为) | 权限 |
| root用户(超级管理员) | 拥有所有权限 |
| 普通用户 | 只拥有被授予的指定权限 |

MySQL在安装时,会自动创建mysql数据库,主要用于维护数据库的用户及权限的控制与管理,包含数据表user、db、host等

user表

user表中保存了所有用户信息,根据功能可分为四个字段:用户字段、权限字段、安全字段和资源控制字段

①用户字段:存储了用户连接MySQL数据库时需要输入的信息

②权限字段:针对所有数据库,数据类型为ENUM(值只有N或Y,默认值都为N)

③安全字段:包含安全连接、身份验证和密码相关等字段

④资源控制字段:用于限制用户对服务器资源的使用

创建用户

使用CREATE USER语句创建用户
CREATE USER 'username'@'hostname' IDENTIFIED BY \[PASSWORD'password'
,'username'@'hostname' \[IDENTIFIED BY \[PASSWORD'password']]...

username为新创建用户名称

hostname为主机名(localhost:仅允许本地连接,%:允许从任意主机连接)
IDENTIFIED BY 用于设置用户的密码

PASSWORD为使用哈希值设置密码

可以同时创建多个用户,多个用户之间使用逗号分隔
**注意:**如果添加的用户已经存在,执行CREATE USER语句会报错

使用GRANT语句创建用户(8.0版本前)
GRANT privileges ON database.table
TO 'username'@'hostname' IDENTIFIED BY \[PASSWORD'password']
,'username'@'hostname' \[IDENTIFIED BY \[PASSWORD'password']]...

privileges为该用户具有的权限信息,database.table为新用户的权限范围表

username为新用户名称,hostname为主机名,password为新用户密码

删除用户

使用DROP USER语句删除用户
DROP USER 'username'@'hostname' ,username'@'hostname' ;

可以同时删除多个用户,多个用户之间使用逗号分隔

使用DELETE语句删除用户,不仅可以删除普通表中的数据,还可以删除mysql.user表中的数据
DELETE FROM mysql.user WHERE Host='hostname' AND User='username';

mysql.user指定要操作的表,WHERE指定条件语句

host和user都是mysql.user表的字段,可以确定唯一的一条记录

修改用户密码

使用mysqladmin命令
mysqladmin -u username -h hostname -p password new_password

username为要修改密码的用户名

-h hostname用于指定对应的主机名,默认为localhost

-p password用于指定要修改的内容为密码

new_password为新设置的密码

使用ALTER USER语句
ALTER USER 'username'@'hostname' IDENTIFIED by new_password;

使用SET语句
SET PASSWORD=new_password;

使用UPDATE语句(不建议使用)
UPDATE mysql.user SET authentication_string=PASSWORD('new_password')
WHERE User='username' and Host='hostname';

注意:使用UPDATE语句修改密码后,需要使用FLUSH PRIVILEGES命令重新加载权限表

权限管理

授予权限

使用GRANT语句:授予用户权限
GRANT 权限类型(字段列表),权限类型\[(字段列表)] ON 权限级别 TO 'username'@'hostname' ,'username'@'hostname'... WITH with_option

权限类型包括:

数据权限(select、update、delete、insert、show database、show view、process)

结构权限(drop、create、alter、index等)

管理权限(create user、create option等)

权限级别包括:

全局级别:*.*

当前未选择数据库 * 表示全局级别;选择数据库 * 表示数据库级别

数据库级别:数据库名.*

数据表级别:数据库名.数据表名

WITH with_option包含五个with_option取值:

将自己的权限授予其他用户:GRANT OPTION

设置每小时最多可以执行多少次查询:MAS_QUERIES_PRE_HOUR count

设置每小时最多可以执行多少次更新:MAS_UPDATES_PRE_HOUR count

设置每小时最大的连接数量:MAS_CONNECTIONS_PRE_HOUR count

设置每个用户最多可以同时建立的连接数量:MAS_USER_CONNECTIONS

-将所有权限授予用户

grant all PRIVILEGES on 'username'@'hostname';

查看权限

表权限可以在mysql.tables_priv中查看,列权限可以在mysql.columns_priv中查看

使用SHOW GRANTS语句
SHOW GRANTS FOR 'username'@'hostname';

收回权限

使用REVOKE语句:收回指定用户的指定权限
REVOKE 权限类型(字段列表),权限类型\[(字段列表)] ON 权限级别 FROM 'username'@'hostname' ,'username'@'hostname'...

字段列表表示权限作用的字段,默认作用于整个数据表

相关推荐
jiayou6417 小时前
KingbaseES 表级与列级加密完全指南
数据库·后端
GBASE2 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr2 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
唐青枫3 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
吃糖的小孩3 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
小满8783 天前
5.Mysql事务隔离级别与锁机制
mysql
笃行3504 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3504 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3504 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
元Y亨H4 天前
技术笔记:MySQL 字符集排序规则与大小写敏感性问题解决方案
mysql