Export to GitHub

sqlheavy - issue #23

Bad SQL causes Queryable.run() and run_script() to fail with "database already locked" error


Posted on Jun 12, 2012 by Happy Rhino

If a script passed to run_script() (or a straight SQL string is passed to run()) has bad SQL in it (in my case, it was attempting to create an index that already existed), the method will fail with

** (geary:744): CRITICAL **: sqlheavy-database.vala:167: Unable to execute queued query: The database file is locked

After debugging, it appears the problem is that run_internal() is throwing an exception causing the Transaction object to be dereferenced, and the ROLLBACK TRANSACTION TO SAVEPOINT command is failing with Sqlite.BUSY.

Status: New

Labels:
Type-Defect Priority-Medium