类别:程序开发

日期:2024-01-09 浏览:1044 评论: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
作者授权:除特别说明外,本文由 零一 原创编译并授权 零一的世界 刊载发布。
版权声明:本文不使用任何协议授权,您可以任何形式自由转载或使用。
 您阅读本篇文章共花了: 

 可能感兴趣的文章

评论区

发表评论 / 取消回复

必填

选填

选填

◎欢迎讨论,请在这里发表您的看法及观点。