use*_*306 6 python mysql python-3.x pymysql
使用Python我一直得到一个
(1205, 'Lock wait timeout exceeded; try restarting transaction')
Run Code Online (Sandbox Code Playgroud)
每当我尝试插入特定表时出错.但是,当我尝试直接从MySQL控制台插入时,它工作得很好.展望着
SHOW FULL PROCESSLIST
Run Code Online (Sandbox Code Playgroud)
在数据库上显示没有其他活动查询.由于这是一个没有附加实时应用程序的开发数据库,我无法想象任何问题.但是,它是在托管我们的生产数据库的服务器上提供的,因此我强烈希望尽可能不进行重置.关于如何调试这个的任何建议?
注意 如果我使用SHOW FULL PROCESSLIST查看正在对数据库运行的查询,最终会因上述消息而失败,然后从MySQL控制台手动插入它,它会按预期工作.
编辑 以下是查询的示例:
INSERT INTO deals (user_ID, store_ID, storeChain_ID, title, dealSaving,
dealDisclaimer, restriction, dealImage, dealURL, submit_ID, userProvider_ID,
createDate, createDateTime, expirationDate, expirationDateTime, ZIP, STATE,
city, businessType, DealType_ID, IP, rating, popular, dealSearchData, tag,
submitName, provider_dealID)
VALUES (NULL,
2651049,
NULL,
'Toronto East Community Arts Program',
'Three-Week Photography Workshop',
NULL,
NULL,
'https://a1.image.net/imgs/8423535b-bd3b-4e1e-afee-ab2869970a4c/700_q60.jpg',
'https://www.exmples.com/deals/1336374',
111,
1,
'2015-11-12',
'2015-11-12 10:01:58.282826',
'2015-11-17 09:59:59',
'2015-11-17 23:59:00',
'M4M 1K7',
'ON',
'Toronto',
NULL,
'1',
'127.0.0.1',
0,
144565,
'Three-Week Photography Workshop',
'Photography Class',
'Partner',
1336374)
Run Code Online (Sandbox Code Playgroud)
编辑 使用建议的示例如下:
self.DB['master']['cursor'].execute("SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED")
self.DB['master']['con'].commit()
self.DB['master']['cursor'].execute(dealsquery,data)
self.DB['master']['con'].commit()
Run Code Online (Sandbox Code Playgroud)
我相信 MySql 使用“可重复读”隔离,它将为整个事务(我相信,也称为直到提交)持有锁。尝试使用不同的隔离设置,例如“已提交读”
在 python mysql 中设置读已提交类似于
cur = conn.cursor()
cur.execute("SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED")
编辑:隔离级别的一个很好的介绍性资源 http://vladmihalcea.com/a-beginners-guide-to-database-locking-and-the-lost-update-phenomena/
| 归档时间: |
|
| 查看次数: |
1980 次 |
| 最近记录: |