summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy/mapping/mapper.py
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2006-03-05 21:01:21 +0000
committerMike Bayer <mike_mp@zzzcomputing.com>2006-03-05 21:01:21 +0000
commit9446e490cb14d456c96b4731993e2a965a090b1a (patch)
tree193545cacdfd7f452d58c81e7f2e28f788f58d74 /lib/sqlalchemy/mapping/mapper.py
parent9c4f3c0480f54e08b3aa2800ed76e89f957f8131 (diff)
downloadsqlalchemy-9446e490cb14d456c96b4731993e2a965a090b1a.tar.gz
got mapper to receive the onupdates after updating an instance (also properly receives defaults on inserts)...
Diffstat (limited to 'lib/sqlalchemy/mapping/mapper.py')
-rw-r--r--lib/sqlalchemy/mapping/mapper.py31
1 files changed, 22 insertions, 9 deletions
diff --git a/lib/sqlalchemy/mapping/mapper.py b/lib/sqlalchemy/mapping/mapper.py
index 85fe8dc69..8239df99c 100644
--- a/lib/sqlalchemy/mapping/mapper.py
+++ b/lib/sqlalchemy/mapping/mapper.py
@@ -591,6 +591,7 @@ class Mapper(object):
for rec in update:
(obj, params) = rec
c = statement.execute(params)
+ self._postfetch(table, obj, table.engine.last_updated_params())
self.extension.after_update(self, obj)
rows += c.cursor.rowcount
if table.engine.supports_sane_rowcount() and rows != len(update):
@@ -608,18 +609,30 @@ class Mapper(object):
if self._getattrbycolumn(obj, col) is None:
self._setattrbycolumn(obj, col, primary_key[i])
i+=1
- if table.engine.lastrow_has_defaults():
- clause = sql.and_()
- for p in self.pks_by_table[table]:
- clause.clauses.append(p == self._getattrbycolumn(obj, p))
- row = table.select(clause).execute().fetchone()
- for c in table.c:
- if self._getattrbycolumn(obj, c) is None:
- self._setattrbycolumn(obj, c, row[c])
+ self._postfetch(table, obj, table.engine.last_inserted_params())
if self._synchronizer is not None:
self._synchronizer.execute(obj, obj)
self.extension.after_insert(self, obj)
-
+
+ def _postfetch(self, table, obj, params):
+ """after an INSERT or UPDATE, asks the engine if PassiveDefaults fired off on the database side
+ which need to be post-fetched, *or* if pre-exec defaults like ColumnDefaults were fired off
+ and should be populated into the instance. this is only for non-primary key columns."""
+ if table.engine.lastrow_has_defaults():
+ clause = sql.and_()
+ for p in self.pks_by_table[table]:
+ clause.clauses.append(p == self._getattrbycolumn(obj, p))
+ row = table.select(clause).execute().fetchone()
+ for c in table.c:
+ if self._getattrbycolumn(obj, c) is None:
+ self._setattrbycolumn(obj, c, row[c])
+ else:
+ for c in table.c:
+ if c.primary_key or not params.has_key(c.name):
+ continue
+ if self._getattrbycolumn(obj, c) != params[c.name]:
+ self._setattrbycolumn(obj, c, params[c.name])
+
def delete_obj(self, objects, uow):
"""called by a UnitOfWork object to delete objects, which involves a
DELETE statement for each table used by this mapper, for each object in the list."""