next_id : merged Tony's changeset r9516 from 4.2 branch
authorThierry Parmentelat <thierry.parmentelat@sophia.inria.fr>
Sat, 11 Oct 2008 10:23:03 +0000 (10:23 +0000)
committerThierry Parmentelat <thierry.parmentelat@sophia.inria.fr>
Sat, 11 Oct 2008 10:23:03 +0000 (10:23 +0000)
PLC/PostgreSQL.py

index 4e05639..98ef727 100644 (file)
@@ -134,6 +134,15 @@ class PostgreSQL:
         cursor.close()
         return self.rowcount
 
+    def next_id(self, table_name, primary_key):
+       sequence = "%(table_name)s_%(primary_key)s_seq" % locals()      
+       sql = "SELECT nextval('%(sequence)s')" % locals()
+       rows = self.selectall(sql, hashref = False)
+       if rows: 
+           return rows[0][0]
+               
+       return None 
+
     def last_insert_id(self, table_name, primary_key):
         if isinstance(self.lastrowid, int):
             sql = "SELECT %s FROM %s WHERE oid = %d" % \