我正在尝试进行设置,以便可以从AS400数据库读取二进制数据,而不必在每个选定的列上放置“ CAST(TABLE.COL AS CHAR(29)CCSID 37)COL”。每次都很难说,更不用说将列大小与C#代码耦合了(我想我可以将所有内容都转换为VARCHAR(9999),但是...)。

我以为可以通过ADO.Net的连接字符串来做到这一点。但是,在尝试阅读各种页面上的所有建议设置以使其正常工作之后,它们都给出了“ ConnectionString属性无效”的信息。错误。

我尝试了以下每种方法,但它们都给出相同的错误:

var connectionString = "DataSource=" + /*blah blah...*/ +
//"; CCSID=37; TRANSLATE=1" +
//"; BinAsChar=true; CCSID=37;" +
//"; BinAsChar=true; CCSID=37; TRANSLATE=1" +
//"; BinAsChar=true; CCSID=37; Force Translate=1" +
//"; BinAsChar=true; CCSID=37; ForceTranslation=1" +
//"; CCSID=37; ForceTranslation=1" +
//"; ForceTranslation=1" +
//"; CCSID=37" +
//"; Host CCSID=37" +
//"; CharsetFor65535=0" +
//"; CCSID=EBCDIC" +
"";


有什么办法可以使它正常工作吗?还是我必须继续污染所有查询?

最佳答案

自Redbook Mike参考发布以来,似乎有所增强。

在7.1 DB2 for i .NET Provider技术参考(作为Windows iAccess的程序员工具包组件或更新的ACS Windows应用程序包的一部分安装)中,有几个有趣的属性...

iDB2Connection.CharBitDataAsString属性
获取一个布尔值,该布尔值指示是否应将用CCSID 65535标记的字符位数据转换为字符串数据。

iDB2ProviderSettings.CharBitDataCcsid属性
当CharBitDataAsString属性设置为True时,指定用于转换iDB2CharBitData和iDB2VarCharBitData类型的CCSID。当CharBitDataAsString设置为False时,将忽略此属性。

09-08 03:44