PostgreSQL
 sql >> Base de Dados >  >> RDS >> PostgreSQL

Passando param para DB .execute para WHERE IN... INT list


Edit:Se você acha que esta resposta contorna as proteções internas contra o ataque de injeção de SQL, você está enganado; olhar mais de perto.

Testando com pg8000 (uma interface Pure-Python compatível com DB-API 2.0 para o mecanismo de banco de dados PostgreSQL):

Essa é a maneira recomendada de passar vários parâmetros para uma cláusula "IN".
params = [3,2,1]
stmt = 'SELECT * FROM table WHERE id IN (%s)' % ','.join('%s' for i in params)
cursor.execute(stmt, params)

Exemplo completo:
>>> from pg8000 import DBAPI
>>> conn = DBAPI.connect(user="a", database="d", host="localhost", password="p")
>>> c = conn.cursor()
>>> prms = [1,2,3]
>>> stmt = 'SELECT * FROM table WHERE id IN (%s)' % ','.join('%s' for i in prms)
>>> c.execute(stmt,prms)
>>> c.fetchall()
((1, u'myitem1'), (2, u'myitem2'), (3, u'myitem3'))