python sqlalchemy oracle 中文_请教关于 flask-sqlalchemy 查询 oracle 库时, query.all()查询中编码的问题...

在尝试使用Python Flask-SQLAlchemy连接Oracle数据库并进行查询时,遇到编码问题。当使用query.all()方法时,由于数据库编码为ZHS16GBK,导致查询报错UnicodeDecodeError。通过在ORM类中增加toGBK()和toUTF8()方法转换编码,写入数据正常,但在查询时失败。手动执行SQL可以成功转换。寻求解决方案。
摘要由CSDN通过智能技术生成

我初学 python,打算照着网上的例程,用 flask 搭一个笔记网站练手,因为想着尽量贴近公司现有的基础资源,所以数据库没有照例程的用 mongoDB,而是直接连公司的 oracle 数据库,悲催的是这个库编码已经是 ZHS16GBK,不可能更改,而且也会是以后绕不过的一个坑,所以还是得将这个骨头啃下来。

现在的困难是,我能成功建表、写入数据,在构造 class 的时候,我增加了 toGBK()方法,将几个字段都转码,这样写进去的中文也是正常格式了。我还写了个 toUTF8()方法,准备照样子将查询出来的结果转为 UTF-8,可惜在 Note.query.all()这一步查询时就报错了,错误信息是:

UnicodeDecodeError: 'utf8' codec can't decode byte 0xbf in position 0: invalid start byte

我直接自己写 sql 去查,都能成功转码,不懂为啥用了 query.all()就出错了。下面是我测试环境和两个相关文件代码,希望大家帮忙。

先列一下我这边的版本:

服务器:64 位 centos 7.3.1611

系统编码环境:

LANG=en_US.UTF-8

NLS_LANG='SIMPLIFIED CHINESE_CHINA.ZHS16GBK'

Python 2.7.5

cx-Oracle==5.3

decorator==3.4.0

ez-setup==0.9

Fla

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值