pymssql控制SQL进行中文查询时无法查询到结果,但是SQL语句在SSMS中是可以查询到结果的
import SQL_part
if name == 'main':
con,cur=SQL_part.ConDataBase()
print(SQL_part.Select_Plate(cur,'皖A4K1PS'))
测试函数
def Select_Plate(cursor,plate):
sql = "SELECT * FROM LicensePlate where plate='%s'"%plate
cursor.execute(sql.encode('cp936'))
return cursor.fetchall()
查询函数
SQL语句
SELECT * FROM LicensePlate where plate='皖C45K23'
无报错,但是没有预期结果
考虑可能是SQL编码中文问题,但是另一个查询函数是可以正常获取结果的,而且在ssms中sql语句是可以运行的
能够获取中文关键词查询结果
大概率是字符集的问题,请确认文件编码及字符集的一致性。
另外,尝试把cp936换成cp65001,前面的是ansi(GBK),后面的是utf8
试一下 a = cursor.fetchall() 然后 return a
我以前好像也遇过这个问题,直接打印是空
要给他声明一个名字