summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy/databases/postgres.py
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2006-02-05 00:19:14 +0000
committerMike Bayer <mike_mp@zzzcomputing.com>2006-02-05 00:19:14 +0000
commit1d20ecbb6d0f0f8cfbb0a54e2a3aaf6cead23ecb (patch)
tree7092c12ed6a625137361ad35448936197a2d3ff6 /lib/sqlalchemy/databases/postgres.py
parentf0aa20cab011488b1cdecb5ed9bc68fc1ef1f73e (diff)
downloadsqlalchemy-1d20ecbb6d0f0f8cfbb0a54e2a3aaf6cead23ecb.tar.gz
started PassiveDefault, which is a "database-side" default. mapper will go
fetch the most recently inserted row if a table has PassiveDefault's set on it
Diffstat (limited to 'lib/sqlalchemy/databases/postgres.py')
-rw-r--r--lib/sqlalchemy/databases/postgres.py4
1 files changed, 3 insertions, 1 deletions
diff --git a/lib/sqlalchemy/databases/postgres.py b/lib/sqlalchemy/databases/postgres.py
index 2d6adc165..9122c2afa 100644
--- a/lib/sqlalchemy/databases/postgres.py
+++ b/lib/sqlalchemy/databases/postgres.py
@@ -275,7 +275,9 @@ class PGCompiler(ansisql.ANSICompiler):
class PGSchemaGenerator(ansisql.ANSISchemaGenerator):
def get_column_specification(self, column, override_pk=False, **kwargs):
colspec = column.name
- if column.primary_key and isinstance(column.type, types.Integer) and (column.default is None or (isinstance(column.default, schema.Sequence) and column.default.optional)):
+ if isinstance(column.default, schema.PassiveDefault):
+ colspec += " DEFAULT " + column.default.text
+ elif column.primary_key and isinstance(column.type, types.Integer) and (column.default is None or (isinstance(column.default, schema.Sequence) and column.default.optional)):
colspec += " SERIAL"
else:
colspec += " " + column.type.get_col_spec()