На помощь спешит PySQLPool, в нём есть методы для создания пула подключений к MySQL.
Я использую движок таблиц (table engine) InnoDB с нормальной поддержкой транзакций. Совсем неинтересно каждый раз писать BEGIN TRANSACTION/COMMIT, это ж Python! Должен быть способ! И он нашёлся.
В версии 2.5 добавили оператор with и контекстные менеджеры. Я написал простенький патч, и использование транзакций стало простым и красивым:
q = PySQLPool.getNewQuery(connection) with q: # внутренние запросы обёрнуты в транзакцию q.Query('INSERT INTO peer SET PeerName=%s', (name,))
Есть и маленькая ложка дёгтя в виде заявленного автором бага при работе с транзакциями из нескольких тредов. В общем-то, ко времени релиза нашего проекта либо я исправлю этот баг, либо автор, либо вы. ;)
Комментариев нет:
Отправить комментарий