Qt连接SQLServer的问题

sjyzhxw 2012-05-07 05:52:50

#include <QtCore/QCoreApplication>
#include <QtSql/QSqlDatabase>
#include <QtSql>
#include <QStringList>
#include <QDebug>

struct Student
{
QString id;
QString name;
QString sex;
};


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

QSqlDatabase db=QSqlDatabase::addDatabase("QODBC");


QString dsn = QString::fromLocal8Bit("DRIVER={SQL SERVER};SERVER=127.0.0.1;DATABASE=mydb");
db.setDatabaseName(dsn);
db.setUserName("admin");
db.setPassword("123456");
if(db.open()) {
qDebug()<<"OK!";
}
else{
qDebug()<<"Error!";
}


QSqlQuery query(db);
query.exec("select * from NewStudent");

QSqlError error=query.lastError();
qDebug()<<error.number();

if(!query.isValid()){
qDebug()<<"Invalid!";
}

while(query.next()){
Student student;

student.id=query.value(0).toString();
student.name=query.value(1).toString();
student.sex=query.value(2).toString();

qDebug()<<"ID: "<<student.id<<" Name: "<<student.name<<" Sex: "<<student.sex;
}


return a.exec();
}



输出了invalid
...全文
260 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
sjyzhxw 2012-06-12
  • 打赏
  • 举报
回复
Java风格迭代器用不惯啊。。。
[Quote=引用 1 楼 的回复:]
query.next()调用前,query.value数据是没有数据的
[/Quote]
xxq123321 2012-05-28
  • 打赏
  • 举报
回复
query.next()调用前,query.value数据是没有数据的

16,212

社区成员

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

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