首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Python3进阶——使用PyMySQL操作MySQL

来源: Shocker 链接:

https://shockerli.net/post/python3-pymysql/

PyMySQL 是一个纯 Python 实现的 MySQL 客户端操作库,支持事务、存储过程、批量执行等。

PyMySQL 遵循 Python 数据库 API v2.0 规范,并包含了 pure-Python MySQL 客户端库。

安装

创建数据库连接

参数列表:

执行 SQL

cursor.execute(sql, args) 执行单条 SQL

executemany(sql, args) 批量执行 SQL

注意:INSERT、UPDATE、DELETE 等修改数据的语句需手动执行connection.commit()完成对数据修改的提交。

获取自增 ID

查询数据

游标控制

所有的数据查询操作均基于游标,我们可以通过控制游标的位置。

设置游标类型

查询时,默认返回的数据类型为元组,可以自定义设置返回类型。支持5种游标类型:

Cursor: 默认,元组类型

DictCursor: 字典类型

DictCursorMixin: 支持自定义的游标类型,需先自定义才可使用

SSCursor: 无缓冲元组类型

SSDictCursor: 无缓冲字典类型

无缓冲游标类型,适用于数据量很大,一次性返回太慢,或者服务端带宽较小时。源码注释:

Unbuffered Cursor, mainly useful for queries that return a lot of data, or for connections to remote servers over a slow network.

Instead of copying every row of data into a buffer, this will fetch rows as needed. The upside of this is the client uses much less memory, and rows are returned much faster when traveling over a slow network or if the result set is very big.

There are limitations, though. The MySQL protocol doesn’t support returning the total number of rows, so the only way to tell how many rows there are is to iterate over every row returned. Also, it currently isn’t possible to scroll backwards, as only the current row is held in memory.

创建连接时,通过 cursorclass 参数指定类型:

也可以在创建游标时指定类型:

事务处理

开启事务

提交修改

回滚事务

防 SQL 注入

转义特殊字符

参数化语句 支持传入参数进行自动转义、格式化 SQL 语句,以避免 SQL 注入等安全问题。

参考资料

Python中操作mysql的pymysql模块详解

http://www.cnblogs.com/wt11/p/6141225.html

Python之pymysql的使用

http://www.cnblogs.com/liubinsh/p/7568423.html

(完)

看完本文有收获?请转发分享给更多人

关注「Python那些事」,做全栈开发工程师

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180909B0AMGM00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券