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

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日

悬赏问题

  • ¥15 wamp3.3.5安装完成后图标正常显示绿色,鼠标左右键点击图标均无反应。求解决方法。
  • ¥15 鼠标点击的这条记录了什么?
  • ¥15 在写pid调速的程序时,电机始终维持最大速度
  • ¥15 帅锅们,我很想知道这个论坛是用什么模板搭的(T_T)
  • ¥15 请问如何查看手机root记录?
  • ¥15 商城小程序订单号重复
  • ¥15 学校优化算法sbo和蚁群算法怎么结合
  • ¥21 matlab怎么求时域信号的二阶导数
  • ¥15 判断两个表是否完全相同
  • ¥15 java map类型数据格式,如何快速通过前缀匹配元素