--- a/server/sources/rql2sql.py Tue Sep 21 16:35:37 2010 +0200
+++ b/server/sources/rql2sql.py Thu Sep 23 23:28:58 2010 +0200
@@ -761,6 +761,8 @@
restrictions.append(restriction)
restriction = ' AND '.join(restrictions)
if not restriction:
+ if tables:
+ return 'SELECT 1 FROM %s' % ', '.join(tables)
return ''
if not tables:
# XXX could leave surrounding EXISTS() in this case no?
@@ -1141,11 +1143,11 @@
def visit_constant(self, constant):
"""generate SQL name for a constant"""
- value = constant.value
if constant.type is None:
return 'NULL'
+ value = constant.value
if constant.type == 'Int' and isinstance(constant.parent, SortTerm):
- return constant.value
+ return value
if constant.type in ('Date', 'Datetime'):
rel = constant.relation()
if rel is not None:
@@ -1158,7 +1160,7 @@
# we may found constant from simplified var in varmap
return self._mapped_term(constant, '%%(%s)s' % value)[0]
except KeyError:
- _id = constant.value
+ _id = value
if isinstance(_id, unicode):
_id = _id.encode()
else: