一 IDE工具介绍

生产环境还是推荐使用mysql命令行,但为了方便测试,可以使用IDE工具

下载链接:https://pan.baidu.com/s/1bpo5mqj

掌握:
#1. 测试+链接数据库
#2. 新建库
#3. 新建表,新增字段+类型+约束
#4. 设计表:外键
#5. 新建查询
#6. 备份库/表 #注意:
批量加注释:ctrl+?键
批量去注释:ctrl+shift+?键

二 MySQL数据备份

#1. 物理备份: 直接复制数据库文件,适用于大型数据库环境。但不能恢复到异构系统中如Windows。
#2. 逻辑备份: 备份的是建表、建库、插入等操作所执行SQL语句,适用于中小型数据库,效率相对较低。
#3. 导出表: 将表导入到文本文件中。

一、使用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

二、恢复逻辑备份

#方法一:
[root@egon backup]# 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;

三、备份/恢复案例

#数据库备份/恢复实验一:数据库损坏
备份:
1. # mysqldump -uroot -p123 --all-databases > /backup/`date +%F`_all.sql
2. # mysql -uroot -p123 -e 'flush logs' //截断并产生新的binlog
3. 插入数据 //模拟服务器正常运行
4. mysql> set sql_log_bin=0; //模拟服务器损坏
mysql> drop database db; 恢复:
1. # mysqlbinlog 最后一个binlog > /backup/last_bin.log
2. mysql> set sql_log_bin=0;
mysql> source /backup/2014-02-13_all.sql //恢复最近一次完全备份
mysql> source /backup/last_bin.log //恢复最后个binlog文件 #数据库备份/恢复实验二:如果有误删除
备份:
1. mysqldump -uroot -p123 --all-databases > /backup/`date +%F`_all.sql
2. mysql -uroot -p123 -e 'flush logs' //截断并产生新的binlog
3. 插入数据 //模拟服务器正常运行
4. drop table db1.t1 //模拟误删除
5. 插入数据 //模拟服务器正常运行 恢复:
1. # mysqlbinlog 最后一个binlog --stop-position=260 > /tmp/1.sql
# mysqlbinlog 最后一个binlog --start-position=900 > /tmp/2.sql
2. 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中

四、实现自动化备份

备份计划:
1. 什么时间 2:00
2. 对哪些数据库备份
3. 备份文件放的位置 备份脚本:
[root@egon ~]# 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 {} \; 手动测试:
[root@egon ~]# chmod a+x /mysql_back.sql
[root@egon ~]# chattr +i /mysql_back.sql
[root@egon ~]# /mysql_back.sql 配置cron:
[root@egon ~]# crontab -l
0 2 * * * /mysql_back.sql

五、表的导出和导入

SELECT... INTO OUTFILE 导出文本文件
示例:
mysql> SELECT * FROM school.student1
INTO OUTFILE 'student1.txt'
FIELDS TERMINATED BY ',' //定义字段分隔符
OPTIONALLY ENCLOSED BY '”' //定义字符串使用什么符号括起来
LINES TERMINATED BY '\n' ; //定义换行符 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 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';

六、数据库迁移

务必保证在相同版本之间迁移
# mysqldump -h 源IP -uroot -p123 --databases db1 | mysql -h 目标IP -uroot -p456

七 pymysql模块

#安装
pip3 install pymysql

一 链接、执行sql、关闭(游标)

#!/usr/bin/python
import pymysql
conn=pymysql.connect(host='localhost',user='root',password='',database='db8')
cursor=conn.cursor()
sql='select * from user where id=1'
print(sql)
rows=cursor.execute(sql)
print('%s row in set(0.00 sec)'%rows)
#conn.commit()
cursor.close() #关闭光标连接
conn.close() #关闭连接 '''
执行结果:
[root@localhost pythonfile]# python3 s1.py
select * from user where id=1
1 row in set(0.00 sec) #显示1条记录
'''

验证登陆

#!/usr/bin/python
import pymysql
name=input('用户名>>: ').strip()
pwd=input('密码:>>: ').strip() conn=pymysql.connect(host='localhost',user='root',password='',database='db8') #建立连接
cursor=conn.cursor() #连接游标 mysql>
sql='select * from user where user="%s" and password="%s";' %(name,pwd)
print(sql)
rows=cursor.execute(sql)
#print('%s row in set(0.00 sec)'%rows)
#conn.commit()
cursor.close() #关闭游标
conn.close() #关闭连接
if rows:
print('登陆成功')
else:
print('登陆失败') '''
验证结果:
[root@localhost pythonfile]# python3 sql.py
用户名>>: egon
密码:>>: 221a
select * from user where user="egon" and password="221a";
登陆成功
'''

二 execute()之sql注入

注意:符号--会注释掉它之后的sql,正确的语法:--后至少有一个任意字符

根本原理:就根据程序的字符串拼接name='%s',我们输入一个xxx' -- haha,用我们输入的xxx加'在程序中拼接成一个判断条件name='xxx' -- haha'

最后那一个空格,在一条sql语句中如果遇到select * from t1 where id > 3 -- and name='egon';则--之后的条件被注释掉了

#1、sql注入之:用户存在,绕过密码
egon' -- 任意字符 #2、sql注入之:用户不存在,绕过用户与密码
xxx' or 1=1 -- 任意字符
[root@localhost pythonfile]# python3 sql.py
用户名>>: egon" -- xxxxx
密码:>>:
select * from user where user="egon" -- xxxxx" and password=""; #--之后的的sql均被注释掉了
登陆成功 #绕过密码直接登录成功

缺点:如果不能知道用户名就不能进行

绕过用户名登录:

[root@localhost pythonfile]# python3 sql.py
用户名>>: xxx" or 1=1 -- sssss
密码:>>:
select * from user where user="xxx" or 1=1 -- sssss" and password="";
登陆成功

解决sql注入的方法

# 原来是我们对sql进行字符串拼接
# sql="select * from userinfo where name='%s' and password='%s'" %(user,pwd)
# print(sql)
# res=cursor.execute(sql) #改写为(execute帮我们做字符串拼接,我们无需且一定不能再为%s加引号了)
sql="select * from userinfo where name=%s and password=%s" #!!!注意%s需要去掉引号,因为pymysql会自动为我们加上
res=cursor.execute(sql,[user,pwd]) #pymysql模块自动帮我们解决sql注入的问题,只要我们按照pymysql的规矩来。

三 增、删、改:conn.commit()

#!/usr/bin/python
import pymysql
conn=pymysql.connect(host='localhost',user='root',password='',database='db8',charset='utf8'
)
cursor=conn.cursor()
sql='insert into user(name,password) values(%s,%s);' rows=cursor.execute(sql,('alex','')) #单条插入
rows=cursor.executemany(sql,[('ss',''),('laowu','')]) #多条插入
print('%s row in set (0.00 sec)' %rows)
conn.commit() cursor.close()
conn.close() '''
mysql> select * from user;
+----+-------+----------+
| id | name | password |
+----+-------+----------+
| 1 | egon | 123 |
| 2 | egon1 | 123 |
| 3 | alex | 123 |
| 4 | egon1 | 123 |
+----+-------+----------+
4 rows in set (0.00 sec) mysql> select * from user;
+----+-------+----------+
| id | name | password |
+----+-------+----------+
| 1 | egon | 123 |
| 2 | egon1 | 123 |
| 3 | alex | 123 |
| 4 | egon1 | 123 |
+----+-------+----------+
4 rows in set (0.00 sec) mysql> select * from user;
+----+-------+----------+
| id | name | password |
+----+-------+----------+
| 1 | egon | 123 |
| 2 | egon1 | 123 |
| 3 | alex | 123 |
| 4 | egon1 | 123 |
| 5 | alex | 123 |
| 6 | ss | 121 |
| 7 | laowu | 111 |
+----+-------+----------+
7 rows in set (0.00 sec) '''

四、查:fetchone,fetchmany,fetchall

[root@localhost pythonfile]# cat examine.py
#!/usr/bin/python #单条查询
import pymysql
conn=pymysql.connect(host='localhost',user='root',password='',database='db8')
cursor=conn.cursor() #游标
sql='select * from user;'
rows=cursor.execute(sql)
res1=cursor.fetchone() #查单条
print(res1) #多条查询
[root@localhost pythonfile]# cat examine.py
#!/usr/bin/python import pymysql
conn=pymysql.connect(host='localhost',user='root',password='',database='db8')
cursor=conn.cursor() #游标
sql='select * from user;'
rows=cursor.execute(sql)
res1=cursor.fetchone()
print(res1)
print(cursor.fetchmany(3)) #多条查询 '''
查询结果:
[root@localhost pythonfile]# python3 examine.py
(1, 'egon', '123')
((2, 'egon1', '123'), (3, 'alex', '123'), (4, 'egon1', '123')) #以一个大元组的形式返回
''' #查所有
[root@localhost pythonfile]# cat examine.py
#!/usr/bin/python import pymysql
conn=pymysql.connect(host='localhost',user='root',password='',database='db8')
cursor=conn.cursor() #游标
sql='select * from user;'
rows=cursor.execute(sql)
print(cursor.fetchall()) #查表的所有 '''
查询结果:
[root@localhost pythonfile]# python3 examine.py
((1, 'egon', '123'), (2, 'egon1', '123'), (3, 'alex', '123'), (4, 'egon1', '123'), (5, 'alex', '123'), (6, 'ss', '121'), (7, 'laowu', '111'))
''' #光标移动查询
[root@localhost pythonfile]# cat examine.py
#!/usr/bin/python import pymysql
conn=pymysql.connect(host='localhost',user='root',password='',database='db8')
cursor=conn.cursor() #游标
sql='select * from user;'
rows=cursor.execute(sql)
print(cursor.fetchall())
cursor.scroll(1,mode='absolute') #绝对路径
print(cursor.fetchone()) '''
结果: [root@localhost pythonfile]# python3 examine.py
((1, 'egon', '123'), (2, 'egon1', '123'), (3, 'alex', '123'), (4, 'egon1', '123'), (5, 'alex', '123'), (6, 'ss', '121'), (7, 'laowu', '111'))
(2, 'egon1', '123') #光标跳到第一条后面,后面查询直接是第二条了 ''' #相对路径
[root@localhost pythonfile]# cat examine.py
#!/usr/bin/python import pymysql
conn=pymysql.connect(host='localhost',user='root',password='',database='db8')
cursor=conn.cursor() #游标
sql='select * from user;'
rows=cursor.execute(sql)
print(cursor.fetchone())
cursor.scroll(1,mode='relative') #相对路径,在原有的基础上开始移动光标
print(cursor.fetchone()) '''
输出结果:
[root@localhost pythonfile]# python3 examine.py
(1, 'egon', '123')
(3, 'alex', '123') '''

												

mysql数据库从删库到跑路之mysql其他的更多相关文章

  1. mysql数据库从删库到跑路之mysql表操作

    表介绍 表相当于文件,表中的一条记录就相当于文件的一行内容,不同的是,表中的一条记录有对应的标题,称为表的字段 id,name,qq,age称为字段,其余的,一行内容称为一条记录 内容: 1 创建表 ...

  2. mysql数据库从删库到跑路之mysql基础

    一 数据库是什么 之前所学,数据要永久保存,比如用户注册的用户信息,都是保存于文件中,而文件只能存在于某一台机器上. 如果我们不考虑从文件中读取数据的效率问题,并且假设我们的程序所有的组件都运行在一台 ...

  3. mysql数据库从删库到跑路之mysql库操作

    一 知识储备 MySQL数据库基本操作知识储备 数据库服务器:一台计算机(对内存要求比较高) 数据库管理系统:如mysql,是一个软件 数据库:oldboy_stu,相当于文件夹 表:student, ...

  4. mysql数据库从删库到跑路之mysql存储引擎

    一 什么是存储引擎 mysql中建立的库===>文件夹 库中建立的表===>文件 现实生活中我们用来存储数据的文件应该有不同的类型:比如存文本用txt类型,存表格用excel,存图片用pn ...

  5. mysql数据库从删库到跑路之mysql数据类型

    一 介绍 存储引擎决定了表的类型,而表内存放的数据也要有不同的类型,每种数据类型都有自己的宽度,但宽度是可选的 详细参考: http://www.runoob.com/mysql/mysql-data ...

  6. mysql数据库从删库到跑路之mysql完整性约束

    一 介绍 约束条件与数据类型的宽度一样,都是可选参数 作用:用于保证数据的完整性和一致性主要分为: PRIMARY KEY (PK) 标识该字段为该表的主键,可以唯一的标识记录 FOREIGN KEY ...

  7. mysql数据库从删库到跑路之mysql:视图、触发器、事务、存储过程、函数

    mysql:视图.触发器.事务.存储过程.函数 一.视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,可以将该结果 ...

  8. mysql数据库从删库到跑路之mysql多表查询

    一 介绍 本节主题 多表连接查询 复合条件连接查询 子查询 准备表 company.employeecompany.department #建表 create table department( id ...

  9. mysql数据库从删库到跑路之select单表查询

    一 介绍 本节内容: 查询语法 关键字的执行优先级 简单查询 单条件查询:WHERE 分组查询:GROUP BY HAVING 查询排序:ORDER BY 限制查询的记录数:LIMIT 使用聚合函数查 ...

随机推荐

  1. 【BZOJ】1016: [JSOI2008]最小生成树计数(kruskal+特殊的技巧)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1016 想也想不到QAQ 首先想不到的是:题目有说,具有相同权值的边不会超过10条. 其次:老是去想组 ...

  2. MySQL [Err]1449 : The user specified as a definer ('root'@'%') does not exist

    权限问题:授权 给 root 所有sql 权限 mysql> grant all privileges on *.* to root@"%" identified by &q ...

  3. C++之运行时类型识别RTTI

     C++ Code  12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 ...

  4. VC++ 设置桌面壁纸

    Windows Shell API提供了接口IActiveDesktop来完成墙纸的设置. //IActiveDesktop 接口方法表 (详情参见MSDN) AddDesktopItem AddDe ...

  5. LINQ to SQL语句(2)Count/Sum/Min/Max/Avg操作符

    使用场景 类似于SQL中的聚合函数,用于统计数据,不延迟.如返回序列中的元素数量.求和.最小值.最大值.求平均值. Count 说明:用于返回集合中元素的个数,返回Int类型,生成SQL语句为SELE ...

  6. 传参方法:sharedApplication, NSUserDefaults, protocol 和 delegate(实例)

    本文转载至  http://blog.csdn.net/learnios/article/details/8442201 分类: 功能模块2012-12-27 10:22 109人阅读 评论(0) 收 ...

  7. Codevs 5914 [SXOI2016]最大值

    70分算法+30分打表 #include<ctime> #include<cstdio> #include<cstdlib> #include<algorit ...

  8. iOS 7 Master-Detail模板不好用

    将storyboard->use size classes disabled

  9. maven web框架搭建

    前面我们描述了如何使用maven搭建一个最基本的Java Project 框架.在实际生产应用中,一般不会仅仅建立一个最基本的Java Project项目,目前 Java Web 开发已经成为Java ...

  10. java -jar后台启动

    nohup  java -jar XX.jar >logs.log &