在QT中,我们可以使用QThread来创建一个新的线程来执行数据库的写入操作。这样可以避免在主线程中进行数据库操作而引起的界面冻结问题。
解决方案1:使用QThread
class DatabaseWriter : public QThread
{
Q_OBJECT
public:
DatabaseWriter(QObject *parent = nullptr) : QThread(parent) {}
void run() override {
// 数据库写入操作
// 例如:
// QSqlQuery query(QSqlDatabase::database());
// query.exec("INSERT INTO table_name (column1, column2) VALUES (value1, value2)");
}
signals:
void error(const QString &message);
void finished();
public slots:
void writeData(const QVariant &data) {
// 数据处理和准备
// 例如:
// QVariant data = ...
// 在这里可以对data进行处理
// 数据库写入操作
// 例如:
// QSqlQuery query(QSqlDatabase::database());
// query.exec("INSERT INTO table_name (column1, column2) VALUES (value1, value2)");
// 如果写入成功,发送finished信号
emit finished();
}
};
在主线程中,你可以这样使用这个线程:
DatabaseWriter *databaseWriter = new DatabaseWriter(this);
connect(databaseWriter, &DatabaseWriter::finished, this, [this]() {
// 数据库写入完成后的操作
});
connect(databaseWriter, &DatabaseWriter::error, this, [this](const QString &message)
// 处理错误信息
});
// 准备数据并开始写入
QVariant data = ...
databaseWriter->writeData(data);
解决方案2:使用QRunnable
class DatabaseWriter : public QObject
{
Q_OBJECT
public:
DatabaseWriter(QObject *parent = nullptr) : QObject(parent) {}
public slots:
void writeData(const QVariant &data) {
// 数据处理和准备
// 例如:
// QVariant data = ...
// 在这里可以对data进行处理
// 数据库写入操作
// 例如:
// QSqlQuery query(QSqlDatabase::database());
// query.exec("INSERT INTO table_name (column1, column2) VALUES (value1, value2)");
}
};
// 创建QRunnable对象
DatabaseWriter *databaseWriter = new DatabaseWriter(this);
QThread *thread = new QThread(this);
databaseWriter->moveToThread(thread);
// 连接信号和槽以启动写入操作
QVariant data = ...
connect(this, &MainWindow::startWriting, databaseWriter, &DatabaseWriter::writeData);
// 发送startWriting信号