From 8ed2f5c6a958c6b53817da600752c2b1c73c02a1 2013-08-21 14:37:09 From: MinRK Date: 2013-08-21 14:37:09 Subject: [PATCH] quote table name avoids syntax errors from hyphens --- diff --git a/IPython/parallel/controller/sqlitedb.py b/IPython/parallel/controller/sqlitedb.py index 00d0445..cf3c3e7 100644 --- a/IPython/parallel/controller/sqlitedb.py +++ b/IPython/parallel/controller/sqlitedb.py @@ -195,7 +195,7 @@ class SQLiteDB(BaseDB): If a bad (old) table does exist, return False """ - cursor = self._db.execute("PRAGMA table_info(%s)"%self.table) + cursor = self._db.execute("PRAGMA table_info('%s')"%self.table) lines = cursor.fetchall() if not lines: # table does not exist @@ -241,7 +241,7 @@ class SQLiteDB(BaseDB): ) previous_table = self.table - self._db.execute("""CREATE TABLE IF NOT EXISTS %s + self._db.execute("""CREATE TABLE IF NOT EXISTS '%s' (msg_id text PRIMARY KEY, header dict text, metadata dict text, @@ -333,12 +333,12 @@ class SQLiteDB(BaseDB): d['msg_id'] = msg_id line = self._dict_to_list(d) tups = '(%s)'%(','.join(['?']*len(line))) - self._db.execute("INSERT INTO %s VALUES %s"%(self.table, tups), line) + self._db.execute("INSERT INTO '%s' VALUES %s"%(self.table, tups), line) # self._db.commit() def get_record(self, msg_id): """Get a specific Task Record, by msg_id.""" - cursor = self._db.execute("""SELECT * FROM %s WHERE msg_id==?"""%self.table, (msg_id,)) + cursor = self._db.execute("""SELECT * FROM '%s' WHERE msg_id==?"""%self.table, (msg_id,)) line = cursor.fetchone() if line is None: raise KeyError("No such msg: %r"%msg_id) @@ -346,7 +346,7 @@ class SQLiteDB(BaseDB): def update_record(self, msg_id, rec): """Update the data in an existing record.""" - query = "UPDATE %s SET "%self.table + query = "UPDATE '%s' SET "%self.table sets = [] keys = sorted(rec.keys()) values = [] @@ -361,13 +361,13 @@ class SQLiteDB(BaseDB): def drop_record(self, msg_id): """Remove a record from the DB.""" - self._db.execute("""DELETE FROM %s WHERE msg_id==?"""%self.table, (msg_id,)) + self._db.execute("""DELETE FROM '%s' WHERE msg_id==?"""%self.table, (msg_id,)) # self._db.commit() def drop_matching_records(self, check): """Remove a record from the DB.""" expr,args = self._render_expression(check) - query = "DELETE FROM %s WHERE %s"%(self.table, expr) + query = "DELETE FROM '%s' WHERE %s"%(self.table, expr) self._db.execute(query,args) # self._db.commit() @@ -399,7 +399,7 @@ class SQLiteDB(BaseDB): else: req = '*' expr,args = self._render_expression(check) - query = """SELECT %s FROM %s WHERE %s"""%(req, self.table, expr) + query = """SELECT %s FROM '%s' WHERE %s"""%(req, self.table, expr) cursor = self._db.execute(query, args) matches = cursor.fetchall() records = [] @@ -410,7 +410,7 @@ class SQLiteDB(BaseDB): def get_history(self): """get all msg_ids, ordered by time submitted.""" - query = """SELECT msg_id FROM %s ORDER by submitted ASC"""%self.table + query = """SELECT msg_id FROM '%s' ORDER by submitted ASC"""%self.table cursor = self._db.execute(query) # will be a list of length 1 tuples return [ tup[0] for tup in cursor.fetchall()]