同事遇到了一个奇怪的问题:同样的SQL语句,写在C#里,访问oracle数据库,在他机器执行会报错,而其他机器则不会。
这条语句拿到他本机的PL/SQL developer执行,又没有问题。
出现这种问题,首先检查SQL语句后面是否带分号";"。带分号在plsql developer里执行没有问题,但在C#里就不允许。
不过同事的SQL没有分号。但是里面有中文字段。按照错误提示,应该中文编码的问题。
参考网上文章提示
果然错误修正。
这里修正的,是oracle服务器端的编码。如果是修改oracle客户端,需修改注册表。
参考文章:
ORA-00911: invalid character 错误解决集锦