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

举报
天元浪子 发表于 2021/07/26 23:10:18 2021/07/26
【摘要】 torndb曾经是我非常喜欢使用的一个MySQL客户端,虽然不足300行代码,却支持pymysql/mysqlclient双模块,且能在连接失效时自动重连。torndb的函数封装也很有特色,相同的功能提供了不同的名字。遗憾的是,进入Py3之后,torndb没有相应的升级,只好放弃了。 近日,重读了torndb的源码,结合我对数据库应用的理解,整理出了一个新的MySQL...

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

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。