设为首页 收藏本站
查看: 1303|回复: 0

[经验分享] mysql六:数据备份、pymysql模块

[复制链接]

尚未签到

发表于 2018-10-6 07:01:42 | 显示全部楼层 |阅读模式
  一、IDE工具介绍
  生产环境还是推荐使用mysql命令行,但为了方便我们测试,可以使用IDE工具 下载链接:https://pan.baidu.com/s/1bpo5mqj
  掌握:
  1. 测试+链接数据库
  2. 新建库
  3. 新建表,新增字段+类型+约束
  4. 设计表:外键
  5. 新建查询
  6. 备份库/表
  注意:
  批量加注释:ctrl+?键
  批量去注释:ctrl+shift+?键
  二 MySQL数据备份
  1、名词解释
  物理备份: 直接复制数据库文件,适用于大型数据库环境。但不能恢复到异构系统中如Windows。
  逻辑备份: 备份的是建表、建库、插入等操作所执行SQL语句,适用于中小型数据库,效率相对较低。
  导出表: 将表导入到文本文件中。
  2、使用mysqldump实现逻辑备份
  语法:mysqldump -h 服务器 -u用户名 -p密码 数据库名 > 备份文件.sql
  示例:
  单库备份
  mysqldump -uroot -p123 db1 > db1.sql
  mysqldump -uroot -p123 db1 table1 table2 > db1-table1-table2.sql
  多库备份
  mysqldump -uroot -p123 --databases db1 db2 mysql db3 > db1_db2_mysql_db3.sql
  备份所有库
  mysqldump -uroot -p123 --all-databases > all.sql
  3、恢复逻辑备份
  方法一:mysql -uroot -p123 < /backup/all.sql
  方法二:
  mysql> use db1;
  mysql> SET SQL_LOG_BIN=0;
  mysql> source /root/db1.sql
  注:如果备份/恢复单个库时,可以修改sql文件
  DROP database if exists school;
  create database school;
  use school;
  4、备份/恢复案例
  实验一:数据库损坏
  备份:
  #mysqldump -uroot -p123 --all-databases > /backup/`date +%F`_all.sql
  #mysql -uroot -p123 -e 'flush logs' //截断并产生新的binlog
  插入数据 //模拟服务器正常运行
  mysql> set sql_log_bin=0; //模拟服务器损坏
  mysql> drop database db;
  恢复:
  #mysqlbinlog 最后一个binlog > /backup/last_bin.log
  mysql> set sql_log_bin=0;
  mysql> source /backup/2014-02-13_all.sql //恢复最近一次完全备份
  mysql> source /backup/last_bin.log //恢复最后个binlog文件
  实验二:如果有误删除
  备份:
  mysqldump -uroot -p123 --all-databases > /backup/`date +%F`_all.sql
  mysql -uroot -p123 -e 'flush logs' //截断并产生新的binlog
  插入数据 //模拟服务器正常运行
  drop table db1.t1 //模拟误删除
  插入数据 //模拟服务器正常运行
  恢复:
  #mysqlbinlog 最后一个binlog --stop-position=260 > /tmp/1.sql
  #mysqlbinlog 最后一个binlog --start-position=900 > /tmp/2.sql
  mysql> set sql_log_bin=0;
  mysql> source /backup/2014-02-13_all.sql //恢复最近一次完全备份
  mysql> source /tmp/1.log //恢复最后个binlog文件
  mysql> source /tmp/2.log //恢复最后个binlog文件
  注意事项:
  1.完全恢复到一个干净的环境(例如新的数据库或删除原有的数据库)
  2.恢复期间所有SQL语句不应该记录到binlog中
  5、实现自动化备份
  备份计划:
  1)什么时间 2:00
  2)对哪些数据库备份
  3)备份文件放的位置
  备份脚本:
  vim /mysql_back.sql
  #!/bin/bash
  back_dir=/backup
  back_file=`date +%F`_all.sql
  user=root
  pass=123
  if [ ! -d /backup ];then
  mkdir -p /backup
  fi
  #备份并截断日志
  mysqldump -u${user} -p${pass} --events --all-databases > ${back_dir}/${back_file}
  mysql -u${user} -p${pass} -e 'flush logs'
  #只保留最近一周的备份
  cd $back_dir
  find . -mtime +7 -exec rm -rf {} \;
  手动测试:
  #chmod a+x /mysql_back.sql
  #chattr +i /mysql_back.sql
  #/mysql_back.sql
  配置cron:
  # crontab -e
  2 * * * /mysql_back.sql
  6、表的导出和导入
  1)SELECT... INTO OUTFILE 导出文本文件
  mysql> SELECT * FROM school.student1 INTO OUTFILE 'student1.txt'
  FIELDS TERMINATED BY ',' //定义字段分隔符
  OPTIONALLY ENCLOSED BY '”' //定义字符串使用什么符号括起来
  LINES TERMINATED BY '\n' ; //定义换行符
  2)mysql 命令导出文本文件:
  mysql -u root -p123 -e 'select * from student1.school' > /tmp/student1.txt
  mysql -u root -p123 --xml -e 'select * from student1.school' > /tmp/student1.xml
  mysql -u root -p123 --html -e 'select * from student1.school' > /tmp/student1.html
  3)LOAD DATA INFILE 导入文本文件
  mysql> DELETE FROM student1;
  mysql> LOAD DATA INFILE '/tmp/student1.txt' INTO TABLE school.student1
  FIELDS TERMINATED BY ','
  OPTIONALLY ENCLOSED BY '”'
  LINES TERMINATED BY '\n';
  注意:可能会报错 ERROR 1238 (HY000): Variable 'secure_file_priv' is a read only variable
  数据库最关键的是数据,一旦数据库权限泄露,那么通过上述语句就可以轻松将数据导出到文件中然后下载拿走,因而mysql对此作了限制,只能将文件导出到指定目录
  [mysqld]
  secure_file_priv='xxx'
  重启mysql,重新执行上述语句
  7、数据库迁移
  务必保证在相同版本之间迁移
  #mysqldump -h 源IP -uroot -p123 --databases db1 | mysql -h 目标IP -uroot -p456
  三、pymysql模块
  1、安装
  pip3 install pymysql
  2、链接、执行sql、关闭(游标)
  import pymysql
  user=input('用户名: ').strip()
  pwd=input('密码: ').strip()
  #链接
  conn=pymysql.connect(host='localhost',user='root',password='123',database='databasename',charset='utf8')
  #游标
  cursor=conn.cursor() #执行完毕返回的结果集默认以元组显示
  #cursor=conn.cursor(cursor=pymysql.cursors.DictCursor)
  #执行sql语句
  sql='select * from tablename where name=&quot;%s&quot; and password=&quot;%s&quot;' %(user,pwd) #注意%s需要加引号
  print(sql)
  res=cursor.execute(sql) #执行sql语句,返回sql查询成功的记录数目
  print(res)
  cursor.close()
  conn.close()
  if res:
  print('登录成功')
  else:
  print('登录失败')
  3、 execute()之sql注入
  4、增、删、改:conn.commit()
  5、查:fetchone,fetchmany,fetchall
  6、获取插入的最后一条数据的自增ID


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-612917-1-1.html 上篇帖子: MySQL主从复制搭建 下篇帖子: MySQL单机多实例配置实战
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表