当前位置:w88手机版登录-www.w88zhan.com-优德w88app官方登录 > w88手机版登录网络 > 这4条命令是用来对数据库里的数据进行操作的语

这4条命令是用来对数据库里的数据进行操作的语

文章作者:w88手机版登录网络 上传时间:2019-07-26

前言

在平日专门的工作或然学习中,操作数据库时候难免会因为“大体”而误操作,必要急速复苏的话通过备份来平复是不太恐怕的,上边那篇作品首要给大家介绍有关Mysql误操作后使用binlog2sql快捷回滚的措施,话非常少说,来一齐看看详细的介绍:

一、总体解释:

DML(data manipulation language):

       它们是SELECT、UPDATE、INSERT、DELETE,就象它的名字同样,那4条命令是用来对数据Curry的数量举行操作的语言

DDL(data definition language):

       DDL比DML要多,首要的吩咐有CREATE、ALTELX570、DROP等,DDL首借使用在概念或更换表(TABLE)的结构,数据类型,表之间的链接和束缚等开头化专门的学业上,他们大都在创设表时使用

DCL(Data Control Language):

       是数据库调控机能。是用来设置或转移数据库用户或角色权限的言语,满含(grant,deny,revoke等)语句。在暗许状态下,独有sysadmin,dbcreator,db_owner或db_securityadmin等职员才有权力推行DCL

二、binlog2sql安装

从mysql binlog深入分析出您要的sql。根据差别接纳,你能够赢得原始sql、回滚sql、去除主键的insert sql等。

2.1、用途

  • 数据急迅回滚(闪回)
  • 主从切换后数据分歧样的修补
  • 从binlog生成规范SQL,带来的衍生作用

2.2、安装

# cd /usr/local
# git clone https://github.com/danfengcao/binlog2sql.git
# ls 
binlog2sql games java lib64 mariadb sbin src 
# cd binlog2sql
# pip install -r requirements.txt
-bash: pip: command not found
 -------------安装pip工具-------------
# wget https://bootstrap.pypa.io/get-pip.py 
# python get-pip.py
# pip -V  #查看pip版本
pip 9.0.1 from /usr/lib/python2.7/site-packages (python 2.7)
# pip install -r requirements.txt
Requirement already satisfied: PyMySQL==0.7.8 in /usr/lib/python2.7/site-packages (from -r requirements.txt (line 1))
Requirement already satisfied: wheel==0.24.0 in /usr/lib/python2.7/site-packages (from -r requirements.txt (line 2))
Requirement already satisfied: mysql-replication==0.9 in /usr/lib/python2.7/site-packages (from -r requirements.txt (line 3))

2.3、user须要的矮小权限聚积:

select, super/replication client, replication slave权限提议授权

mysql > GRANT SELECT,REPLICATION SLAVE,REPLICATION CLIENT ON *.* to flashback@'localhost' identified by 'flashback';
mysql > GRANT SELECT,REPLICATION SLAVE,REPLICATION CLIENT ON *.* to flashback@'127.0.0.1' identified by 'flashback';

2.4、基本用法

解析出正式SQL

shell> python binlog2sql.py -h127.0.0.1 -P3306 -uadmin -p'admin' -ddatabase -t table1 table2 --start-file='mysql-bin.000002' --start-datetime='2017-01-12 18:00:00' --stop-datetime='2017-01-12 18:30:00' --start-pos=1240

浅析出回滚SQL

shell> python binlog2sql.py --flashback -h127.0.0.1 -P3306 -uadmin -p'admin' -dtest -ttest3 --start-file='mysql-bin.000002' --start-position=763 --stop-position=1147

三、测试:

3.1、新建表users

create table cope_users like info_users; # 新建表
insert into cope_users select * from info_users limit 500; # 插入500行数据
delete from cope_users where id<20;  # 删除20行数据

3.2、剖判标准sql

# python /usr/local/binlog2sql/binlog2sql/binlog2sql.py -uflashback -pflashback -dttt -tusers --start-file='mysql-bin.000034' --start-datetime='2017-07-11 15:10:00' --stop-datetime='2017-07-11 15:12:00'
DELETE FROM `ttt`.`users` WHERE `uid`='0e8e2609c748bbb052d7' AND `ip`='172.16.208.32' AND `sex`=0 AND `app_ver`='5.2.3' AND `device_type`=2 AND `guides`='' AND `last_login_time`=1481602129 AND `id`=1 AND `latitude`='' AND `add_time`=1481602080 AND `recharge_time`=0 AND `token_change_time`=1481602129 AND `expire_time`=0 AND `nickname`='阿超' AND `device_id`='cc0e154d9b5dd703eccc7d8a0dbc0f67d64b79e8' AND `push_key`='' AND `level`=0 AND `mobile`='18810895535' AND `settings`='' AND `longitude`='' AND `signature`='' AND `os_ver`='' LIMIT 1; #start 79078 end 83053 time 2017-07-11 15:11:50
DELETE FROM `ttt`.`users` WHERE `uid`='b5cfbdb4205b56703a97' AND `ip`='172.16.208.48' AND `sex`=0 AND `app_ver`='5.2.2' AND `device_type`=2 AND `guides`='' AND `last_login_time`=1481602096 AND `id`=2 AND `latitude`='' AND `add_time`=1481602096 AND `recharge_time`=0 AND `token_change_time`=1481602096 AND `expire_time`=0 AND `nickname`='家长091410' AND `device_id`='fedea666076a7906be53523acc7a8b32811354fe' AND `push_key`='7759d6772c9851a2bfc13835a3d7e7da' AND `level`=0 AND `mobile`='13629470521' AND `settings`='' AND `longitude`='' AND `signature`='' AND `os_ver`='' LIMIT 1; #start 79078 end 83053 time 2017-07-11 15:11:50

3.3、深入分析出回滚SQL

# python /usr/local/binlog2sql/binlog2sql/binlog2sql.py --flashback -h127.0.0.1 -P3306 -uflashback -pflashback -dttt -tusers --start-file='mysql-bin.000034' --start-position=79078 --stop-position=83053

查阅深入分析出的sql,如准确,可打字与印刷到sql文件中/data/backup/rollback.sql

# python /usr/local/binlog2sql/binlog2sql/binlog2sql.py --flashback -uflashback -pflashback -dttt -tusers --start-file='mysql-bin.000034' --start-position=79078 --stop-position=83053> /data/backup/rollback.sql
# cat /data/backup/rollback.sql 
`id`, `latitude`, `add_time`, `recharge_time`, `token_change_time`, `expire_time`, `nickname`, `device_id`, `push_key`, `level`, `mobile`, `settings`, `longitude`, `signature`, `os_ver`) VALUES ('24667530f4b16a446b3e', '172.16.218.75', 0, '5.2.93', 3, '{"2103":1,"2100":1,"2101":1,"2102":1,"2104":1,"2105":1}', 1490239125, 19, '', 1481610680, 0, 1490239125, 0, 'zf', 'da75b093-bd22-48f6-bbb1-d3296e29e9b5', 'be05183f80a96e788e0b0a99d1275392', 0, '15101538925', '', '', '', ''); #start 79078 end 83053 time 2017-07-11 15:11:50
INSERT INTO `ttt`.`users`(`uid`, `ip`, `sex`, `app_ver`, `device_type`, `guides`, `last_login_time`, `id`, `latitude`, `add_time`, `recharge_time`, `token_change_time`, `expire_time`, `nickname`, `device_id`, `push_key`, `level`, `mobile`, `settings`, `longitude`, `signature`, `os_ver`) VALUES ('77e50b4910a9389057ed', '172.16.218.37', 0, '5.2.1.14', 3, '', 1488787835, 18, '39.978212', 1481610517, 0, 1488787835, 0, '陈俊宇', 'ed0a273d-74de-4173-92c6-55d92597bc79', '', 0, '18612482272', '', '116.306826', '', ''); #start 79078 end 83053 time 2017-07-11 15:11:50

mysql连接配置

 -h host; -P port; -u user; -p password

深入分析形式

  •   --realtime 持续同步binlog。可选。不加则同步至实施命令时最新的binlog地方。
  •   --popPk 对INSERT语句去除主键。可选。
  •   -B, --flashback 生成回滚语句。可选。与realtime或popPk无法同有的时候间加上。

剖判范围调控

  •   --start-file 初始深入分析文件。必须。
  •   --start-pos start-file的开场剖析地方。可选。默感觉start-file的序曲地方;
  •   --end-file 末尾分析文件。可选。默以为start-file同多个文件。若剖析格局为realtime,此选项失效。
  •   --end-pos end-file的末尾剖析地方。可选。默以为end-file的最末地方;若分析方式为realtime,此选项失效。

指标过滤

  •    -d, --databases 只输出目标db的sql。可选。默以为空。
  •    -t, --tables 只输出目的tables的sql。可选。默感觉空。

3.4、开头回滚

# mysql -uroot -p000000 < /data/backup/rollback.sql

3.5、登录数据库验证

四、注意事项

4.1、在配置文件中安装了以下参数:

server_id = 1
log_bin = /data/mysql/mysql-bin.log
max_binlog_size = 1G
binlog_format = row
binlog_row_image = full # 默认

4.2、在闪回的时候必须运行 MySQL 服务

因为它是透过 BINLOG_DUMP 协商来取得 binlog 内容,需求读取server端 information_schema.COLUMNS 表,来获取表结构的元音信,工夫拼接成 SQL 语句。由此要求给用户提供的小不点儿权限如下:

GRANT SELECT, REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'user'@'%';

源码中,主借使选取 python-mysql-replication 作为实时解析 MySQL binlog 来赢得各类 EVENT。 python-mysql-replication 达成了 MySQL 复制协议,客户端伪装成 slave 来博取主的 binlog 和 EVENT。

4.3、insert、update、delete一大半时候能够解析出来规范sql和回滚sql

一种情状分裂:insert、updete、delete操作之后,drop/truncate table。 此时虽说在binlog中记录了具备的event,不过接纳binlog2sql生成标准sql、回滚sql的时候曾经找不到了dml操作的对应的表

4.4、DDL不能够选取binlog2sql闪回数据。

总结

如上正是那篇小说的全体内容了,希望本文的源委对大家的上学大概工作能拉动一定的相助,假设有疑难大家能够留言交换,多谢我们对剧本之家的扶助。

您大概感兴趣的小说:

  • MySQL数据库误操作后飞快回滚的办法
  • MySQL中truncate误操作后的数据苏醒案例
  • 详解MySQL误操作后如何举行数据恢复
  • MySQL误操作后赶快回涨数据的不二法门
  • MySQL数据库防止人为误操作的实例批注
  • 有关mysql数据库误删除后的数据苏醒操作表达
  • 浅析Mysql 数据回滚错误的化解措施

本文由w88手机版登录-www.w88zhan.com-优德w88app官方登录发布于w88手机版登录网络,转载请注明出处:这4条命令是用来对数据库里的数据进行操作的语

关键词: w88top优徳官网