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
相关文章
|
3天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
48 15
|
4天前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。
|
8天前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
16天前
|
关系型数据库 MySQL 数据库
GBase 数据库如何像MYSQL一样存放多行数据
GBase 数据库如何像MYSQL一样存放多行数据
|
28天前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
35 1
|
1月前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
39 4
|
24天前
|
运维 关系型数据库 MySQL
安装MySQL8数据库
本文介绍了MySQL的不同版本及其特点,并详细描述了如何通过Yum源安装MySQL 8.4社区版,包括配置Yum源、安装MySQL、启动服务、设置开机自启动、修改root用户密码以及设置远程登录等步骤。最后还提供了测试连接的方法。适用于初学者和运维人员。
148 0
|
SQL Java 数据库连接
MySQL---数据库从入门走向大神系列(十五)-Apache的DBUtils框架使用
MySQL---数据库从入门走向大神系列(十五)-Apache的DBUtils框架使用
194 0
MySQL---数据库从入门走向大神系列(十五)-Apache的DBUtils框架使用
|
SQL 关系型数据库 MySQL
MySQL---数据库从入门走向大神系列(六)-事务处理与事务隔离(锁机制)
MySQL---数据库从入门走向大神系列(六)-事务处理与事务隔离(锁机制)
142 0
MySQL---数据库从入门走向大神系列(六)-事务处理与事务隔离(锁机制)
|
存储 SQL 关系型数据库
MySQL---数据库从入门走向大神系列(五)-存储过程
MySQL---数据库从入门走向大神系列(五)-存储过程
142 0
MySQL---数据库从入门走向大神系列(五)-存储过程

热门文章

最新文章