linux 下QT连接SQLserver数据库的问题

天长地久007 2014-11-12 03:11:36
这是我的测试源码:
 qDebug()<<QSqlDatabase::drivers();

// 建立连接
QSqlDatabase db=QSqlDatabase::addDatabase("QODBC");
db.setDatabaseName("testdsn");
db.setUserName("sa");
db.setPassword("longzhou@2014?");

if(!db.open())
{
qDebug("=== %s",qPrintable(db.lastError().text()));
}else
{
qDebug("==== ok");
}

然后执行报错:("QSQLITE", "QODBC3", "QODBC", "QPSQL7", "QPSQL")
=== [unixODBC][Driver Manager]Data source name not found, and no default driver specified QODBC3: Unable to connect
root@ubuntu:/usr/local/etc# cat odbc.ini
下面是我的配置文件,谁能帮我看一下错误原因啊
[testdsn] # 数据源名称
Driver=FREETDS# 指向odbcinst.ini的驱动配置
Description=MSSQL Server
Description = sample database
Trace = Yes
Servername=testdsn # 数据源名称
Database=ncpjgSys #数据库名称
root@ubuntu:/usr/local/etc# cat odbcinst.ini
[FREETDS]
Description=freetds driver
Driver=/usr/local/lib/libtdsodbc.so #指定TDS驱动路径
Trace=yes
TraceFile=/tmp/odbc.log # 启用ODBC日志记录
root@ubuntu:/usr/local/etc# cat freetds.conf
[testdsn]
host = 192.168.1.232
port = 1433
tds version = 7.1
root@ubuntu:/usr/local/etc# ls //usr/local/lib/libtdsodbc.so
//usr/local/lib/libtdsodbc.so
...全文
651 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
foxgod 2016-08-31
  • 打赏
  • 举报
回复
在/usr/local/ unixODBC/lib/下没有 libtdsodbc.so.0 这个呀,只有libodbc.so.2这个,为什么
天长地久007 2014-11-15
  • 打赏
  • 举报
回复
解决了:各种问题详见:http://blog.csdn.net/lovehere33/article/details/41118405
天长地久007 2014-11-13
  • 打赏
  • 举报
回复
又出现了新问题:QT 操作SQLSERVER 连接成功,但不能执行SQL语。
qDebug()<<QSqlDatabase::drivers();
    QSqlDatabase db=QSqlDatabase::addDatabase("QODBC");
        db.setDatabaseName(QString("DRIVER={FreeTDS};"
                                   "SERVER=%1;" //服务器名称
                                   "port=%2"
                                   "DATABASE=%3;"//数据库.arg("密码")名
                                   "UID=%4;"           //登录名
                                   "PWD=%45;"        //密码
                                   ).arg("192.168.1.253")
                           .arg(1433)
                           .arg("ncpjgSys")
                           .arg("sa")
                           .arg("longzhou@2014?")
                           );//tsql -H 112.232.114.214 -p 1433 -U sa -P longzhou@2014? -D ncpjgSys

    if(!db.open())
    {
        qDebug("=== %s",qPrintable(db.lastError().text()));
    }else
    {
        qDebug("==== ok");
    }

    QSqlQuery query(db);
//     QDateTime time = QDateTime::currentDateTime();//获取系统现在的时间
//     QString tm = time.toString("yyyy-MM-dd hh:mm:ss"); //设置显示格式
//     QString slct = tr("insert into table1 values('10.5','2.0','2014-11-12 16:01:15','keke')");
//     qDebug()<<slct;
//             if(!query.exec(slct))
//                  qDebug("error%s",qPrintable(db.lastError().text()));
//             else
//                 qDebug("sucess");
    QString sql="insert into table1 values('10.5','2.0','2014-11-12 16:01:15','keke')";
    qDebug()<<sql;
    query.prepare(sql);
    if(!query.exec())
         qDebug("error== %s",qPrintable(db.lastError().text()));
打印信息:("QSQLITE", "QODBC3", "QODBC", "QPSQL7", "QPSQL") ==== ok "insert into table1 values('10.5','2.0','2014-11-12 16:01:15','keke')" QODBCResult::exec: Unable to execute statement: "[FreeTDS][SQL Server]Invalid object name 'table1'." error==
Creator_莫言 2014-11-12
  • 打赏
  • 举报
回复
天长地久007 2014-11-12
  • 打赏
  • 举报
回复
自己解决了,把odbcinst.ini 拷贝到/etc下即可

16,212

社区成员

发帖
与我相关
我的任务
社区描述
Qt 是一个跨平台应用程序框架。通过使用 Qt,您可以一次性开发应用程序和用户界面,然后将其部署到多个桌面和嵌入式操作系统,而无需重复编写源代码。
社区管理员
  • Qt
  • 亭台六七座
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧