QT 4.7.0 使用odbc链接sqlserver 测试成功

#include <QApplication>
#include <QSqlDatabase>
#include <QStringList>
#include <QDebug>
#include <QtGui/QMessageBox>
#include <QtSql/QSqlError>
#include <QtDebug>
#include <QSqlQuery>
#include <QVariant>


int main(int argc, char* argv[]) {

    QApplication app(argc, argv);

  qDebug() << "Available drivers:";
QStringList drivers = QSqlDatabase::drivers();
foreach(QString driver, drivers)
qDebug() << "\t" << driver;

    QSqlDatabase db = QSqlDatabase::addDatabase("QODBC", "test");
    db.setHostName("192.168.18.114");//如果dsn中已经含有SERVER,可以省略此句
    QString dsn = QString::fromLocal8Bit("DRIVER={SQL SERVER};SERVER=192.168.18.114;DATABASE=test");
    //如果已经设定DSN,可以写为QString::fromLocal8Bit("SQLSERVER_DSN")
    db.setDatabaseName(dsn);
    //即使dsn中已经设置了UID和PASSWD,仍然需要执行setUserName和setPassword的步骤
    db.setUserName("sa");
    db.setPassword("sa123456");
    if(!db.open()) {
     QMessageBox::critical(0, QObject::tr("Database Error"),
     db.lastError().text());
     return -1;

    }

    QSqlQuery mquery=QSqlQuery::QSqlQuery(db);
    bool isok=mquery.exec("select * from student;");
    if (!isok)
    {
        db.close();
        return -1;
    }
    //这个是必须的,因为查处的结果集当前位置不在第一条记录上。
    mquery.next();
    QString sID=mquery.value(0).toString();
    QString sName=mquery.value(1).toString();
    //清除结果集
    mquery.clear();
    // 如果该连接不再使用,就可以关闭。
    db.close();
    //这里是将从数据库读出的数据写到一个list控件里
    qDebug() << sID;
    qDebug() << sName;


    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值