数据库备份与pymysql

<div id="post_body" class="blogpost-body"><a name="_labelTop"></a><div id="navCategory"><p style="font-size:25px"><b>阅读目录</b></p><ul><li><a href="#_label1" style="color: darkseagreen;text-decoration:none;font-size:18px">一 IDE工具介绍</a></li><li><a href="#_label2" style="color: darkseagreen;text-decoration:none;font-size:18px">二 MySQL数据备份</a></li><li><a href="#_label3" style="color: darkseagreen;text-decoration:none;font-size:18px">三 pymysql模块</a></li></ul></div><div style="text-align: right"><a href="#_labelTop"></a><a name="_label1"></a></div><h3>一 IDE工具介绍</h3>
<p>生产环境还是推荐使用mysql命令行,但为了方便我们测试,可以使用IDE工具</p>
<p><a href="https://pan.baidu.com/s/1bpo5mqj" target="_blank">下载链接:https://pan.baidu.com/s/1bpo5mqj</a></p>
<div class="code"><div class="code_toolbar"><span class="code_copy"><a href="javascript:void(0);" onclick="copyCnblogsCode(this)" title="复制代码"><img src="/img/fz.gif" alt="复制代码"></a></span></div>
<pre><span style="color: #000000;">掌握:
</span><span style="color: #008000;">#</span><span style="color: #008000;">1. 测试+链接数据库</span><span style="color: #008000;">
#</span><span style="color: #008000;">2. 新建库</span><span style="color: #008000;">
#</span><span style="color: #008000;">3. 新建表,新增字段+类型+约束</span><span style="color: #008000;">
#</span><span style="color: #008000;">4. 设计表:外键</span><span style="color: #008000;">
#</span><span style="color: #008000;">5. 新建查询</span><span style="color: #008000;">
#</span><span style="color: #008000;">6. 备份库/表</span>

<span style="color: #008000;">#</span><span style="color: #008000;">注意:</span>
批量加注释:ctrl+<span style="color: #000000;">?键
批量去注释:ctrl</span>+shift+?键</pre>
<div class="code_toolbar"><span class="code_copy"><a href="javascript:void(0);" onclick="copyCnblogsCode(this)" title="复制代码"><img src="/img/fz.gif" alt="复制代码"></a></span></div></div>
<div style="text-align: right"><a href="#_labelTop"></a><a name="_label2"></a></div><h3>二 MySQL数据备份</h3>
<div class="code">
<pre><span style="color: #008000;">#</span><span style="color: #008000;">1. 物理备份: 直接复制数据库文件,适用于大型数据库环境。但不能恢复到异构系统中如Windows。</span><span style="color: #008000;">
#</span><span style="color: #008000;">2. 逻辑备份: 备份的是建表、建库、插入等操作所执行SQL语句,适用于中小型数据库,效率相对较低。</span><span style="color: #008000;">
#</span><span style="color: #008000;">3. 导出表: 将表导入到文本文件中。</span>&nbsp;</pre>
</div>
<p><span style="font-size: 18px;"><strong>一、使用mysqldump实现逻辑备份</strong></span></p>
<div class="code"><div class="code_toolbar"><span class="code_copy"><a href="javascript:void(0);" onclick="copyCnblogsCode(this)" title="复制代码"><img src="/img/fz.gif" alt="复制代码"></a></span></div>
<pre><span style="color: #008000;">#</span><span style="color: #008000;">语法:</span><span style="color: #008000;">
#</span><span style="color: #008000;"> mysqldump -h 服务器 -u用户名 -p密码 数据库名 &gt; 备份文件.sql</span>

<span style="color: #008000;">#</span><span style="color: #008000;">示例:</span><span style="color: #008000;">
#</span><span style="color: #008000;">单库备份</span>
mysqldump -uroot -p123 db1 &gt;<span style="color: #000000;"> db1.sql
mysqldump </span>-uroot -p123 db1 table1 table2 &gt; db1-table1-<span style="color: #000000;">table2.sql

</span><span style="color: #008000;">#</span><span style="color: #008000;">多库备份</span>
mysqldump -uroot -p123 --databases db1 db2 mysql db3 &gt;<span style="color: #000000;"> db1_db2_mysql_db3.sql

</span><span style="color: #008000;">#</span><span style="color: #008000;">备份所有库</span>
mysqldump -uroot -p123 --all-databases &gt; all.sql&nbsp;</pre>
<div class="code_toolbar"><span class="code_copy"><a href="javascript:void(0);" onclick="copyCnblogsCode(this)" title="复制代码"><img src="/img/fz.gif" alt="复制代码"></a></span></div></div>
<p><span style="font-size: 18px;"><strong><strong>二、恢复逻辑备份</strong></strong></span></p>
<div class="code"><div class="code_toolbar"><span class="code_copy"><a href="javascript:void(0);" onclick="copyCnblogsCode(this)" title="复制代码"><img src="/img/fz.gif" alt="复制代码"></a></span></div>
<pre><span style="color: #008000;">#</span><span style="color: #008000;">方法一:</span>
[[email protected] backup]<span style="color: #008000;">#</span><span style="color: #008000;"> mysql -uroot -p123 &lt; /backup/all.sql</span>

<span style="color: #008000;">#</span><span style="color: #008000;">方法二:</span>
mysql&gt;<span style="color: #000000;"> use db1;
mysql</span>&gt; SET SQL_LOG_BIN=<span style="color: #000000;">0;
mysql</span>&gt; source /root/<span style="color: #000000;">db1.sql

</span><span style="color: #008000;">#</span><span style="color: #008000;">注:如果备份/恢复单个库时,可以修改sql文件</span>
DROP database <span style="color: #0000ff;">if</span><span style="color: #000000;"> exists school;
create database school;
use school;</span>&nbsp;</pre>
<div class="code_toolbar"><span class="code_copy"><a href="javascript:void(0);" onclick="copyCnblogsCode(this)" title="复制代码"><img src="/img/fz.gif" alt="复制代码"></a></span></div></div>
<p><span style="font-size: 18px;"><strong>三、备份/恢复案例</strong></span></p>
<div class="code" onclick="code_show(‘5b4cb974-74cf-4727-972c-ea5e88956d30‘)"><img id="code_img_closed_5b4cb974-74cf-4727-972c-ea5e88956d30" class="code_img_closed" src="/img/jia.gif" ><img id="code_img_opened_5b4cb974-74cf-4727-972c-ea5e88956d30" class="code_img_opened" style="display: none;" onclick="code_hide(‘5b4cb974-74cf-4727-972c-ea5e88956d30‘,event)" src="/img/jian.gif" >
<div id="code_open_5b4cb974-74cf-4727-972c-ea5e88956d30" class="code_hide">
<pre><span style="color: #008000;">#</span><span style="color: #008000;">数据库备份/恢复实验一:数据库损坏</span>
<span style="color: #000000;">备份:
</span>1. <span style="color: #008000;">#</span><span style="color: #008000;"> mysqldump -uroot -p123 --all-databases &gt; /backup/`date +%F`_all.sql</span>
2. <span style="color: #008000;">#</span><span style="color: #008000;"> mysql -uroot -p123 -e ‘flush logs‘ //截断并产生新的binlog</span>
3. 插入数据 //<span style="color: #000000;">模拟服务器正常运行
</span>4. mysql&gt; set sql_log_bin=0; //<span style="color: #000000;">模拟服务器损坏
mysql</span>&gt;<span style="color: #000000;"> drop database db;

恢复:
</span>1. <span style="color: #008000;">#</span><span style="color: #008000;"> mysqlbinlog 最后一个binlog &gt; /backup/last_bin.log</span>
2. mysql&gt; set sql_log_bin=<span style="color: #000000;">0;
mysql</span>&gt; source /backup/2014-02-13_all.sql //<span style="color: #000000;">恢复最近一次完全备份
mysql</span>&gt; source /backup/last_bin.log //<span style="color: #000000;">恢复最后个binlog文件

</span><span style="color: #008000;">#</span><span style="color: #008000;">数据库备份/恢复实验二:如果有误删除</span>
<span style="color: #000000;">备份:
</span>1. mysqldump -uroot -p123 --all-databases &gt; /backup/`date +%<span style="color: #000000;">F`_all.sql
</span>2. mysql -uroot -p123 -e <span style="color: #800000;">‘</span><span style="color: #800000;">flush logs</span><span style="color: #800000;">‘</span> //<span style="color: #000000;">截断并产生新的binlog
</span>3. 插入数据 //<span style="color: #000000;">模拟服务器正常运行
</span>4. drop table db1.t1 //<span style="color: #000000;">模拟误删除
</span>5. 插入数据 //<span style="color: #000000;">模拟服务器正常运行

恢复:
</span>1. <span style="color: #008000;">#</span><span style="color: #008000;"> mysqlbinlog 最后一个binlog --stop-position=260 &gt; /tmp/1.sql </span><span style="color: #008000;">
#</span><span style="color: #008000;"> mysqlbinlog 最后一个binlog --start-position=900 &gt; /tmp/2.sql </span>
2. mysql&gt; set sql_log_bin=<span style="color: #000000;">0;
mysql</span>&gt; source /backup/2014-02-13_all.sql //<span style="color: #000000;">恢复最近一次完全备份
mysql</span>&gt; source /tmp/1.log //<span style="color: #000000;">恢复最后个binlog文件
mysql</span>&gt; source /tmp/2.log //<span style="color: #000000;">恢复最后个binlog文件

注意事项:
</span>1<span style="color: #000000;">. 完全恢复到一个干净的环境(例如新的数据库或删除原有的数据库)
</span>2. 恢复期间所有SQL语句不应该记录到binlog中</pre>
</div>
<span class="code_collapse"></span></div>
<p><span style="font-size: 18px;"><strong><strong>四、实现自动化备份</strong></strong></span></p>
<div class="code" onclick="code_show(‘f451285c-0744-403d-8073-c5f29cb9044a‘)"><img id="code_img_closed_f451285c-0744-403d-8073-c5f29cb9044a" class="code_img_closed" src="/img/jia.gif" ><img id="code_img_opened_f451285c-0744-403d-8073-c5f29cb9044a" class="code_img_opened" style="display: none;" onclick="code_hide(‘f451285c-0744-403d-8073-c5f29cb9044a‘,event)" src="/img/jian.gif" >
<div id="code_open_f451285c-0744-403d-8073-c5f29cb9044a" class="code_hide">
<pre><span style="color: #000000;">备份计划:
</span>1. 什么时间 2:00
2<span style="color: #000000;">. 对哪些数据库备份
</span>3<span style="color: #000000;">. 备份文件放的位置

备份脚本:
[[email protected] </span>~]<span style="color: #008000;">#</span><span style="color: #008000;"> vim /mysql_back.sql</span><span style="color: #008000;">
#</span><span style="color: #008000;">!/bin/bash</span>
back_dir=/<span style="color: #000000;">backup
back_file</span>=`date +%<span style="color: #000000;">F`_all.sql
user</span>=<span style="color: #000000;">root
</span><span style="color: #0000ff;">pass</span>=123

<span style="color: #0000ff;">if</span> [ ! -d /<span style="color: #000000;">backup ];then
mkdir </span>-p /<span style="color: #000000;">backup
fi

</span><span style="color: #008000;">#</span><span style="color: #008000;"> 备份并截断日志</span>
mysqldump -u${user} -p${<span style="color: #0000ff;">pass</span>} --events --all-databases &gt; ${back_dir}/<span style="color: #000000;">${back_file}
mysql </span>-u${user} -p${<span style="color: #0000ff;">pass</span>} -e <span style="color: #800000;">‘</span><span style="color: #800000;">flush logs</span><span style="color: #800000;">‘</span>

<span style="color: #008000;">#</span><span style="color: #008000;"> 只保留最近一周的备份</span>
<span style="color: #000000;">cd $back_dir
find . </span>-mtime +7 -<span style="color: #0000ff;">exec</span> rm -<span style="color: #000000;">rf {} \;

手动测试:
[[email protected] </span>~]<span style="color: #008000;">#</span><span style="color: #008000;"> chmod a+x /mysql_back.sql </span>
[[email protected] ~]<span style="color: #008000;">#</span><span style="color: #008000;"> chattr +i /mysql_back.sql</span>
[[email protected] ~]<span style="color: #008000;">#</span><span style="color: #008000;"> /mysql_back.sql</span>
<span style="color: #000000;">
配置cron:
[[email protected] </span>~]<span style="color: #008000;">#</span><span style="color: #008000;"> crontab -l</span>
2 * * * /mysql_back.sql</pre>
</div>
<span class="code_collapse"></span></div>
<p><span style="font-size: 18px;"><strong>五、表的导出和导入</strong></span></p>
<div class="code" onclick="code_show(‘0f09fea7-3001-4315-969a-5e7678dac9b5‘)"><img id="code_img_closed_0f09fea7-3001-4315-969a-5e7678dac9b5" class="code_img_closed" src="/img/jia.gif" ><img id="code_img_opened_0f09fea7-3001-4315-969a-5e7678dac9b5" class="code_img_opened" style="display: none;" onclick="code_hide(‘0f09fea7-3001-4315-969a-5e7678dac9b5‘,event)" src="/img/jian.gif" >
<div id="code_open_0f09fea7-3001-4315-969a-5e7678dac9b5" class="code_hide">
<pre><span style="color: #000000;">SELECT... INTO OUTFILE 导出文本文件
示例:
mysql</span>&gt; SELECT *<span style="color: #000000;"> FROM school.student1
INTO OUTFILE </span><span style="color: #800000;">‘</span><span style="color: #800000;">student1.txt</span><span style="color: #800000;">‘</span><span style="color: #000000;">
FIELDS TERMINATED BY </span><span style="color: #800000;">‘</span><span style="color: #800000;">,</span><span style="color: #800000;">‘</span> //<span style="color: #000000;">定义字段分隔符
OPTIONALLY ENCLOSED BY </span><span style="color: #800000;">‘</span><span style="color: #800000;">”</span><span style="color: #800000;">‘</span> //<span style="color: #000000;">定义字符串使用什么符号括起来
LINES TERMINATED BY </span><span style="color: #800000;">‘</span><span style="color: #800000;">\n</span><span style="color: #800000;">‘</span> ; //<span style="color: #000000;">定义换行符

mysql 命令导出文本文件
示例:
</span><span style="color: #008000;">#</span><span style="color: #008000;"> mysql -u root -p123 -e ‘select * from student1.school‘ &gt; /tmp/student1.txt</span><span style="color: #008000;">
#</span><span style="color: #008000;"> mysql -u root -p123 --xml -e ‘select * from student1.school‘ &gt; /tmp/student1.xml</span><span style="color: #008000;">
#</span><span style="color: #008000;"> mysql -u root -p123 --html -e ‘select * from student1.school‘ &gt; /tmp/student1.html</span>
<span style="color: #000000;">
LOAD DATA INFILE 导入文本文件
mysql</span>&gt;<span style="color: #000000;"> DELETE FROM student1;
mysql</span>&gt; LOAD DATA INFILE <span style="color: #800000;">‘</span><span style="color: #800000;">/tmp/student1.txt</span><span style="color: #800000;">‘</span><span style="color: #000000;">
INTO TABLE school.student1
FIELDS TERMINATED BY </span><span style="color: #800000;">‘</span><span style="color: #800000;">,</span><span style="color: #800000;">‘</span><span style="color: #000000;">
OPTIONALLY ENCLOSED BY </span><span style="color: #800000;">‘</span><span style="color: #800000;">”</span><span style="color: #800000;">‘</span><span style="color: #000000;">
LINES TERMINATED BY </span><span style="color: #800000;">‘</span><span style="color: #800000;">\n</span><span style="color: #800000;">‘</span>;</pre>
</div>
<span class="code_collapse"></span></div>
<div class="code" onclick="code_show(‘b99f6256-cf1f-43b7-a7bc-2789b62b4480‘)"><img id="code_img_closed_b99f6256-cf1f-43b7-a7bc-2789b62b4480" class="code_img_closed" src="/img/jia.gif" ><img id="code_img_opened_b99f6256-cf1f-43b7-a7bc-2789b62b4480" class="code_img_opened" style="display: none;" onclick="code_hide(‘b99f6256-cf1f-43b7-a7bc-2789b62b4480‘,event)" src="/img/jian.gif" >
<div id="code_open_b99f6256-cf1f-43b7-a7bc-2789b62b4480" class="code_hide">
<pre><span style="color: #008000;">#</span><span style="color: #008000;">可能会报错</span>
mysql&gt; select * <span style="color: #0000ff;">from</span> db1.emp into outfile <span style="color: #800000;">‘</span><span style="color: #800000;">C:\\db1.emp.txt</span><span style="color: #800000;">‘</span> fields terminated by <span style="color: #800000;">‘</span><span style="color: #800000;">,</span><span style="color: #800000;">‘</span> lines terminated by <span style="color: #800000;">‘</span><span style="color: #800000;">\r\n</span><span style="color: #800000;">‘</span><span style="color: #000000;">;
ERROR </span>1238 (HY000): Variable <span style="color: #800000;">‘</span><span style="color: #800000;">secure_file_priv</span><span style="color: #800000;">‘</span> <span style="color: #0000ff;">is</span><span style="color: #000000;"> a read only variable

</span><span style="color: #008000;">#</span><span style="color: #008000;">数据库最关键的是数据,一旦数据库权限泄露,那么通过上述语句就可以轻松将数据导出到文件中然后下载拿走,因而mysql对此作了限制,只能将文件导出到指定目录</span>
<span style="color: #000000;">在配置文件中
[mysqld]
secure_file_priv</span>=<span style="color: #800000;">‘</span><span style="color: #800000;">C:\\</span><span style="color: #800000;">‘</span> <span style="color: #008000;">#</span><span style="color: #008000;">只能将数据导出到C:\\下</span>
<span style="color: #000000;">
重启mysql
重新执行上述语句</span></pre>
</div>
<span class="code_collapse">报错:Variable ‘secure_file_priv‘ is a read only</span></div>
<p><span style="font-size: 18px;"><strong><strong>六、数据库迁移</strong></strong></span></p>
<div class="code">
<pre><span style="color: #000000;">务必保证在相同版本之间迁移
</span><span style="color: #008000;">#</span><span style="color: #008000;"> mysqldump -h 源IP -uroot -p123 --databases db1 | mysql -h 目标IP -uroot -p456</span></pre>
</div>
<div style="text-align: right"><a href="#_labelTop"></a><a name="_label3"></a></div><h3>三 pymysql模块</h3>
<div class="code">
<pre><span style="color: #008000;">#</span><span style="color: #008000;">安装</span>
pip3 install pymysql</pre>
</div>
<p><span style="font-size: 18px;"><strong>一 链接、执行sql、关闭(游标)</strong></span></p>
<p><img src="https://images2017.cnblogs.com/blog/1036857/201709/1036857-20170915114556719-2064840662.png" ></p>
<div class="code"><div class="code_toolbar"><span class="code_copy"><a href="javascript:void(0);" onclick="copyCnblogsCode(this)" title="复制代码"><img src="/img/fz.gif" alt="复制代码"></a></span></div>
<pre><span style="color: #0000ff;">import</span><span style="color: #000000;"> pymysql
user</span>=input(<span style="color: #800000;">‘</span><span style="color: #800000;">用户名: </span><span style="color: #800000;">‘</span><span style="color: #000000;">).strip()
pwd</span>=input(<span style="color: #800000;">‘</span><span style="color: #800000;">密码: </span><span style="color: #800000;">‘</span><span style="color: #000000;">).strip()

</span><span style="color: #008000;">#</span><span style="color: #008000;">链接</span>
conn=pymysql.connect(host=<span style="color: #800000;">‘</span><span style="color: #800000;">localhost</span><span style="color: #800000;">‘</span>,user=<span style="color: #800000;">‘</span><span style="color: #800000;">root</span><span style="color: #800000;">‘</span>,password=<span style="color: #800000;">‘</span><span style="color: #800000;">123</span><span style="color: #800000;">‘</span>,database=<span style="color: #800000;">‘</span><span style="color: #800000;">egon</span><span style="color: #800000;">‘</span>,charset=<span style="color: #800000;">‘</span><span style="color: #800000;">utf8</span><span style="color: #800000;">‘</span><span style="color: #000000;">)
</span><span style="color: #008000;">#</span><span style="color: #008000;">游标</span>
cursor=conn.cursor() <span style="color: #008000;">#</span><span style="color: #008000;">执行完毕返回的结果集默认以元组显示</span><span style="color: #008000;">
#</span><span style="color: #008000;">cursor=conn.cursor(cursor=pymysql.cursors.DictCursor)</span>

<span style="color: #008000;">#</span><span style="color: #008000;">执行sql语句</span>
sql=<span style="color: #800000;">‘</span><span style="color: #800000;">select * from userinfo where name="%s" and password="%s"</span><span style="color: #800000;">‘</span> %(user,pwd) <span style="color: #008000;">#</span><span style="color: #008000;">注意%s需要加引号</span>
<span style="color: #0000ff;">print</span><span style="color: #000000;">(sql)
res</span>=cursor.execute(sql) <span style="color: #008000;">#</span><span style="color: #008000;">执行sql语句,返回sql查询成功的记录数目</span>
<span style="color: #0000ff;">print</span><span style="color: #000000;">(res)

cursor.close()
conn.close()

</span><span style="color: #0000ff;">if</span><span style="color: #000000;"> res:
</span><span style="color: #0000ff;">print</span>(<span style="color: #800000;">‘</span><span style="color: #800000;">登录成功</span><span style="color: #800000;">‘</span><span style="color: #000000;">)
</span><span style="color: #0000ff;">else</span><span style="color: #000000;">:
</span><span style="color: #0000ff;">print</span>(<span style="color: #800000;">‘</span><span style="color: #800000;">登录失败</span><span style="color: #800000;">‘</span>)</pre>
<div class="code_toolbar"><span class="code_copy"><a href="javascript:void(0);" onclick="copyCnblogsCode(this)" title="复制代码"><img src="/img/fz.gif" alt="复制代码"></a></span></div></div>
<p><span style="font-size: 18px;"><strong>二 execute()之sql注入</strong></span></p>
<p>注意:符号--会注释掉它之后的sql,正确的语法:--后至少有一个任意字符</p>
<p>根本原理:就根据程序的字符串拼接name=‘%s‘,我们输入一个<span style="color: #ff0000;"><em><strong>xxx‘ -- haha</strong></em></span>,用我们输入的xxx加‘在程序中拼接成一个判断条件name=‘<span style="color: #ff0000;"><em><strong>xxx‘ -- haha</strong></em></span>‘</p>
<div class="code"><div class="code_toolbar"><span class="code_copy"><a href="javascript:void(0);" onclick="copyCnblogsCode(this)" title="复制代码"><img src="/img/fz.gif" alt="复制代码"></a></span></div>
<pre>最后那一个空格,在一条sql语句中如果遇到select * <span style="color: #0000ff;">from</span> t1 where id &gt; 3 -- <span style="color: #0000ff;">and</span> name=<span style="color: #800000;">‘</span><span style="color: #800000;">egon</span><span style="color: #800000;">‘</span>;则--<span style="color: #000000;">之后的条件被注释掉了

</span><span style="color: #008000;">#</span><span style="color: #008000;">1、sql注入之:用户存在,绕过密码</span>
egon<span style="color: #800000;">‘</span><span style="color: #800000;"> -- 任意字符</span>

<span style="color: #008000;">#</span><span style="color: #008000;">2、sql注入之:用户不存在,绕过用户与密码</span>
xxx<span style="color: #800000;">‘</span><span style="color: #800000;"> or 1=1 -- 任意字符</span></pre>
<div class="code_toolbar"><span class="code_copy"><a href="javascript:void(0);" onclick="copyCnblogsCode(this)" title="复制代码"><img src="/img/fz.gif" alt="复制代码"></a></span></div></div>
<p><img src="https://images2017.cnblogs.com/blog/1036857/201709/1036857-20170914080611375-1304472294.png" width="663" height="197"></p>
<p><img src="https://images2017.cnblogs.com/blog/1036857/201709/1036857-20170914073716813-2024667165.png" width="662" height="161"></p>
<p><img src="https://images2017.cnblogs.com/blog/1036857/201709/1036857-20170914073927438-1525371660.png" width="662" height="173">&nbsp;</p>
<p>解决方法:</p>
<div class="code"><div class="code_toolbar"><span class="code_copy"><a href="javascript:void(0);" onclick="copyCnblogsCode(this)" title="复制代码"><img src="/img/fz.gif" alt="复制代码"></a></span></div>
<pre><span style="color: #008000;">#</span><span style="color: #008000;"> 原来是我们对sql进行字符串拼接</span><span style="color: #008000;">
#</span><span style="color: #008000;"> sql="select * from userinfo where name=‘%s‘ and password=‘%s‘" %(user,pwd)</span><span style="color: #008000;">
#</span><span style="color: #008000;"> print(sql)</span><span style="color: #008000;">
#</span><span style="color: #008000;"> res=cursor.execute(sql)</span>

<span style="color: #008000;">#</span><span style="color: #008000;">改写为(execute帮我们做字符串拼接,我们无需且一定不能再为%s加引号了)</span>
sql=<span style="color: #800000;">"</span><span style="color: #800000;">select * from userinfo where name=%s and password=%s</span><span style="color: #800000;">"</span> <span style="color: #008000;">#</span><span style="color: #008000;">!!!注意%s需要去掉引号,因为pymysql会自动为我们加上</span>
res=cursor.execute(sql,[user,pwd]) <span style="color: #008000;">#</span><span style="color: #008000;">pymysql模块自动帮我们解决sql注入的问题,只要我们按照pymysql的规矩来。</span></pre>
<div class="code_toolbar"><span class="code_copy"><a href="javascript:void(0);" onclick="copyCnblogsCode(this)" title="复制代码"><img src="/img/fz.gif" alt="复制代码"></a></span></div></div>
<p><strong><span style="font-size: 18px;">三 增、删、改:conn.commit()</span></strong></p>
<div class="code" onclick="code_show(‘2ffcf73c-8ec6-4e08-8173-01d4243cf6bd‘)"><img id="code_img_closed_2ffcf73c-8ec6-4e08-8173-01d4243cf6bd" class="code_img_closed" src="/img/jia.gif" ><img id="code_img_opened_2ffcf73c-8ec6-4e08-8173-01d4243cf6bd" class="code_img_opened" style="display: none;" onclick="code_hide(‘2ffcf73c-8ec6-4e08-8173-01d4243cf6bd‘,event)" src="/img/jian.gif" >
<div id="code_open_2ffcf73c-8ec6-4e08-8173-01d4243cf6bd" class="code_hide">
<pre><span style="color: #0000ff;">import</span><span style="color: #000000;"> pymysql
</span><span style="color: #008000;">#</span><span style="color: #008000;">链接</span>
conn=pymysql.connect(host=<span style="color: #800000;">‘</span><span style="color: #800000;">localhost</span><span style="color: #800000;">‘</span>,user=<span style="color: #800000;">‘</span><span style="color: #800000;">root</span><span style="color: #800000;">‘</span>,password=<span style="color: #800000;">‘</span><span style="color: #800000;">123</span><span style="color: #800000;">‘</span>,database=<span style="color: #800000;">‘</span><span style="color: #800000;">egon</span><span style="color: #800000;">‘</span><span style="color: #000000;">)
</span><span style="color: #008000;">#</span><span style="color: #008000;">游标</span>
cursor=<span style="color: #000000;">conn.cursor()

</span><span style="color: #008000;">#</span><span style="color: #008000;">执行sql语句</span><span style="color: #008000;">
#</span><span style="color: #008000;">part1</span><span style="color: #008000;">
#</span><span style="color: #008000;"> sql=‘insert into userinfo(name,password) values("root","123456");‘</span><span style="color: #008000;">
#</span><span style="color: #008000;"> res=cursor.execute(sql) #执行sql语句,返回sql影响成功的行数</span><span style="color: #008000;">
#</span><span style="color: #008000;"> print(res)</span>

<span style="color: #008000;">#</span><span style="color: #008000;">part2</span><span style="color: #008000;">
#</span><span style="color: #008000;"> sql=‘insert into userinfo(name,password) values(%s,%s);‘</span><span style="color: #008000;">
#</span><span style="color: #008000;"> res=cursor.execute(sql,("root","123456")) #执行sql语句,返回sql影响成功的行数</span><span style="color: #008000;">
#</span><span style="color: #008000;"> print(res)</span>

<span style="color: #008000;">#</span><span style="color: #008000;">part3</span>
sql=<span style="color: #800000;">‘</span><span style="color: #800000;">insert into userinfo(name,password) values(%s,%s);</span><span style="color: #800000;">‘</span><span style="color: #000000;">
res</span>=cursor.executemany(sql,[(<span style="color: #800000;">"</span><span style="color: #800000;">root</span><span style="color: #800000;">"</span>,<span style="color: #800000;">"</span><span style="color: #800000;">123456</span><span style="color: #800000;">"</span>),(<span style="color: #800000;">"</span><span style="color: #800000;">lhf</span><span style="color: #800000;">"</span>,<span style="color: #800000;">"</span><span style="color: #800000;">12356</span><span style="color: #800000;">"</span>),(<span style="color: #800000;">"</span><span style="color: #800000;">eee</span><span style="color: #800000;">"</span>,<span style="color: #800000;">"</span><span style="color: #800000;">156</span><span style="color: #800000;">"</span>)]) <span style="color: #008000;">#</span><span style="color: #008000;">执行sql语句,返回sql影响成功的行数</span>
<span style="color: #0000ff;">print</span><span style="color: #000000;">(res)

conn.commit() </span><span style="color: #008000;">#</span><span style="color: #008000;">提交后才发现表中插入记录成功</span>
<span style="color: #000000;">cursor.close()
conn.close()</span></pre>
</div>
<span class="code_collapse"></span></div>
<p><strong><span style="font-size: 18px;">四 查:fetchone,fetchmany,fetchall</span></strong></p>
<p><img src="https://images2017.cnblogs.com/blog/1036857/201709/1036857-20170914075702438-239735784.png" ></p>
<div class="code" onclick="code_show(‘eaca94cb-c582-43eb-b0f1-7cb682603c4e‘)"><img id="code_img_closed_eaca94cb-c582-43eb-b0f1-7cb682603c4e" class="code_img_closed" src="/img/jia.gif" ><img id="code_img_opened_eaca94cb-c582-43eb-b0f1-7cb682603c4e" class="code_img_opened" style="display: none;" onclick="code_hide(‘eaca94cb-c582-43eb-b0f1-7cb682603c4e‘,event)" src="/img/jian.gif" >
<div id="code_open_eaca94cb-c582-43eb-b0f1-7cb682603c4e" class="code_hide">
<pre><span style="color: #0000ff;">import</span><span style="color: #000000;"> pymysql
</span><span style="color: #008000;">#</span><span style="color: #008000;">链接</span>
conn=pymysql.connect(host=<span style="color: #800000;">‘</span><span style="color: #800000;">localhost</span><span style="color: #800000;">‘</span>,user=<span style="color: #800000;">‘</span><span style="color: #800000;">root</span><span style="color: #800000;">‘</span>,password=<span style="color: #800000;">‘</span><span style="color: #800000;">123</span><span style="color: #800000;">‘</span>,database=<span style="color: #800000;">‘</span><span style="color: #800000;">egon</span><span style="color: #800000;">‘</span><span style="color: #000000;">)
</span><span style="color: #008000;">#</span><span style="color: #008000;">游标</span>
cursor=<span style="color: #000000;">conn.cursor()

</span><span style="color: #008000;">#</span><span style="color: #008000;">执行sql语句</span>
sql=<span style="color: #800000;">‘</span><span style="color: #800000;">select * from userinfo;</span><span style="color: #800000;">‘</span><span style="color: #000000;">
rows</span>=cursor.execute(sql) <span style="color: #008000;">#</span><span style="color: #008000;">执行sql语句,返回sql影响成功的行数rows,将结果放入一个集合,等待被查询</span>

<span style="color: #008000;">#</span><span style="color: #008000;"> cursor.scroll(3,mode=‘absolute‘) # 相对绝对位置移动</span><span style="color: #008000;">
#</span><span style="color: #008000;"> cursor.scroll(3,mode=‘relative‘) # 相对当前位置移动</span>
res1=<span style="color: #000000;">cursor.fetchone()
res2</span>=<span style="color: #000000;">cursor.fetchone()
res3</span>=<span style="color: #000000;">cursor.fetchone()
res4</span>=cursor.fetchmany(2<span style="color: #000000;">)
res5</span>=<span style="color: #000000;">cursor.fetchall()
</span><span style="color: #0000ff;">print</span><span style="color: #000000;">(res1)
</span><span style="color: #0000ff;">print</span><span style="color: #000000;">(res2)
</span><span style="color: #0000ff;">print</span><span style="color: #000000;">(res3)
</span><span style="color: #0000ff;">print</span><span style="color: #000000;">(res4)
</span><span style="color: #0000ff;">print</span><span style="color: #000000;">(res5)
</span><span style="color: #0000ff;">print</span>(<span style="color: #800000;">‘</span><span style="color: #800000;">%s rows in set (0.00 sec)</span><span style="color: #800000;">‘</span> %<span style="color: #000000;">rows)

conn.commit() </span><span style="color: #008000;">#</span><span style="color: #008000;">提交后才发现表中插入记录成功</span>
<span style="color: #000000;">cursor.close()
conn.close()

</span><span style="color: #800000;">‘‘‘</span><span style="color: #800000;">
(1, ‘root‘, ‘123456‘)
(2, ‘root‘, ‘123456‘)
(3, ‘root‘, ‘123456‘)
((4, ‘root‘, ‘123456‘), (5, ‘root‘, ‘123456‘))
((6, ‘root‘, ‘123456‘), (7, ‘lhf‘, ‘12356‘), (8, ‘eee‘, ‘156‘))
rows in set (0.00 sec)
</span><span style="color: #800000;">‘‘‘</span></pre>
</div>
<span class="code_collapse"></span></div>
<p><strong><span style="font-size: 18px;">五 获取插入的最后一条数据的自增ID</span></strong></p>
<div class="code" onclick="code_show(‘c633ac75-1e62-416a-92fc-7c3784f11f9f‘)"><img id="code_img_closed_c633ac75-1e62-416a-92fc-7c3784f11f9f" class="code_img_closed" src="/img/jia.gif" ><img id="code_img_opened_c633ac75-1e62-416a-92fc-7c3784f11f9f" class="code_img_opened" style="display: none;" onclick="code_hide(‘c633ac75-1e62-416a-92fc-7c3784f11f9f‘,event)" src="/img/jian.gif" >
<div id="code_open_c633ac75-1e62-416a-92fc-7c3784f11f9f" class="code_hide">
<pre><span style="color: #0000ff;">import</span><span style="color: #000000;"> pymysql
conn</span>=pymysql.connect(host=<span style="color: #800000;">‘</span><span style="color: #800000;">localhost</span><span style="color: #800000;">‘</span>,user=<span style="color: #800000;">‘</span><span style="color: #800000;">root</span><span style="color: #800000;">‘</span>,password=<span style="color: #800000;">‘</span><span style="color: #800000;">123</span><span style="color: #800000;">‘</span>,database=<span style="color: #800000;">‘</span><span style="color: #800000;">egon</span><span style="color: #800000;">‘</span><span style="color: #000000;">)
cursor</span>=<span style="color: #000000;">conn.cursor()

sql</span>=<span style="color: #800000;">‘</span><span style="color: #800000;">insert into userinfo(name,password) values("xxx","123");</span><span style="color: #800000;">‘</span><span style="color: #000000;">
rows</span>=<span style="color: #000000;">cursor.execute(sql)
</span><span style="color: #0000ff;">print</span>(cursor.lastrowid) <span style="color: #008000;">#</span><span style="color: #008000;">在插入语句后查看</span>
<span style="color: #000000;">
conn.commit()

cursor.close()
conn.close()</span></pre>
</div>
<span class="code_collapse"></span></div>
<p>&nbsp;</p></div>

原文地址:https://www.cnblogs.com/chengyizhisan/p/10104323.html

时间: 2024-10-19 12:58:17

数据库备份与pymysql的相关文章

Python数据库MySQL之数据备份、pymysql模块

一 IDE工具介绍 生产环境还是推荐使用mysql命令行,但为了方便我们测试,可以使用IDE工具 下载链接:https://pan.baidu.com/s/1bpo5mqj 掌握: #1. 测试+链接数据库 #2. 新建库 #3. 新建表,新增字段+类型+约束 #4. 设计表:外键 #5. 新建查询 #6. 备份库/表 #注意: 批量加注释:ctrl+?键 批量去注释:ctrl+shift+?键 二 MySQL数据备份 #1. 物理备份: 直接复制数据库文件,适用于大型数据库环境.但不能恢复到异

mysql:数据备份、pymysql模块

一 IDE工具介绍 生产环境还是推荐使用mysql命令行,但为了方便我们测试,可以使用IDE工具 下载链接:https://pan.baidu.com/s/1bpo5mqj 掌握: #1. 测试+链接数据库 #2. 新建库 #3. 新建表,新增字段+类型+约束 #4. 设计表:外键 #5. 新建查询 #6. 备份库/表 #注意: 批量加注释:ctrl+?键 批量去注释:ctrl+shift+?键 二 MySQL数据备份 #1. 物理备份: 直接复制数据库文件,适用于大型数据库环境.但不能恢复到异

mysql六:数据备份、pymysql模块

阅读目录 一 IDE工具介绍 二 MySQL数据备份 三 pymysql模块 一 IDE工具介绍 生产环境还是推荐使用mysql命令行,但为了方便我们测试,可以使用IDE工具 下载链接:https://pan.baidu.com/s/1bpo5mqj 掌握: #1. 测试+链接数据库 #2. 新建库 #3. 新建表,新增字段+类型+约束 #4. 设计表:外键 #5. 新建查询 #6. 备份库/表 #注意: 批量加注释:ctrl+?键 批量去注释:ctrl+shift+?键 二 MySQL数据备份

Mysql(六):数据备份、pymysql模块

一 IDE工具介绍 生产环境还是推荐使用mysql命令行,但为了方便我们测试,可以使用IDE工具 下载链接:https://pan.baidu.com/s/1bpo5mqj 掌握: #1. 测试+链接数据库 #2. 新建库 #3. 新建表,新增字段+类型+约束 #4. 设计表:外键 #5. 新建查询 #6. 备份库/表 #注意: 批量加注释:ctrl+?键 批量去注释:ctrl+shift+?键 二 MySQL数据备份 #1. 物理备份: 直接复制数据库文件,适用于大型数据库环境.但不能恢复到异

数据备份、pymysql模块

MySQL数据备份 #1. 物理备份: 直接复制数据库文件,适用于大型数据库环境.但不能恢复到异构系统中如Windows. #2. 逻辑备份: 备份的是建表.建库.插入等操作所执行SQL语句,适用于中小型数据库,效率相对较低. #3. 导出表: 将表导入到文本文件中.  一.使用mysqldump实现逻辑备份 #语法: # mysqldump -h 服务器 -u用户名 -p密码 数据库名 > 备份文件.sql #示例: #单库备份 mysqldump -uroot -p123 db1 > db

golang实现mysql数据库备份

背景 navicat是mysql可视化工具中最棒的,但是,在处理视图的导入导出方面,它是按照视图名称的字母顺序来处理的,若视图存在依赖,在导入过程中就会报错.前面已经用python写了一个,但在使用过程中,遇到xfffd编码,python的pymysql会直接崩溃.发现golang没有这个问题,正好用go重写,来熟悉golang. 一些关键点 map & json,在处理主键与外键信息时,需要用到json数据结构来存储中间结果,因为要灵活处理,在golang中只能用map[string]inte

数据库MySQL之 视图、触发器、存储过程、函数、事务、数据库锁、数据库备份、事件

浏览目录 视图 触发器 存储过程 函数 事务 数据库锁 数据库备份 事件 一.视图 1.视图概念 视图是一个虚拟表,其内容由查询定义.同真实的表一样,视图包含一系列带有名称的列和行数据. 2.视图特点 视图的列可以来自不同的表,是表的抽象和逻辑意义上建立的新关系 视图是由基本表(实表)产生的表(虚表) 视图的建立和删除不影响基本表 对视图内容的更新(添加.删除和修改)直接影响基本表 当视图来自多个基本表时,不允许添加,修改和删除数据 3.视图的本质 视图是根据SQL语句获取动态的数据集,并为其命

mysql5.7 innodb数据库备份工具Xtrabackup的安装

mysql5.7 innodb数据库备份工具Xtrabackup的安装     wget mhttps://www.percona.com/downloads/XtraBackup/Percona-XtraBackup-2.4.7/binary/redhat/6/x86_64/percona-xtrabackup-24-2.4.7-1.el6.x86_64.rpm Mysql5.7需要安装XtraBackup 2.4.1以上版本 官网地址 https://www.percona.com/down

java sql编辑器 动态报表 数据库备份还原 quartz定时任务调度 自定义表单 java图片爬虫

获取[下载地址]   QQ: 313596790   [免费支持更新] 三大数据库 mysql  oracle  sqlsever   更专业.更强悍.适合不同用户群体 [新录针对本系统的视频教程,手把手教开发一个模块,快速掌握本系统] A 集成代码生成器(开发利器)+快速构建表单;            QQ:313596790 freemaker模版技术 ,0个代码不用写,生成完整的一个模块,带页面.建表sql脚本,处理类,service等完整模块 B 集成阿里巴巴数据库连接池druid;