2012-02-22 4 views
0

Мой код:python и mysqldb: синтаксическая ошибка на отлично хорошем запросе?

selectQ ="""SELECT * FROM %s WHERE %s = %%s order by RAND() limit %s""" % (self.table,self.columnSpecName,limit), 
self.db.execute(str(selectQ),(idKey)) 

Я получаю это исключение: mysql_exceptions.ProgrammingError: (1064, "You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ''SELECT * FROM table WHERE person_oid = 16 order by RAND() limit 10',)' at line 1")

Однако если скопировать запрос и запустить его через MySQL он работает просто отлично.

Что я могу увидеть?

+0

Он заменяет %% s на% s, поэтому его можно использовать в db.execute, который заменит его idKey –

ответ

3

Вы должны выглядеть ближе:

синтаксис для использования рядом с '' SELECT * FROM table WHERE person_oid = 16 order by RAND() limit 10 ',)' в строке 1 ")

И вы увидите двойной апостроф в начале запроса и ,)' в конце его.

selectQ ="""SELECT * FROM %s WHERE %s = %%s order by RAND() limit %s""" % (self.table,self.columnSpecName,limit), 
self.db.execute(str(selectQ),(idKey)) 

У вас есть запятая в конце первой строки, что делает его кортеж

Удалите его и вам не нужно будет на второй линии.

2

У вас есть запятые для много в первой строке (в конце):

selectQ ="""SELECT * FROM %s WHERE %s = %%s order by RAND() limit %s""" % (self.table,self.columnSpecName,limit), 
self.db.execute(str(selectQ),(idKey)) 

изменить его на:

selectQ ="""SELECT * FROM %s WHERE %s = %%s order by RAND() limit %s""" % (self.table,self.columnSpecName,limit) 
self.db.execute(str(selectQ),(idKey))