From: Jonathan Ellis Date: Mon, 9 Mar 2009 21:24:43 +0000 (+0000) Subject: add schema to entity method X-Git-Tag: rel_0_5_3~8 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=a4ee98fe66248d2550d818c8027f6c1256c9bc98;p=thirdparty%2Fsqlalchemy%2Fsqlalchemy.git add schema to entity method --- diff --git a/lib/sqlalchemy/ext/sqlsoup.py b/lib/sqlalchemy/ext/sqlsoup.py index f2754793b0..b3f2de743e 100644 --- a/lib/sqlalchemy/ext/sqlsoup.py +++ b/lib/sqlalchemy/ext/sqlsoup.py @@ -286,6 +286,9 @@ You can load a table whose name is specified at runtime with the entity() method >>> db.entity(tablename) == db.loans True +entity() also takes an optional schema argument. If none is specified, the +default schema is used. + Extra tests =========== @@ -537,11 +540,11 @@ class SqlSoup: j = join(*args, **kwargs) return self.map(j) - def entity(self, attr): + def entity(self, attr, schema=None): try: t = self._cache[attr] except KeyError: - table = Table(attr, self._metadata, autoload=True, schema=self.schema) + table = Table(attr, self._metadata, autoload=True, schema=schema or self.schema) if not table.primary_key.columns: raise PKNotFoundError('table %r does not have a primary key defined [columns: %s]' % (attr, ','.join(table.c.keys()))) if table.columns: