公司用的oracle rac,已被其字符集问题玩成狗

2013-11-27 10:51:52 +08:00
 jazdelu
当时建数据库的时候我还不在这公司混
不知道是什么使用了AL16UTF16的字符集编码
现在公司要同时上两个应用
一个是GBK 一个是UTF8请问我改如何自处
3067 次点击
所在节点    Linux
2 条回复
Muninn
2013-11-27 11:02:50 +08:00
我很怀疑你说的。
oracle在建库的时候,默认选择根据环境有可能是GBK或者是AL32UTF-8。
而国际字符串那里的默认选项才是AL16UTF16。这个只影响到nchar和nvarchar的字符集,而没有人用这些数据类型。

另外,应用的字符集和数据库统一了固然方便很多,但是不统一,只要你清楚各个步骤的字符集,进行恰当的转换,并不会造成问题,这和你的应用,也许和驱动层有关。

拿python举例,如果是python应用,cx_Oracle库无论Oracle用的什么字符集,将对象取到python内部后,总是python自己的字符串格式,2是unicode,3是string 。

ps,有的库是要求客户端的,有的不需要,如jdbc。 要求客户端的,在客户端必须将NLS_LANG设置的和数据库字符集一样。
jazdelu
2013-11-27 12:28:45 +08:00
@Muninn 啊啊啊啊啊太感谢了!我是菜鸟!谢谢指教!

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/90797

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX