2013-08-29 12:03:45 +00:00
import threading
import Queue
sqlSubmitQueue = Queue . Queue ( ) #SQLITE3 is so thread-unsafe that they won't even let you call it from different threads using your own locks. SQL objects can only be called from one thread.
sqlReturnQueue = Queue . Queue ( )
sqlLock = threading . Lock ( )
2013-08-27 00:00:30 +00:00
def sqlQuery ( sqlStatement , * args ) :
2013-08-29 12:03:45 +00:00
sqlLock . acquire ( )
sqlSubmitQueue . put ( sqlStatement )
2013-08-27 00:00:30 +00:00
if args == ( ) :
2013-08-29 12:03:45 +00:00
sqlSubmitQueue . put ( ' ' )
2013-08-27 00:00:30 +00:00
else :
2013-08-29 12:03:45 +00:00
sqlSubmitQueue . put ( args )
2013-08-27 00:00:30 +00:00
2013-08-29 12:03:45 +00:00
queryreturn = sqlReturnQueue . get ( )
sqlLock . release ( )
2013-08-27 00:00:30 +00:00
return queryreturn
def sqlExecute ( sqlStatement , * args ) :
2013-08-29 12:03:45 +00:00
sqlLock . acquire ( )
sqlSubmitQueue . put ( sqlStatement )
2013-08-27 00:00:30 +00:00
if args == ( ) :
2013-08-29 12:03:45 +00:00
sqlSubmitQueue . put ( ' ' )
2013-08-27 00:00:30 +00:00
else :
2013-08-29 12:03:45 +00:00
sqlSubmitQueue . put ( args )
2013-08-27 00:00:30 +00:00
2013-08-29 12:03:45 +00:00
sqlReturnQueue . get ( )
sqlSubmitQueue . put ( ' commit ' )
sqlLock . release ( )
2013-08-27 00:00:30 +00:00
def sqlStoredProcedure ( procName ) :
2013-08-29 12:03:45 +00:00
sqlLock . acquire ( )
sqlSubmitQueue . put ( procName )
sqlLock . release ( )
2013-08-31 14:40:11 +00:00
class SqlBulkExecute :
def __enter__ ( self ) :
sqlLock . acquire ( )
return self
def __exit__ ( self , type , value , traceback ) :
sqlSubmitQueue . put ( ' commit ' )
sqlLock . release ( )
def execute ( self , sqlStatement , * args ) :
sqlSubmitQueue . put ( sqlStatement )
if args == ( ) :
sqlSubmitQueue . put ( ' ' )
else :
sqlSubmitQueue . put ( args )
sqlReturnQueue . get ( )
def query ( self , sqlStatement , * args ) :
sqlSubmitQueue . put ( sqlStatement )
if args == ( ) :
sqlSubmitQueue . put ( ' ' )
else :
sqlSubmitQueue . put ( args )
return sqlReturnQueue . get ( )