summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2005-12-31 07:13:18 +0000
committerMike Bayer <mike_mp@zzzcomputing.com>2005-12-31 07:13:18 +0000
commitf3e9dc2c8c611a2dd03e96f13e99894f10820dd0 (patch)
tree64a3fa1207090e0a6b9f26d27182ada3ae96c8f1 /lib
parent7553b79721c96cdecf87049477ac7c84ef0b0676 (diff)
downloadsqlalchemy-f3e9dc2c8c611a2dd03e96f13e99894f10820dd0.tar.gz
fix to ansisql when it tries to determine param-based select clause that its
only on a column-type object engine has settable 'paramstyle' attribute
Diffstat (limited to 'lib')
-rw-r--r--lib/sqlalchemy/ansisql.py10
-rw-r--r--lib/sqlalchemy/engine.py28
-rw-r--r--lib/sqlalchemy/mapping/mapper.py9
-rw-r--r--lib/sqlalchemy/sql.py3
4 files changed, 30 insertions, 20 deletions
diff --git a/lib/sqlalchemy/ansisql.py b/lib/sqlalchemy/ansisql.py
index 7f30a5da0..a4cbb4358 100644
--- a/lib/sqlalchemy/ansisql.py
+++ b/lib/sqlalchemy/ansisql.py
@@ -70,11 +70,11 @@ class ANSICompiler(sql.Compiled):
elif self.engine.paramstyle=='format':
self.strings[self.statement] = re.sub(match, '%s', self.strings[self.statement])
elif self.engine.paramstyle=='numeric':
- i = 0
+ i = [0]
def getnum(x):
- i += 1
- return i
- self.strings[self.statement] = re.sub(match, getnum(s), self.strings[self.statement])
+ i[0] += 1
+ return str(i[0])
+ self.strings[self.statement] = re.sub(match, getnum, self.strings[self.statement])
def get_from_text(self, obj):
return self.froms[obj]
@@ -282,7 +282,7 @@ class ANSICompiler(sql.Compiled):
if self.parameters is not None:
revisit = False
for c in inner_columns.values():
- if self.parameters.has_key(c.key) and not self.binds.has_key(c.key):
+ if sql.is_column(c) and self.parameters.has_key(c.key) and not self.binds.has_key(c.key):
value = self.parameters[c.key]
else:
continue
diff --git a/lib/sqlalchemy/engine.py b/lib/sqlalchemy/engine.py
index bc39d90d9..f23701424 100644
--- a/lib/sqlalchemy/engine.py
+++ b/lib/sqlalchemy/engine.py
@@ -176,23 +176,33 @@ class SQLEngine(schema.SchemaEngine):
else:
self.logger = logger
- def _figure_paramstyle(self):
+ def _set_paramstyle(self, style):
+ self._paramstyle = style
+ self._figure_paramstyle(style)
+ paramstyle = property(lambda s:s._paramstyle, _set_paramstyle)
+
+ def _figure_paramstyle(self, paramstyle=None):
db = self.dbapi()
- if db is not None:
- self.paramstyle = db.paramstyle
+ if paramstyle is not None:
+ self._paramstyle = paramstyle
+ elif db is not None:
+ self._paramstyle = db.paramstyle
else:
- self.paramstyle = 'named'
+ self._paramstyle = 'named'
- if self.paramstyle == 'named':
+ if self._paramstyle == 'named':
self.bindtemplate = ':%s'
self.positional=False
- elif self.paramstyle =='pyformat':
+ elif self._paramstyle == 'pyformat':
self.bindtemplate = "%%(%s)s"
self.positional=False
- else:
- # for positional, use pyformat until the end
+ elif self._paramstyle == 'qmark' or self._paramstyle == 'format' or self._paramstyle == 'numeric':
+ # for positional, use pyformat internally, ANSICompiler will convert
+ # to appropriate character upon compilation
self.bindtemplate = "%%(%s)s"
- self.positional=True
+ self.positional = True
+ else:
+ raise "Unsupported paramstyle '%s'" % self._paramstyle
def type_descriptor(self, typeobj):
"""provides a database-specific TypeEngine object, given the generic object
diff --git a/lib/sqlalchemy/mapping/mapper.py b/lib/sqlalchemy/mapping/mapper.py
index 1920d4ff2..27479ae9d 100644
--- a/lib/sqlalchemy/mapping/mapper.py
+++ b/lib/sqlalchemy/mapping/mapper.py
@@ -117,10 +117,10 @@ class Mapper(object):
# load custom properties
if properties is not None:
for key, prop in properties.iteritems():
- if is_column(prop):
+ if sql.is_column(prop):
self.columns[key] = prop
prop = ColumnProperty(prop)
- elif isinstance(prop, list) and is_column(prop[0]):
+ elif isinstance(prop, list) and sql.is_column(prop[0]):
self.columns[key] = prop[0]
prop = ColumnProperty(*prop)
self.props[key] = prop
@@ -170,7 +170,7 @@ class Mapper(object):
def add_property(self, key, prop):
self.copyargs['properties'][key] = prop
- if is_column(prop):
+ if sql.is_column(prop):
self.columns[key] = prop
prop = ColumnProperty(prop)
self.props[key] = prop
@@ -797,9 +797,6 @@ def hash_key(obj):
return obj.hash_key()
else:
return repr(obj)
-
-def is_column(col):
- return isinstance(col, schema.Column) or isinstance(col, sql.ColumnElement)
def mapper_hash_key(class_, table, primarytable = None, properties = None, **kwargs):
if properties is None:
diff --git a/lib/sqlalchemy/sql.py b/lib/sqlalchemy/sql.py
index 6e1024251..d7b1ac021 100644
--- a/lib/sqlalchemy/sql.py
+++ b/lib/sqlalchemy/sql.py
@@ -201,6 +201,9 @@ def _compound_select(keyword, *selects, **kwargs):
def _is_literal(element):
return not isinstance(element, ClauseElement) and not isinstance(element, schema.SchemaItem)
+def is_column(col):
+ return isinstance(col, schema.Column) or isinstance(col, ColumnElement)
+
class ClauseVisitor(schema.SchemaVisitor):
"""builds upon SchemaVisitor to define the visiting of SQL statement elements in
addition to Schema elements."""