else:
self.strings[list] = string.join([self.get_str(c) for c in list.clauses], ', ')
+ def apply_function_parens(self, func):
+ return func.name.upper() not in ANSI_FUNCS or len(func.clauses) > 0
+
def visit_function(self, func):
if len(self.select_stack):
self.typemap.setdefault(func.name, func.type)
- if func.name.upper() in ANSI_FUNCS and not len(func.clauses):
+ if not self.apply_function_parens(func):
self.strings[func] = ".".join(func.packagenames + [func.name])
else:
self.strings[func] = ".".join(func.packagenames + [func.name]) + "(" + string.join([self.get_str(c) for c in func.clauses], ', ') + ")"
gives Oracle a chance to tack on a "FROM DUAL" to the string output. """
return " FROM DUAL"
+ def apply_function_parens(self, func):
+ return len(func.clauses) > 0
+
def visit_join(self, join):
if self._use_ansi:
return ansisql.ANSICompiler.visit_join(self, join)
def __init__(self, name, *clauses, **kwargs):
self.name = name
self.type = kwargs.get('type', sqltypes.NULLTYPE)
- self.packagenames = kwargs.get('packagenames')
+ self.packagenames = kwargs.get('packagenames', None) or []
self._engine = kwargs.get('engine', None)
if self._engine is not None:
self.type = self._engine.type_descriptor(self.type)
data.setdefault(self, self)
def copy_container(self):
clauses = [clause.copy_container() for clause in self.clauses]
- return Function(self.name, type=self.type, *clauses)
+ return Function(self.name, type=self.type, packagenames=self.packagenames, *clauses)
def accept_visitor(self, visitor):
for c in self.clauses:
c.accept_visitor(visitor)