【发布时间】:2017-06-26 16:10:16
【问题描述】:
我正在尝试将如下列表传递给 sql 查询
x = ['1000000000164774783','1000000000253252111']
我正在使用 sqlalchemy 和 pyodbc 连接到 sql:
import pandas as pd
from pandas import Series,DataFrame
import pyodbc
import sqlalchemy
cnx=sqlalchemy.create_engine("mssql+pyodbc://Omnius:MainBrain1@172.31.163.135:1433/Basis?driver=/opt/microsoft/sqlncli/lib64/libsqlncli-11.0.so.1790.0")
我尝试在 sql 查询中使用各种字符串格式函数。以下是其中之一
xx = ', '.join(x)
sql = "select * from Pretty_Txns where Send_Customer in (%s)" % xx
df = pd.read_sql(sql,cnx)
他们似乎都将其转换为数字格式
(1000000000164774783, 1000000000253252111) instead of ('1000000000164774783','1000000000253252111')
因此查询失败,因为 Send_Customer 的数据类型在 SQL 中是 varchar(50)
ProgrammingError: (pyodbc.ProgrammingError) ('42000', '[42000] [Microsoft][SQL Server Native Client 11.0]
[SQL Server]Error converting data type varchar to numeric. (8114) (SQLExecDirectW)')
[SQL: 'select * from Pretty_Txns where Send_Customer in (1000000000164774783, 1000000000253252111)']
【问题讨论】:
标签: python sql-server sqlalchemy pyodbc