MySQL-数据库(4)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 本文主要讲述了MySQL的恢复、日志、备份以及关于用户的授权操作。

本文主要讲述了MySQL的恢复、日志、备份以及关于用户的授权操作。

3.3恢复、日志、备份

动态转储 静态转储
海量转储 动态海量转储 静态海量转储
增量转储 动态增量转储 静态增量转储
  • 逻辑备份工具:mysqldump
  • 物理备份工具:mysqlbackup(仅限商用版)
  • 日志工具:mysqlbinlog
  • 还原工具:mysql
  • 管理工具:mysqladmin

3.3.1逻辑备份 - mysqldump

mysqldump -h127.0.0.1 -uroot -p123123 [options] --databases db_name1 db_name2 


--databases 参数用指定数据库名,后面可跟一个或多个数据库的名字,多个数据库名间用空格隔开。
--all-databases 导出所有数据库
--tables参数代表要导出多个数据表;
--flush-logs 刷MySQL日志,即重新开始一个日志文件。
-p和密码之间没有空格


mysqldump -unew-user1 -p123123 db1 --tables tb1 tb2> tb1tb2.sql

3.3.2还原 - mysql

mysql -h127.0.0.1 -uroot -p12313 < mydb.sql  # 直接执行mydb.sql脚本用于恢复数据库

#     MYSQL
use db1;  
source tb1tb2.sql;  
  • 导入只有数据表的sql文件时,需要先选择数据库,然后再导入;

3.3.3管理 - mysqladmin

# mysqladmin一般用于配置服务器,也可以用来创建或删除数据库:
mysqladmin [options] command [command-arg] [command [command-arg]]

# 常用的command(执行命令)有:
create db_name                             创建数据库
drop db_name                                 删除数据库
flush-logs                                     刷日志
flush-tables                                 刷表,所有表数据写入磁盘盘
kill id,id,...                          杀死某些进程
password new_password             修改(登录者的)登录密码
ping                                                 检查服务器是否可用
status                                             显示服务器状态
variables                                     显示各配置参数的值

3.3.4日志 - mysqlbinlog

# 查看日志
mysqlbinlog  mysql-bin.000983

# 根据日志恢复数据
mysqlbinlog [option] binlog_files | mysql -u root -p


[option] :
--disable-log-bin         在通过日志恢复数据库期间不再写日志
--no-defaults                 不使用MySQL默认的设置
mysql -uroot -p123123 -h127.0.0.1登陆数据库

# SQL语句查询日志启用情况:

SHOW VARIABLES LIKE "log_%";

# 设置日志文件存储方式:

SET GLOBAL log_output="option";

--
option参数有3个值,分别是FILE,TABLE,FILE,TABLE;
FILE代表以文件形式存储,TABLE代表以数据表形式存储,FILE,TABLE代表以文件和数据表两种形式都进行存储。
--

# 查看日志文件位置
show variables like 'general_log_file';
'''
+------------------+-----------------------------------------------------------------+
| Variable_name    | Value                                                           |
+------------------+-----------------------------------------------------------------+
| general_log_file | C:\phpstudy_pro\Extensions\MySQL8.0.12\data\LAPTOP-3N4T0RBF.log |
+------------------+-----------------------------------------------------------------+
'''

# 启动慢日志
SET GLOBAL log_slow_queries="ON";

# 设置long_query_time参数:
SET GLOBAL long_query_time=秒数;


# 启动常规查询日志
SET GLOBAL general_log="ON";
【注意】:虽然全局的long_query_time参数值已经被改变,但是对于本次连接并不生效,必须重新连接才会生效。

3.4授权与撤销授权

3.4.1用户管理

SELECT user FROM  mysql.user;  -- 查看所有用户

select user(); -- 查看当前用户

select database(); -- 查看当前使用的数据库
mysql -uroot -p123123 -h127.0.0.1 # 登录mysql

# MYSQL语句
# 创建用户
create user '用户名'@'允许登录的主机地址' identified by 密码;  

#创建指定ip为 192.168.1.1 的lyn用户登录  
create user 'lyn'@'192.168.1.1' identified by '123';


# 删除用户
drop user '用户名'@'允许登录的主机地址';  
DELETE FROM mysql.user WHERE User="用户名" AND Host="主机名";

# 在删除用户后,必须执行更新权限语句:

# 修改用户名
rename user '用户名'@'IP地址' to '新用户名'@'IP地址';  

# 修改密码
set password for '用户名'@'IP地址' = Password('新密码');  

UPDATE mysql.user SET Password=PASSWORD("新密码") WHERE User="用户名" [AND Host="主机名"];
# examples
DELETE FROM mysql.user WHERE User="new-user2" AND Host="127.0.0.1";  
FLUSH PRIVILEGES;  
CREATE USER "new-user2"@"127.0.0.1"; 


UPDATE mysql.user SET Password=PASSWORD("newpassword") WHERE User="new-user3" AND Host="%";  

3.4.2连接数据库

import pymysql
# 连接数据库
def connect():
    conn = pymysql.connect(host='localhost',user='root',passwd='123123',charset='utf8')
    return conn.get_host_info()

# 执行SQL语句
cursor = conn.cursor() # 获取游标  【游标是一种数据访问对象,可用于创建数据库和数据表,也可用于在表中迭代一组行或者向表中插入新行。】
cursor.execute('create database carinfo')  

# 确定使用的数据库  【也可在连接的时候就指定数据库 db='xxx'】
conn.select_db(dbName)  

# 插入数据
sql = "insert into %s values ('%s', '%s', '%s')" % (tablename, '2017-8-19', 1000, 'Chevrolet') 

# 接收返回值
fetchall():                接收全部的返回结果行  
fetchmany(size=None):    接收size条返回结果行  
fetchone():                返回一条结果行  

cursor().execute(sql)
records = cursor.fetchall()

scroll(value, mode='relative'):     指针移动value条  

# 在完成插入之后需要将插入事务提交,否则会导致相应的表死锁
conn.commit() 

# 在对数据库的所有操作完成之后,需要关闭与数据库之间的连接:  
conn.close()  

3.4.3权限

# 查看权限:
show grants for '用户'@'IP地址'

# all表示允许做任何事, usage表示只允许登录

# 授予权限
grant 权限列表 on 库.表 to 用户名@'ip';  

# 刷新权限
FLUSH PRIVILEGES;

# 查看全部的权限
SHOW PRIVILEGES;


# eg:
GRANT all privileges ON *.* TO "new-user1"@"%";  
FLUSH PRIVILEGES;  
授权操作只能是root用户来操作;grant给用户权限后,该用户只有重新连接 MySQL 数据库,权限才能生效;授权后一定要刷新权限,使权限立即生效: **FLUSH PRIVILEGES;**
revoke 权限列表 on 库.表 from 用户名@'ip';  

# eg:
revoke all on mydb1.table1 from user1@'localhost';

报错:mysql8:not allowed to create a user with GRANT
原因:授权的形式是 database.table,授权形式错了,😅
GRANT all privileges ON mei_tuan.* TO "test"@"127.0.0.1";

好像localhost 和127.0.0.1不能混着来,

image.png
3.4.4命令行形式修改MySQL8密码
系统:Windows
MySQL版本:8.0.12

首先以管理员权限打开powershell,用net stop mysql8 关闭服务
注意这里是mysql8, 要和任务管理器中的服务,中的mysql服务的名称对应起来即可。
在命令行输入:

mysqld --console --skip-grant-tables --shared-memory

然后启动另外一个powershell,输入MySQL -u root直接登陆,接着输入alter user 'root'@'localhost' identified by 'min66666';

注意这里密码最好是字母加数字,纯数字不一定能设置成功。

然后刷新一下权限,flus

net start mysql8
输入MySQL -u root
在输入刚刚设置的密码即可。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1天前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
13 4
|
10天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
49 2
|
13天前
|
存储 关系型数据库 MySQL
MySQL vs. PostgreSQL:选择适合你的开源数据库
在众多开源数据库中,MySQL和PostgreSQL无疑是最受欢迎的两个。它们都有着强大的功能、广泛的社区支持和丰富的生态系统。然而,它们在设计理念、性能特点、功能特性等方面存在着显著的差异。本文将从这三个方面对MySQL和PostgreSQL进行比较,以帮助您选择更适合您需求的开源数据库。
56 4
|
8天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
43 0
|
9天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第26天】数据库作为现代应用系统的核心组件,其性能优化至关重要。本文主要探讨MySQL的索引策略与查询性能调优。通过合理创建索引(如B-Tree、复合索引)和优化查询语句(如使用EXPLAIN、优化分页查询),可以显著提升数据库的响应速度和稳定性。实践中还需定期审查慢查询日志,持续优化性能。
38 0
|
18天前
|
存储 监控 关系型数据库
MySQL并发控制与管理:优化数据库性能的关键
【10月更文挑战第17天】MySQL并发控制与管理:优化数据库性能的关键
78 0
|
18天前
|
存储 SQL 关系型数据库
MySQL Workbench支持哪些数据库引擎
【10月更文挑战第17天】MySQL Workbench支持哪些数据库引擎
15 0
|
27天前
|
存储 SQL 关系型数据库
Mysql学习笔记(二):数据库命令行代码总结
这篇文章是关于MySQL数据库命令行操作的总结,包括登录、退出、查看时间与版本、数据库和数据表的基本操作(如创建、删除、查看)、数据的增删改查等。它还涉及了如何通过SQL语句进行条件查询、模糊查询、范围查询和限制查询,以及如何进行表结构的修改。这些内容对于初学者来说非常实用,是学习MySQL数据库管理的基础。
105 6
|
25天前
|
存储 关系型数据库 MySQL
Mysql(4)—数据库索引
数据库索引是用于提高数据检索效率的数据结构,类似于书籍中的索引。它允许用户快速找到数据,而无需扫描整个表。MySQL中的索引可以显著提升查询速度,使数据库操作更加高效。索引的发展经历了从无索引、简单索引到B-树、哈希索引、位图索引、全文索引等多个阶段。
58 3
Mysql(4)—数据库索引
|
27天前
|
SQL Ubuntu 关系型数据库
Mysql学习笔记(一):数据库详细介绍以及Navicat简单使用
本文为MySQL学习笔记,介绍了数据库的基本概念,包括行、列、主键等,并解释了C/S和B/S架构以及SQL语言的分类。接着,指导如何在Windows和Ubuntu系统上安装MySQL,并提供了启动、停止和重启服务的命令。文章还涵盖了Navicat的使用,包括安装、登录和新建表格等步骤。最后,介绍了MySQL中的数据类型和字段约束,如主键、外键、非空和唯一等。
64 3
Mysql学习笔记(一):数据库详细介绍以及Navicat简单使用