我通过linux redhat 64bit上的odbc连接了MSSQL(在windows上) 下面是odbc和freetds配置文件。
freetds.conf
:
[FreeTDS]
host=172.21.32.20
port=1433
tds version=7.2
client charset = GB2312
odbcinst.ini
:
[TDS]
Description = TDS
Driver = /usr/local/lib/libtdsodbc.so
Trace = Yes
TraceFile=/tmp/odbcinst.log
UsageCount = 1
odbc.ini
:
[SQLSERVER]
Driver = TDS
Description = sql server dsn
Trace = NO
Server = 172.21.32.20
Database = Live
Port = 1433
TDS_Version = 7.2
TraceFile=/tmp/sqlserver.log
代码段:
QString f3ErpDsn = QString::fromLocal8Bit("Driver={SQLSERVER};server=172.21.32.20;database=Live;uid=inp;pwd=inp;");
QSqlDatabase f3ErpDb= QSqlDatabase::addDatabase("QODBC");
f3ErpDb.setDatabaseName(f3ErpDsn);
// f3ErpDb.setDatabaseName("SQLSERVER");
f3ErpDb.setUserName("inp");
f3ErpDb.setPassword("inp");
QString sqlCmdStr = "select * from dbo.Table_Drilling_Data01 where status=1";
if ( ! f3ErpDb.open() )
{
qDebug() << f3ErpDb.lastError().text();
return 1;
}
QSqlTableModel model;
model.setTable("dbo.Table_Drilling_Data01");
model.setFilter("status=3");
model.select();
qDebug() << model.lastError().text();
错误讯息:
f3ErpDb.setDatabaseName(f3ErpDsn);
如果setDatabaseName
为f3ErpDsn
,则错误消息为:
“QODBC3:无法连接”,“[unixODBC] [驱动程序管理器]未找到数据源名称,并且未指定默认驱动程序”)
我在odbc.ini中定义了SQLSERVER。为什么找不到它?
但如果我更改f3ErpDb.setDatabaseName("SQLSERVER");
,则错误消息为:
“[FreeTDS] [SQL Server]传入的表格数据流(TDS)远程过程调用(RPC)协议流不正确。参数1(”“):数据类型0x00未知.QODBC3:无法执行语句”
这让我感到困惑,有人可以帮助我吗?
答案 0 :(得分:0)
我不确定QSqlDatabase是什么。但似乎你有不正确的SQL连接字符串。
尝试这样的事情:
UID=inp;PWD=inp;DSN=SQLSERVER;database=Live;SERVER=AMIN\SQLEXPRESS;charset=UTF-8
DSN=SQLSERVER
因为SQLSERVER
是odbc.ini
SERVER=AMIN\SQLEXPRESS
- 尝试Windows Server的Windows名称,而不是主机的IP地址(我不确定此处是否允许使用IP,但Windows名称是100%正常工作)
答案 1 :(得分:0)
我有同样的问题,当我将TDS协议更改为8.0时,我解决了它,之前是7.0。我已经使用freetds,unixodbc,通过Qt连接到MSSQL数据库。