#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[]) {
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;
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;
}
#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;
}