#11234 closed defect (fixed)
ProgrammingError: non-integer constant in ORDER BY
Reported by: | Owned by: | Jun Omae | |
---|---|---|---|
Priority: | normal | Component: | ContactsPlugin |
Severity: | normal | Keywords: | |
Cc: | Trac Release: |
Description (last modified by )
After installing and enabling the Contacts Plugin, I get the following error when navigating to the /contacts
url.
Trac detected an internal error: ProgrammingError: non-integer constant in ORDER BY
accompanied by the following error in the system log:
Jul 22 15:38:04 ledger postgres[36234]: [3-1] ERROR: non-integer constant in ORDER BY Jul 22 15:38:04 ledger postgres[36234]: [3-2] STATEMENT: Jul 22 15:38:04 ledger postgres[36234]: [3-3] SELECT id, first, last, position, email, phone Jul 22 15:38:04 ledger postgres[36234]: [3-4] FROM contact ORDER BY E'last',E'first'
System Info:
FreeBSD 8.3 postgresql-server-8.3.22 Trac 1.0.1 Babel 0.9.6 Docutils 0.10 FullBlog 0.1.1 Genshi 0.7 (with speedups) mod_wsgi 3.4 (WSGIProcessGroup WSGIApplicationGroup %{GLOBAL}) Pygments 1.6 Python 2.7.5 (default, Jul 22 2013, 00:04:17) [GCC 4.2.2 20070831 prerelease [FreeBSD]] pytz 2013b setuptools 0.6c11 Subversion 1.8.0 (r1490375) jQuery 1.4.4
Enabled Plugins:
contacts 0.1 /home/wellsolives/trac/plugins/contacts-0.1-py2.7.egg graphviz 0.7.4 /usr/local/lib/python2.7/site-packages/graphviz-0.7.4-py2.7.egg TracFullBlogPlugin 0.1.1 /usr/local/lib/python2.7/site-packages/TracFullBlogPlugin-0.1.1-py2.7.egg TracTags 0.7dev /usr/local/lib/python2.7/site-packages/TracTags-0.7dev-py2.7.egg
Attachments (0)
Change History (11)
comment:1 Changed 11 years ago by
Owner: | changed from CM Lubinski to Ryan J Ollos |
---|
comment:2 Changed 11 years ago by
Oh. I am experiencing this also!
How to Reproduce
While doing a GET operation on /contacts
, Trac issued an internal error.
(please provide additional details here)
Request parameters:
{}
User agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_7_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/29.0.1547.76 Safari/537.36
System Information
Trac | 1.0
|
Genshi | 0.6 (without speedups)
|
psycopg2 | 2.5
|
Pygments | 0.9
|
Python | 2.5.1 (r251:54863, May 2 2007, 16:27:44) [GCC 4.1.2 (Ubuntu 4.1.2-0ubuntu4)]
|
setuptools | 0.6c11
|
jQuery | 1.7.2
|
Enabled Plugins
contacts | 0.1
|
Python Traceback
Traceback (most recent call last): File "build/bdist.linux-x86_64/egg/trac/web/main.py", line 497, in _dispatch_request dispatcher.dispatch(req) File "build/bdist.linux-x86_64/egg/trac/web/main.py", line 233, in dispatch content_type) File "build/bdist.linux-x86_64/egg/trac/web/chrome.py", line 1000, in render_template encoding='utf-8') File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/core.py", line 183, in render return encode(generator, method=method, encoding=encoding, out=out) File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/output.py", line 58, in encode for chunk in iterator: File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/output.py", line 339, in __call__ for kind, data, pos in stream: File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/output.py", line 826, in __call__ for kind, data, pos in stream: File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/output.py", line 670, in __call__ for kind, data, pos in stream: File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/output.py", line 771, in __call__ for kind, data, pos in chain(stream, [(None, None, None)]): File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/output.py", line 586, in __call__ for ev in stream: File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/core.py", line 288, in _ensure for event in stream: File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/core.py", line 288, in _ensure for event in stream: File "build/bdist.linux-x86_64/egg/trac/web/chrome.py", line 1137, in _strip_accesskeys for kind, data, pos in stream: File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/core.py", line 288, in _ensure for event in stream: File "build/bdist.linux-x86_64/egg/trac/web/chrome.py", line 1126, in _generate for kind, data, pos in stream: File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/template/base.py", line 605, in _include for event in stream: File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/template/markup.py", line 378, in _match ctxt, start=idx + 1, **vars): File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/template/markup.py", line 378, in _match ctxt, start=idx + 1, **vars): File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/template/markup.py", line 327, in _match for event in stream: File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/template/base.py", line 545, in _flatten for kind, data, pos in stream: File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/core.py", line 288, in _ensure for event in stream: File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/path.py", line 588, in _generate subevent = next() File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/template/base.py", line 605, in _include for event in stream: File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/template/markup.py", line 316, in _strip event = next() File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/template/base.py", line 545, in _flatten for kind, data, pos in stream: File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/core.py", line 288, in _ensure for event in stream: File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/path.py", line 588, in _generate subevent = next() File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/template/base.py", line 605, in _include for event in stream: File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/template/markup.py", line 316, in _strip event = next() File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/template/base.py", line 545, in _flatten for kind, data, pos in stream: File "/usr/lib/python2.5/site-packages/Genshi-0.6-py2.5.egg/genshi/template/directives.py", line 366, in __call__ for item in iterable: File "build/bdist.linux-x86_64/egg/contacts/model.py", line 85, in ContactIterator FROM contact ORDER BY %s""" % ','.join(['%s']*len(order_by)), order_by) File "build/bdist.linux-x86_64/egg/trac/db/util.py", line 65, in execute return self.cursor.execute(sql_escape_percent(sql), args) ProgrammingError: non-integer constant in ORDER BY
comment:3 Changed 11 years ago by
I won't have time to look at it until this weekend, but I suppose maybe we just need single-quotes around the parameters?:
- FROM contact ORDER BY %s""" % ','.join(['%s']*len(order_by)), order_by) + FROM contact ORDER BY %s""" % ','.join(["'%s'"]*len(order_by)), order_by)
comment:4 Changed 11 years ago by
That line is missing a string replace... this fixed my problem
- FROM contact ORDER BY %s""" % ','.join(['%s']*len(order_by)), order_by) + FROM contact ORDER BY %s""" % ','.join(['%s']*len(order_by))% order_by)
comment:5 follow-up: 6 Changed 11 years ago by
That might work, and in particular it might work for one type of database, but we should not use string replace, but rather pass the parameter as an argument to the DB API. So the real problem lies somewhere in how the SQL string is formed.
comment:6 Changed 11 years ago by
Replying to rjollos:
That might work, and in particular it might work for one type of database, but we should not use string replace, but rather pass the parameter as an argument to the DB API. So the real problem lies somewhere in how the SQL string is formed.
We cannot use the DB API in this case because of specifying column names of contact
table for the order_by
. Instead, use db.quote
. However the method is available since Trac 0.12, see trac:r9062.
Untested patch.
-
contacts/model.py
74 74 self.email = req.args.get('email') 75 75 self.phone = req.args.get('phone') 76 76 77 78 _COLS = set(('id', 'first', 'last', 'position', 'email', 'phone')) 79 80 77 81 def ContactIterator(env, order_by = None): 78 82 if not order_by: 79 83 order_by = ('last', 'first') 84 for name in order_by: 85 if name not in _COLS: 86 raise ValueError("Must be one of %r: %r" % (_COLS, name)) 87 80 88 db = env.get_db_cnx() 89 if hasattr(db, 'quote'): 90 quote = db.quote # Trac 0.12+ 91 else: 92 quote = lambda name: name 81 93 cursor = db.cursor() 82 # Using the prepared db statement won't work if we have more than one entry in order_by 83 cursor.execute(""" 84 SELECT id, first, last, position, email, phone 85 FROM contact ORDER BY %s""" % ','.join(['%s']*len(order_by)), order_by) 94 cursor.execute("""SELECT id, first, last, position, email, phone 95 FROM contact ORDER BY %s""" % 96 ','.join(quote(v) for v in order_by)) 86 97 for id, first, last, position, email, phone in cursor: 87 98 contact = Contact(env) 88 99 contact.id = id
comment:7 follow-up: 8 Changed 11 years ago by
Description: | modified (diff) |
---|---|
Status: | new → accepted |
comment:8 Changed 11 years ago by
Replying to rjollos:
Patched with this diff and is working on my installation. Thanks.
comment:9 Changed 11 years ago by
Sorry for the delay. I'll try to get the change committed this weekend.
comment:11 Changed 9 years ago by
Owner: | changed from Ryan J Ollos to Jun Omae |
---|
It looks like I introduced a regression in [12247]. I'll fix it shortly.