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

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日

悬赏问题

  • ¥100 房产抖音小程序苹果搜不到安卓可以付费悬赏
  • ¥15 STM32串口接收问题
  • ¥15 腾讯IOA系统怎么在文件夹里修改办公网络的连接
  • ¥15 filenotfounderror:文件是存在的,权限也给了,但还一直报错
  • ¥15 MATLAB和mosek的求解问题
  • ¥20 修改中兴光猫sn的时候提示失败
  • ¥15 java大作业爬取网页
  • ¥15 怎么获取欧易的btc永续合约和交割合约的5m级的历史数据用来回测套利策略?
  • ¥15 有没有办法利用libusb读取usb设备数据
  • ¥15 为什么openeluer里面按不了python3呢?