本文实例分析了Python多线程操作数据库相关问题。分享给大家供大家参考,具体如下:
python多线程并发操作数据库,会存在链接数据库超时、数据库连接丢失、数据库操作超时等问题。
解决方法:使用数据库连接池,并且每次操作都从数据库连接池获取数据库操作句柄,操作完关闭连接返回数据库连接池。
*连接数据库需要设置
charset = 'utf8', use_unicode = True
,不然会报中文乱码问题*网上说解决python多线程并发操作数据库问题,连接时使用
self.conn.ping(True)
(检查并保持长连接),但是我这边亲测无法解决,建议还是使用数据库连接池
python多线程代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
import threading
class MyThread(threading.Thread):
def __init__( self , name, count, exec_object):
threading.Thread.__init__( self )
self .name = name
self .count = count
self .exec_object = exec_object
def run( self ):
while self .count > = 0 :
count = count - 1
self .exec_object.execFunc(count)
thread1 = MyThread( 'MyThread1' , 3 , ExecObject())
thread2 = MyThread( 'MyThread2' , 5 , ExecObject())
thread1.start()
thread2.start()
thread1.join() # join方法 执行完thread1的方法才继续主线程
thread2.join() # join方法 执行完thread2的方法才继续主线程
# 执行顺序 并发执行thread1 thread2,thread1和thread2执行完成才继续执行主线程
# ExecObject类是自定义数据库操作的业务逻辑类
#
########join方法详解########
thread1 = MyThread( 'MyThread1' , 3 , ExecObject())
thread2 = MyThread( 'MyThread2' , 5 , ExecObject())
thread1.start()
thread1.join() # join方法 执行完thread1的方法才继续主线程
thread2.start()
thread2.join() # join方法 执行完thread2的方法才继续主线程
# 执行顺序 先执行thread1,执行完thread1再执行thread2,执行完thread2才继续执行主线程
|
mysql数据库连接池代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
import MySQLdb
from DBUtils.PooledDB import PooledDB
class MySQL:
host = 'localhost'
user = 'root'
port = 3306
pasword = ''
db = 'testDB'
charset = 'utf8'
pool = None
limit_count = 3 # 最低预启动数据库连接数量
def __init__( self ):
self .pool = PooledDB(MySQLdb, self .limit_count, host = self .host, user = self .user, passwd = self .pasword, db = self .db,
port = self .port, charset = self .charset, use_unicode = True )
def select( self , sql):
conn = self .pool.connection()
cursor = conn.cursor()
cursor.execute(sql)
result = cursor.fetchall()
cursor.close()
conn.close()
return result
def insert( self , table, sql):
conn = self .pool.connection()
cursor = conn.cursor()
try :
cursor.execute(sql)
conn.commit()
return { 'result' : True , 'id' : int (cursor.lastrowid)}
except Exception as err:
conn.rollback()
return { 'result' : False , 'err' :err}
finally :
cursor.close()
conn.close()
|
希望本文所述对大家Python程序设计有所帮助。
原文链接:https://blog.csdn.net/mxdzchallpp/article/details/80411514