类别:程序开发
日期:2024-01-09 浏览:1461 评论:0
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,也是可以解决啦:
本文标题:Oracle 返回unicode,OracleClient中加入Unicode=true
本文链接:https://vtzw.com/post/1110.html
作者授权:除特别说明外,本文由
零一 原创编译并授权
零一的世界 刊载发布。
版权声明:本文不使用任何协议授权,您可以任何形式自由转载或使用。
您阅读本篇文章共花了:
发表评论 / 取消回复