
eg:
QSqlQueryModel *model = new QSqlQueryModel
model->setQuery(“select * from xxx”)
model->setHeaderData(0, Qt::Horizontal, tr(“id”))
model->setHeaderData(1, Qt::Horizontal, tr(“name”))
QTableView *view = new QTableView
view->setModel(model)
view->show()
不明白再问
在QT的widget中用tableview显示sqlite数据库表中的内容。假设有数据库文件test.db,有表table(id integer, name nvarchar(20),age integer),且有数条数据。
首先用QTcreator创建一个基于Widget类的窗口,再拖一个tableview到widget中,保存,然后按照如下方法进行:
1.在widget.h中增添头文件:QtSql/qsql.h、QtSql/QsqlDatabase、QtSql/QsqlQuery、QtSql/QsqlQueryModel
2.在.pro工程文件中添加:QT+=sql
3.在widget.cpp中widget的构造函数中添加如下代码:
QsqDatabase db = QsqlDatabase::addDatabase("QSQLITE")
db.setDatabaseName("test.db")
if(!db.open())
{
//错误处理
}
static QSqlQueryModel *model = new QSqlQueryModel(ui->tableview)
model->setQuery(QString("select * from table"))
model->setHeaderData(0,Qt::Horizontal,QObject::tr("编号"))
model->setHeaderData(1,Qt::Horizontal,QObject::tr("姓名"))
model->setHeaderData(2,Qt::Horizontal,QObject::tr("年龄"))
ui->tableview->setModel(model)
db->close()
这样之后,table表里的内容就会显示到tableview中了。
可以采用Stacked Layouts分页布局,具体实现代码如下,望采纳://创建QWidget类的一个对象pWidget
QWidget *pWidget = new QWidget
//创建一个布局管理器类 layout
QHBoxLayout *manLayout = new QHBoxLayout
//左边的列表控件
QListWidget *listWidget = new QListWidget(pWidget)
listWidget->addItem(QObject::tr("外观设置"))
listWidget->addItem(QObject::tr("网页浏览"))
...
//右边的分页控件
QWidget *page1 = new QWidget(pWidget)
<…page1上增加控件>
QWidget *page2 = new QWidget(pWidget)
<…page2上增加控件>
<设置布局管理>
QVBoxLayout *leftLayout = new QVBoxLayout
leftLayout->addWidget(listWidget)
....
//右边分页布局(两页窗口)
QStackedLayout *stackedLayout = new QStackedLayout
stackedLayout->addWidget(page1)
stackedLayout->addWidget(page2)
//通过调用QWidget::setLayout()函数,将layout布局管理器类添加到窗口部件对象pWidget中
manLayout->addLayout(leftLayout)
manLayout->addLayout(stackedLayout)
pWidget->setLayout(manLayout)
listWidget->setCurrentRow(0)
//关联:列表与分组布局
QObject::connect(listWidget, SIGNAL(currentRowChanged(int)),
stackedLayout, SLOT(setCurrentIndex(int)))
pWidget->show()
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)