1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > 我的 MySQL 客户端:支持 pymysql / mysqlclient 双模块 自动重连 独创事务回滚装饰器

我的 MySQL 客户端:支持 pymysql / mysqlclient 双模块 自动重连 独创事务回滚装饰器

时间:2020-01-07 21:18:17

相关推荐

我的 MySQL 客户端:支持 pymysql / mysqlclient 双模块 自动重连 独创事务回滚装饰器

torndb曾经是我非常喜欢使用的一个MySQL客户端,虽然不足300行代码,却支持pymysql/mysqlclient双模块,且能在连接失效时自动重连。torndb的函数封装也很有特色,相同的功能提供了不同的名字。遗憾的是,进入Py3之后,torndb没有相应的升级,只好放弃了。

近日,重读了torndb的源码,结合我对数据库应用的理解,整理出了一个新的MySQL客户端,暂且命名为youthdb,经过测试,基本实现了我对MySQL客户端所有要求。youthdb的主要特点如下:

支持 pymysql / mysqlclient 双模块自动重连,继承自torndb独创事务回滚装饰器

代码总共150行,只有一个Connection类定义,实例化方式如下:

db = Connection(host=‘locahost’, port=3306, db=‘test’, user=‘your_account’, passwd=‘your_password’)

对使用者而言,Connection类只有两个方法:query()和transaction()。query()用于执行sql语句。该方法有select、insert、update、delete等4个别名。query会根据sql语句的不同,自动返回多行查询结果、影响到的行数或最后操作的id等。query的arg参数为None或者元组,则表示单次操作;若arg参数为列表,则表示批量操作。具体用法如下:

db.select(‘select * from member where age 

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。