同事遇到了一个奇怪的问题:同样的sql语句,写在C#里,访问oracle数据库,在他机器执行会报错,而其他机器则不会。
这条语句拿到他本机的PL/sql developer执行,又没有问题。
出现这种问题,首先检查sql语句后面是否带分号”;”。带分号在plsql developer里执行没有问题,但在C#里就不允许。
不过同事的sql没有分号。但是里面有中文字段。按照错误提示,应该中文编码的问题。
控制面板--系统和安全---系统--高级系统设置--高级--环境变量--系统变量中
变量名:NLS_LANG
变量值:SIMPLIFIED CHINESE_CHINA.ZHS16GBK
把这个变量添加完成以后,把系统重启一下就ok了,重启以后,错误提示消失了。
果然错误修正。
这里修正的,是oracle服务器端的编码。如果是修改oracle客户端,需修改注册表。
原文链接:https://www.f2er.com/oracle/207975.html