oracle 返回unicode,OracleClient中加入Unicode=true

OracleClient中加入Unicode=true

Dotblogs 的标签:Oracle ,ASP.NET

这个问题已经不是第一次在项目中发生了,上一次发生是在 Net1.1 + Oracle 9i 的环境下,PG 用串接字符串的方式去查询 Oracle 中的数据,串接的 Where 条件中有中文字,结果就会发生:

System.Data.OracleClient.OracleException: ORA-01756: 引号字符串未以恰当方式终止

最佳的解决办法当然是,请不要再串字符串 SQL 了!!! 是没看过 Design Guideline 吗,讲了又讲,讲了又讲,还串字符串!!!

改用 OracleCommand,以参数的方式,带入 OracleType.NVarChar 即可:1: sSql = "Select * From ADDR_ZIP Where AND HSN = :HSN ORDER BY ZIP "2: Dim cmd As New OracleClient.OracleCommand3: cmd.CommandText = sSql4: cmd.Parameters.Add("HSN", OracleType.NVarChar).Value = "中国台北市"

但是除了用 OracleCommand 之外,其实在 web.config 的连线字符串上,还是可以加个 Unicode=true,也是可以解决啦:

--------

没什么特别的~

不过是一些笔记而已

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值