c++ qt tableview使用model view显示数据库的数据并且使用委托更改数据保存到数据库中
时间: 2024-04-30 17:23:07 浏览: 233
在使用Qt的TableView显示数据库数据时,需要使用Model-View架构来实现。具体步骤如下:
1.创建数据库连接
需要使用Qt自带的QSqlDatabase类来创建数据库连接,并且需要指定数据库类型、主机地址、数据库名、用户名和密码等信息。
2.创建数据模型
使用Qt自带的QSqlTableModel类来创建数据模型,并且需要指定数据表名和数据库连接等信息。
3.设置TableView
使用Qt自带的QTableView类来显示数据,并且需要设置数据模型、列宽、列标题等信息。
4.使用委托
使用Qt自带的QItemDelegate类来创建委托,并且需要重写委托的paint()和createEditor()等函数来实现自定义的数据显示和编辑功能。
5.保存数据
在数据发生变化时,需要使用数据模型的submitAll()函数来保存数据到数据库中。
完整代码如下:
```
#include <QtWidgets>
#include <QtSql>
class MyDelegate : public QItemDelegate
{
public:
MyDelegate(QObject *parent = nullptr): QItemDelegate(parent) {}
void paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const override
{
// 自定义绘制函数,显示数据时添加单位
QString text = index.data().toString() + " kg";
drawDisplay(painter, option, option.rect, text);
}
QWidget *createEditor(QWidget *parent, const QStyleOptionViewItem &option, const QModelIndex &index) const override
{
// 自定义编辑函数,编辑时去掉单位
QLineEdit *editor = new QLineEdit(parent);
QString text = index.data().toString();
editor->setText(text.left(text.indexOf(" ")));
return editor;
}
void setEditorData(QWidget *editor, const QModelIndex &index) const override
{
QString text = index.data().toString();
QLineEdit *lineEdit = static_cast<QLineEdit*>(editor);
lineEdit->setText(text.left(text.indexOf(" ")));
}
void setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) const override
{
QLineEdit *lineEdit = static_cast<QLineEdit*>(editor);
QString text = lineEdit->text() + " kg";
model->setData(index, text, Qt::EditRole);
}
};
int main(int argc, char *argv[])
{
QApplication app(argc, argv);
// 创建数据库连接
QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
db.setDatabaseName("test.db");
if (!db.open()) {
qDebug() << "Failed to connect to database!";
return -1;
}
// 创建数据模型
QSqlTableModel model;
model.setTable("weight");
model.select();
// 设置TableView
QTableView tableView;
tableView.setModel(&model);
tableView.setItemDelegate(new MyDelegate);
tableView.setColumnWidth(0, 150);
tableView.setColumnWidth(1, 100);
tableView.setHorizontalHeaderLabels(QStringList() << "Name" << "Weight");
// 保存数据
QPushButton saveButton("Save");
QObject::connect(&saveButton, &QPushButton::clicked, [&model]() {
model.submitAll();
});
// 显示窗口
QVBoxLayout layout;
layout.addWidget(&tableView);
layout.addWidget(&saveButton);
QWidget window;
window.setLayout(&layout);
window.show();
return app.exec();
}
```
阅读全文