WEB开发网
开发学院数据库MSSQL Server 通过OLE DB连接MSSQL Server时出现乱码的解决方法... 阅读

通过OLE DB连接MSSQL Server时出现乱码的解决方法

 2007-11-11 10:17:22 来源:WEB开发网   
核心提示: 当使用OLE DB方式与MS sql server(WINDOWS平台上强大的数据库平台)连接时,如果数据库的代码页与本地的不同,当进行查询时字符的返回值就会变成 ? 或是乱码, 微软的网站上说这是一个BUG, 并且描述如下: When you try to retrieve cha


   
当使用OLE DB方式与MS sql server(WINDOWS平台上强大的数据库平台)连接时,如果数据库的代码页与本地的不同,当进行查询时字符的返回值就会变成 ? 或是乱码, 微软的网站上说这是一个BUG, 并且描述如下:
When you try to retrieve character data from a column with different collation than the client code page in Microsoft SQL OLE DB Provider (SQLOLEDB), you may receive question marks (??) instead of correct data when all the following conditions are true:
?A connection is made against a Microsoft sql server(WINDOWS平台上强大的数据库平台) 2000 database.
?SSPROP_IN99v_AUTOTRANSLATE is set to TRUE. SSPROP_IN99v_AUTOTRANSLATE is part of the provider-specific DBPROPSET_SQLSERVERDBIN99v property set.
?A column is bound to an OLEDB DBTYPE_WCHAR data type in the bindings structure.

我的解决方法是关掉 自动字符转换. 例子如下:(PowerBuilder 中)
SQLCA.DBMS = 'OLE DB'
SQLCA.LogID = 'sa'
SQLCA.LogPass = ''
SQLCA.DBParm = “PROVIDER='SQLOLEDB', DataSource='my-server', CommitOnDisconnect='no', ProviderString='Database=mydb, AutoTranslate=no'”

Tags:通过 OLE DB

编辑录入:coldstar [复制链接] [打 印]
赞助商链接