pymysql 数据库编程

1.引入模块

import pymysql

2.用于建立与数据库的连接 调用pymysql模块中的connect()方法

conn = pymysql.connect(host='localhost', port=3306, user='root', password='mysql',database='python_1', charset='utf8')

* 参数host:连接的mysql主机,如果本机是'localhost'
* 参数port:连接的mysql主机的端口,默认是3306
* 参数database:数据库的名称
* 参数user:连接的用户名
* 参数password:连接的密码
* 参数charset:通信采用的编码方式,推荐使用utf8

 

3.获取Cursor对象

cursor = conn.cursor()

4.执行sql语句 返回值就是sql语句在执行过程中影响的行数

sql = 'sql语句'

row_count = cursor.execute(sql)

print("sql语句执行影响的行数%d" % row_count)

5.提交数据到数据库

conn.commit()

6.回滚数据到什么都不做的状态 即撤销刚刚的修改

conn.rollback()

7.关闭游标和连接

cursor.close()

conn.close()

 

注:参数化列表防止SQL注入

什么是SQL注入 ?

产生原因: 后台将用户提交的带有恶意的数据和SQL进行字符串方式的拼接,从而影响了SQL语句的语义,最终产生数据泄露的现象。

如果防止: sql语句的参数化, 将SQL语句的所有数据参数存在一个列表中传递给execute函数的第二个参数

此处不同于python的字符串格式化,必须全部使用%s占位

 

 

posted @ 2018-11-07 15:07  我来搬砖了  阅读(230)  评论(0编辑  收藏  举报