Używam pyodbc zapytań do bazy danych SQL ServerSQL IN operatora za pomocą pyodbc i 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))
ale otrzymuję błąd poniżej. Czy parametr krotki musi być obsługiwany w inny sposób? Czy istnieje lepszy sposób na skonstruowanie tego zapytania?
('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)")
UPDATE:
udało mi się dostać to zapytanie do pracy za pomocą operatora formatowania ciąg, który nie jest idealny, ponieważ wprowadza obawy związane z bezpieczeństwem.
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))
Dla twojej drugiej opcji, trzeba by dynamicznie utworzyć instrukcję SQL na podstawie rozmiaru krotki, którą chciałbyś przejść do instrukcji IN? – user338714
Możesz zrobić coś takiego: cursor.execute ("WYBIERZ * Z filmów, gdzie ocena IN ({})". format ("," .łącz ("?" * len (oceny))) , oceny) – rleelr