python如何通过twisted实现数据库异步插入
作者:北门吹雪
这篇文章主要为大家详细介绍了python如何通过twisted实现数据库异步插入,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
如何通过twisted实现数据库异步插入?
1. 导入adbapi
2. 生成数据库连接池
3. 执行数据数据库插入操作
4. 打印错误信息,并排错
#!/usr/bin/python3 __author__ = 'beimenchuixue' __blog__ = 'http://www.cnblogs.com/2bjiujiu/' import pymysql from twisted.enterprise import adbapi from twisted.internet import reactor def go_insert(cursor, sql): # 对数据库进行插入操作,并不需要commit,twisted会自动帮我commit try: for i in range(10): data = str(i) cursor.execute(sql, data) except Exception as e: print(e) def handle_error(failure): # 打印错误 if failure: print(failure) if __name__ == '__main__': # 数据库基本配置 db_settings = { 'host': 'localhost', 'db': 'jobole', 'user': 'root', 'password': 'passwort', 'charset': 'utf8', 'use_unicode': True } # sql语句模版 insert_sql = 'insert into test_1(text_1) value(%s)' # 普通方法插入数据 # conn = pymysql.connect(**db_settings) # cursor = conn.cursor() # cursor.execute(insert_sql, '1') # conn.commit() try: # 生成连接池 db_conn = adbapi.ConnectionPool('pymysql', **db_settings) # 通过连接池执行具体的sql操作,返回一个对象 query = db_conn.runInteraction(go_insert, insert_sql) # 对错误信息进行提示处理 query.addCallbacks(handle_error) except Exception as e: print(e) # 定时,给4秒时间让twisted异步框架完成数据库插入异步操作,没有定时什么都不会做 reactor.callLater(4, reactor.stop) reactor.run()
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
- python如何通过twisted搭建socket服务
- Python3.6中Twisted模块安装的问题与解决
- python安装twisted的问题解析
- python基于twisted框架编写简单聊天室
- python 编程之twisted详解及简单实例
- Python 基于Twisted框架的文件夹网络传输源码
- 剖析Python的Twisted框架的核心特性
- 实例解析Python的Twisted框架中Deferred对象的用法
- 详解Python的Twisted框架中reactor事件管理器的用法
- 使用Python的Twisted框架编写非阻塞程序的代码示例
- Python的Twisted框架中使用Deferred对象来管理回调函数
- 使用Python的Twisted框架构建非阻塞下载程序的实例教程
- Python的Twisted框架上手前所必须了解的异步编程思想
- 使用Python的Treq on Twisted来进行HTTP压力测试
- 利用Python的Twisted框架实现webshell密码扫描器的教程
- 使用Python的Twisted框架实现一个简单的服务器
- 使用Python的Twisted框架编写简单的网络客户端
- python开发实例之Python的Twisted框架中Deferred对象的详细用法与实例