重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
如何通过twisted实现数据库异步插入?
梨树ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为创新互联公司的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:18980820575(备注:SSL证书合作)期待与您的合作!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()
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。