Я все еще получаю ошибку параметра. Я нашел способ заставить запрос работать с использованием оператора форматирования строки (см. Мое обновление выше), и, поскольку этот код будет выполняться только локально, проблемы безопасности, вероятно, можно пропустить. Я думаю, что cursor.executemany может быть другим вариантом.
ользую pyodbc для запроса к базе данных SQL Server
import datetime
import pyodbc
conn = pyodbc.connect("Driver={SQL Server};Server='dbserver',Database='db',
TrustedConnection=Yes")
cursor = conn.cursor()
ratings = ("PG-13", "PG", "G")
st_dt = datetime(2010, 1, 1)
end_dt = datetime(2010, 12, 31)
cursor.execute("""Select title, director, producer From movies
Where rating In ? And release_dt Between ? And ?""",
ratings, str(st_dt), str(end_dt))
но я получаю сообщение об ошибке ниже. Нужно ли обрабатывать параметр кортежа другим способом? Есть ли лучший способ структурировать этот запрос?
('42000', "[42000] [Microsoft][ODBC SQL Server Driver][SQL Server]Line 9:
Incorrect syntax near '@P1'. (170) (SQLExecDirectW);
[42000] [Microsoft][ODBC SQL Server Driver][SQL Server]
Statement(s) could not be prepared. (8180)")
ОБНОВИТЬ:
Мне удалось заставить этот запрос работать, используя оператор форматирования строки, который не идеален, поскольку представляет проблемы безопасности.
import datetime
import pyodbc
conn = pyodbc.connect("Driver={SQL Server};Server='dbserver',Database='db',
TrustedConnection=Yes")
cursor = conn.cursor()
ratings = ("PG-13", "PG", "G")
st_dt = datetime(2010, 1, 1)
end_dt = datetime(2010, 12, 31)
cursor.execute("""Select title, director, producer From movies
Where rating In %s And release_dt Between '%s' And '%s'""" %
(ratings, st_dt, end_dt))