* [PATCH] serv/db: Don't use BEGIN/COMMIT
@ 2013-08-31 22:42 Richard Purdie
0 siblings, 0 replies; only message in thread
From: Richard Purdie @ 2013-08-31 22:42 UTC (permalink / raw)
To: bitbake-devel
Since we don't support using multiple servers on the same database file,
don't use the BEGIN/COMMIT syntax and allow writes to the database
to work ~100 times faster with no transaction locking.
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
---
diff --git a/bitbake/lib/prserv/db.py b/bitbake/lib/prserv/db.py
index b7190ba..dad445b 100644
--- a/bitbake/lib/prserv/db.py
+++ b/bitbake/lib/prserv/db.py
@@ -52,11 +52,9 @@ class PRTable(object):
else:
#no value found, try to insert
try:
- self._execute("BEGIN")
- self._execute("INSERT OR ROLLBACK INTO %s VALUES (?, ?, ?, (select ifnull(max(value)+1,0) from %s where version=? AND pkgarch=?));"
+ self._execute("INSERT INTO %s VALUES (?, ?, ?, (select ifnull(max(value)+1,0) from %s where version=? AND pkgarch=?));"
% (self.table,self.table),
(version,pkgarch, checksum,version, pkgarch))
- self.conn.commit()
except sqlite3.IntegrityError as exc:
logger.error(str(exc))
@@ -80,11 +78,9 @@ class PRTable(object):
else:
#no value found, try to insert
try:
- self._execute("BEGIN")
self._execute("INSERT OR REPLACE INTO %s VALUES (?, ?, ?, (select ifnull(max(value)+1,0) from %s where version=? AND pkgarch=?));"
% (self.table,self.table),
(version, pkgarch, checksum, version, pkgarch))
- self.conn.commit()
except sqlite3.IntegrityError as exc:
logger.error(str(exc))
self.conn.rollback()
@@ -113,10 +109,8 @@ class PRTable(object):
else:
#no value found, try to insert
try:
- self._execute("BEGIN")
- self._execute("INSERT OR ROLLBACK INTO %s VALUES (?, ?, ?, ?);" % (self.table),
+ self._execute("INSERT INTO %s VALUES (?, ?, ?, ?);" % (self.table),
(version, pkgarch, checksum, value))
- self.conn.commit()
except sqlite3.IntegrityError as exc:
logger.error(str(exc))
@@ -130,18 +124,14 @@ class PRTable(object):
def _importNohist(self, version, pkgarch, checksum, value):
try:
#try to insert
- self._execute("BEGIN")
- self._execute("INSERT OR ROLLBACK INTO %s VALUES (?, ?, ?, ?);" % (self.table),
+ self._execute("INSERT INTO %s VALUES (?, ?, ?, ?);" % (self.table),
(version, pkgarch, checksum,value))
- self.conn.commit()
except sqlite3.IntegrityError as exc:
#already have the record, try to update
try:
- self._execute("BEGIN")
self._execute("UPDATE %s SET value=? WHERE version=? AND pkgarch=? AND checksum=? AND value<?"
% (self.table),
(value,version,pkgarch,checksum,value))
- self.conn.commit()
except sqlite3.IntegrityError as exc:
logger.error(str(exc))
^ permalink raw reply related [flat|nested] only message in thread
only message in thread, other threads:[~2013-08-31 22:42 UTC | newest]
Thread overview: (only message) (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-08-31 22:42 [PATCH] serv/db: Don't use BEGIN/COMMIT Richard Purdie
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.