diff options
| author | Mike Bayer <mike_mp@zzzcomputing.com> | 2010-04-06 18:53:51 -0400 |
|---|---|---|
| committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2010-04-06 18:53:51 -0400 |
| commit | a6480a2c31a52c7fcf1cd5487033d61afab8a7ee (patch) | |
| tree | c91bddd0e32151d3cb9fbb9b0a0d2fd4a1d5edd0 /lib/sqlalchemy | |
| parent | e9cdc0b86ebae7463d33383b9a7e2706387fc6cf (diff) | |
| download | sqlalchemy-a6480a2c31a52c7fcf1cd5487033d61afab8a7ee.tar.gz | |
- Postgresql now reflects sequence names associated with
SERIAL columns correctly, after the name of of the sequence
has been changed. Thanks to Kumar McMillan for the patch.
[ticket:1071]
Diffstat (limited to 'lib/sqlalchemy')
| -rw-r--r-- | lib/sqlalchemy/dialects/postgresql/base.py | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/lib/sqlalchemy/dialects/postgresql/base.py b/lib/sqlalchemy/dialects/postgresql/base.py index bef2f1c61..dcdaa3c7b 100644 --- a/lib/sqlalchemy/dialects/postgresql/base.py +++ b/lib/sqlalchemy/dialects/postgresql/base.py @@ -814,7 +814,8 @@ class PGDialect(default.DefaultDialect): result = connection.execute( sql.text(u"SELECT relname FROM pg_class c " "WHERE relkind = 'r' " - "AND '%s' = (select nspname from pg_namespace n where n.oid = c.relnamespace) " % + "AND '%s' = (select nspname from pg_namespace n " + "where n.oid = c.relnamespace) " % current_schema, typemap = {'relname':sqltypes.Unicode} ) @@ -832,7 +833,8 @@ class PGDialect(default.DefaultDialect): SELECT relname FROM pg_class c WHERE relkind = 'v' - AND '%(schema)s' = (select nspname from pg_namespace n where n.oid = c.relnamespace) + AND '%(schema)s' = (select nspname from pg_namespace n + where n.oid = c.relnamespace) """ % dict(schema=current_schema) # Py3K #view_names = [row[0] for row in connection.execute(s)] @@ -870,7 +872,8 @@ class PGDialect(default.DefaultDialect): SQL_COLS = """ SELECT a.attname, pg_catalog.format_type(a.atttypid, a.atttypmod), - (SELECT substring(d.adsrc for 128) FROM pg_catalog.pg_attrdef d + (SELECT substring(pg_catalog.pg_get_expr(d.adbin, d.adrelid) for 128) + FROM pg_catalog.pg_attrdef d WHERE d.adrelid = a.attrelid AND d.adnum = a.attnum AND a.atthasdef) AS DEFAULT, a.attnotnull, a.attnum, a.attrelid as table_oid |
