 |
操作系统:Windows2000
编程工具:sqlserver70 pb70
问题:我的开发环境为Windows2000, sqlserver70 pb70, 现在PB环境中运行应用程序(SQLSERVER已经运行)出现不能连接数据库的错误信息:A SQL Server request resulted in bad return code or status but no error message was returned.
但可以在PB环境中连接SQLServer数据库(用自带SQLServer6.x 接口),并可编辑记录,也可作DataWindow。
本人试过以下两种方法均不能解决这个问题:
1.SQLCA.DBMS=PROFILESTRING('PB.INI','DATABASE','DBMS','')
...........
2.SQLCA.DBMS='MSS Microsoft SQL Server 6.x'
SQLCA.Database='MYDB'
SQLCA.Servername='MYServer'
SQLCA.Logid='sa'
SQLCA.AutoCommit=False
SQLCA.DBParm=''
我想可能是以上代码有问题,请帮助解决,给出完整代码。万分感激! (Genesis)
|
| |
|
 |
于溪玥的意见:
PB6.x仅提供了MSS Ms SQL Server 6.x的专用接口(DBMS),PB7.0不仅提供了MSS Ms SQL Server 6.x的专用接口, 而且提供了与Microsoft 兼容的OLE DB接口。
本人在PB7的 DataBase 工具(画笔) 曾用
MSS Ms SQL Server 6.x、OLE DB
分别连接 Ms SQL 7 ,连接均可以, 但MSS Ms SQL Server 6.x读取不了个别数据, 用OLE DB :(也可使用*.udl文件)
SQLCA.DBMS = "OLE DB"
SQLCA.LogId = "sa"
SQLCA.AutoCommit = False
SQLCA.DBParm = "PROVIDER='SQLOLEDB',PROVIDERSTRING='database=yourDB'"
(与VB的ConnetionString大同小异)
则完全可以,无任何问题!
我认为问题是在Ms SQL 7与PB的MSS Ms SQL Server 6.x的专用接口不能兼容!
Delphi 4 的 BDE 与 SQL Explorer也存在同样的向后兼容问题!
wsd的意见:
请在PB中的database profiles中选择你的数据引擎,进入EDIT,其中有一个选项为preview,请将里边的内容粘贴到你的程序中,应该没有问题,就可以连接,不过我用的是PB6.5.1我想在PB7.0中也应该没有问题,不过看了你的源代码,也觉得没有问题,可能是你的机器名和连接中的机器名不一直造成的。
Baby的意见:
SQLCA.LogId或SQLCA.LogPass不对。
此问题由于溪玥等回答。
附加关键字:编程, 源程序, programming, source code, Power Builder, PB, sybase, 数据库, database, query。
|
| |
|
| |
|
| |
|
|