findmyslfe 2022-02-08 14:32 采纳率: 100%
浏览 166
已结题

pymssql控制SQL进行中文查询

问题遇到的现象和发生背景

pymssql控制SQL进行中文查询时无法查询到结果,但是SQL语句在SSMS中是可以查询到结果的

img

img

问题相关代码,请勿粘贴截图

import SQL_part
if name == 'main':
con,cur=SQL_part.ConDataBase()
print(SQL_part.Select_Plate(cur,'皖A4K1PS'))

img

测试函数

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语句是可以运行的

我想要达到的结果

能够获取中文关键词查询结果

  • 写回答

2条回答 默认 最新

  • DarkAthena ORACLE应用及数据库设计方案咨询师 2022-02-08 14:55
    关注

    大概率是字符集的问题,请确认文件编码及字符集的一致性。
    另外,尝试把cp936换成cp65001,前面的是ansi(GBK),后面的是utf8

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 2月17日
  • 已采纳回答 2月9日
  • 创建了问题 2月8日