summaryrefslogtreecommitdiff
path: root/test/sql/query.py
diff options
context:
space:
mode:
authorAnts Aasma <ants.aasma@gmail.com>2007-10-02 23:57:54 +0000
committerAnts Aasma <ants.aasma@gmail.com>2007-10-02 23:57:54 +0000
commite82ca71cc5c4175f071cdd72207ec04e58a6498c (patch)
tree74e56b7bef7b9ea082a0b0c296e414fe8686d254 /test/sql/query.py
parent73b0c40946ddcf4f4cbbccb90e81fd914143576d (diff)
downloadsqlalchemy-e82ca71cc5c4175f071cdd72207ec04e58a6498c.tar.gz
add support for returning results from inserts and updates for postgresql 8.2+. [ticket:797]
Diffstat (limited to 'test/sql/query.py')
-rw-r--r--test/sql/query.py46
1 files changed, 45 insertions, 1 deletions
diff --git a/test/sql/query.py b/test/sql/query.py
index a519dd974..b4afbbade 100644
--- a/test/sql/query.py
+++ b/test/sql/query.py
@@ -563,7 +563,51 @@ class QueryTest(PersistTest):
s = users.select(users.c.user_name.in_() == None)
r = s.execute().fetchall()
assert len(r) == 1
-
+
+ @testing.supported('postgres')
+ def test_update_returning(self):
+ meta = MetaData(testbase.db)
+ table = Table('tables', meta,
+ Column('id', Integer, primary_key=True),
+ Column('persons', Integer),
+ Column('full', Boolean)
+ )
+ table.create()
+ try:
+ table.insert().execute([{'persons': 5, 'full': False}, {'persons': 3, 'full': False}])
+
+ result = table.update(table.c.persons > 4, dict(full=True), postgres_returning=[table.c.id]).execute()
+ self.assertEqual(result.fetchall(), [(1,)])
+
+ result2 = select([table.c.id, table.c.full]).order_by(table.c.id).execute()
+ self.assertEqual(result2.fetchall(), [(1,True),(2,False)])
+ finally:
+ table.drop()
+
+ @testing.supported('postgres')
+ def test_insert_returning(self):
+ meta = MetaData(testbase.db)
+ table = Table('tables', meta,
+ Column('id', Integer, primary_key=True),
+ Column('persons', Integer),
+ Column('full', Boolean)
+ )
+ table.create()
+ try:
+ result = table.insert(postgres_returning=[table.c.id]).execute({'persons': 1, 'full': False})
+
+ self.assertEqual(result.fetchall(), [(1,)])
+
+ # Multiple inserts only return the last row
+ result2 = table.insert(postgres_returning=[table]).execute(
+ [{'persons': 2, 'full': False}, {'persons': 3, 'full': True}])
+
+ self.assertEqual(result2.fetchall(), [(3,3,True)])
+
+ result3 = table.insert(postgres_returning=[(table.c.id*2).label('double_id')]).execute({'persons': 4, 'full': False})
+ self.assertEqual([dict(row) for row in result3], [{'double_id':8}])
+ finally:
+ table.drop()
class CompoundTest(PersistTest):
"""test compound statements like UNION, INTERSECT, particularly their ability to nest on