我的 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
文章来源: xufive.blog.csdn.net,作者:天元浪子,版权归原作者所有,如需转载,请联系作者。
原文链接:xufive.blog.csdn.net/article/details/103909533
- 点赞
- 收藏
- 关注作者
评论(0)