如何通過twisted實(shí)現(xiàn)數(shù)據(jù)庫異步插入?
1. 導(dǎo)入adbapi
2. 生成數(shù)據(jù)庫連接池
3. 執(zhí)行數(shù)據(jù)數(shù)據(jù)庫插入操作
4. 打印錯(cuò)誤信息,并排錯(cuò)
#!/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): # 對數(shù)據(jù)庫進(jìn)行插入操作,并不需要commit,twisted會(huì)自動(dòng)幫我commit try: for i in range(10): data = str(i) cursor.execute(sql, data) except Exception as e: print(e) def handle_error(failure): # 打印錯(cuò)誤 if failure: print(failure) if __name__ == '__main__': # 數(shù)據(jù)庫基本配置 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)' # 普通方法插入數(shù)據(jù) # conn = pymysql.connect(**db_settings) # cursor = conn.cursor() # cursor.execute(insert_sql, '1') # conn.commit() try: # 生成連接池 db_conn = adbapi.ConnectionPool('pymysql', **db_settings) # 通過連接池執(zhí)行具體的sql操作,返回一個(gè)對象 query = db_conn.runInteraction(go_insert, insert_sql) # 對錯(cuò)誤信息進(jìn)行提示處理 query.addCallbacks(handle_error) except Exception as e: print(e) # 定時(shí),給4秒時(shí)間讓twisted異步框架完成數(shù)據(jù)庫插入異步操作,沒有定時(shí)什么都不會(huì)做 reactor.callLater(4, reactor.stop) reactor.run()
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
當(dāng)前題目:python如何通過twisted實(shí)現(xiàn)數(shù)據(jù)庫異步插入-創(chuàng)新互聯(lián)
分享地址:http://aaarwkj.com/article20/dohico.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號、品牌網(wǎng)站建設(shè)、網(wǎng)站營銷、動(dòng)態(tài)網(wǎng)站、用戶體驗(yàn)、靜態(tài)網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)