sqlite3 в Python извлекает записи, которые соответствуют значениям в кортеже - PullRequest
2 голосов
/ 29 марта 2012

Я ищу команду sqlite3, которая позволяет мне выбирать записи, данные кортежем, позвольте мне объяснить на примере:

Вот мои данные:

my_data = [(1,8),(2,4),(3,5),(4,7),(5,13)]

пытается извлечь записи, чьи первые значения равны 1,2 или 4;следовательно, мой желаемый вывод:

[(1, 8), (2, 4), (4, 7)]

Я могу добиться этого с помощью кода ниже;Тем не менее, я думаю, что мой код не является оптимальным:

import sqlite3

my_data = [(1,8),(2,4),(3,5),(4,7),(5,13)]

key_indexes = (1,2,4)

conn = sqlite3.connect(':memory:')

c = conn.cursor()

c.execute('''CREATE TABLE my_table
          (val_1 INTEGER, val_2 INTEGER)''')

for entry in my_data:
    c.execute('''INSERT INTO my_table VALUES(?,?)''',entry)

conn.commit()

result = []

for ind in key_indexes:
    c.execute('''SELECT* FROM my_table WHERE val_1 = ?''', (ind,))
    temp_res = c.fetchall()

    result.extend(temp_res)

Я ищу код, который может заменить цикл for в команде и командой sqlite3.Я хочу вставить (1,2,4) где-нибудь в этой строке:

c.execute('''SELECT* FROM my_table WHERE val_1 = ?''', (ind,))

вместо выполнения цикла for.Заранее спасибо

1 Ответ

2 голосов
/ 29 марта 2012

Чтобы заменить последний цикл for, вы можете создать список индексов / индексов в строке и нажать на базу данных только один раз.
Обратите внимание, что это двухэтапный процесс, который сам по себе не уязвим для SQL-инъекций атак.

my_query = '''SELECT val_1, val_2
              FROM   my_table 
              WHERE  val_1 IN ({:s});'''.format(",".join("?"*len(key_indexes)))
# -> 'SELECT val_1, val_2 FROM my_table WHERE val_1 IN (?,?,?);'
c.execute(myquery, ind).fetchall()

Дополнительно:
Вы не спрашивали об этом напрямую, но первый цикл for и вызов execute() могут быть сведены к одному вызову executemany(). Вы должны проверить, какой из двух вариантов быстрее, потому что DB-API не определяет, как именно следует реализовать executemany(); производительность может отличаться в разных СУБД.

c.executemany('''INSERT INTO my_table VALUES (?,?);''', my_data)

Вы можете прочитать о executemany() здесь: http://www.python.org/dev/peps/pep-0249/
Пока достаточно сказать, что он принимает в качестве второго аргумента последовательность параметров.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...