我正在使用 pypyodbc 连接到我的 SQL2014 服务器,并且要执行以下查询。但是,它给出错误消息:
pypyodbc.ProgrammingError: (u'42S22', u"[42S22] [Microsoft][SQL Server Native Cl ient 11.0][SQL Server]Invalid column name '2017-02-07'.")
我可以在服务器上运行sql查询,没有任何问题。 我想知道包含长 sql 语句并执行它的正确方法是什么?
Python 代码:
result = cursor.execute('''
declare @date date ="2017-02-07",
@env varchar (10)= "TEST",
@runid int,
@val smallint,
@timelen int,
@interface varchar(30),
@table_t varchar(30),
@del_t int,
@upd_t int,
@ins_t int
declare @import_test TABLE
(RUN_DATE date,
ENV varchar(10),
ID int,
[CHECK] varchar (100),
CODE varchar(30),
TABLE_NAME varchar(30),
VAL_1 int,
VAL_2 int,
VAL_3 int )
set @val=(select count(*) from MY_TABLE where convert(date,[timestamp])=@date and msg_cd="OK")
insert into @import_test values (@date,@env,null,"Check 1 (count of OK codes)",null,null,@val,null,null)
select * from @import_test
''')
for row in result:
print(row)
最佳答案
在 MSSQL 中,双引号括起来的字符串被解释为列名。您需要对 Python 多行字符串使用双引号,并在 SQL 查询中使用单引号将字符串括起来。
尝试:
result = cursor.execute("""
declare @date date ='2017-02-07',
@env varchar (10)= 'TEST',
@runid int,
@val smallint,
@timelen int,
@interface varchar(30),
@table_t varchar(30),
@del_t int,
@upd_t int,
@ins_t int
...
""")
关于python - 如何在Python中处理多行SQL语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44201577/