您可以使用Qt的定时器(QTimer)来实现这个功能。您可以创建一个定时器并将其设置为每隔两周触发一次,然后在每次触发时清空数据库。
以下是一个示例代码:
#include <QtCore>
#include <QtSql>
int main(int argc, char *argv[]) {
QApplication a(argc, argv);
// Connect to the database
QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
db.setDatabaseName("mydatabase.db");
if (!db.open()) {
qDebug() << "Failed to open database";
return -1;
}
// Create a timer that triggers every two weeks
QTimer timer;
timer.setInterval(14 * 24 * 60 * 60 * 1000); // 14 days in milliseconds
QObject::connect(&timer, &QTimer::timeout, [&]() {
// Clear the database
QSqlQuery query(db);
query.exec("DELETE FROM mytable");
});
timer.start();
return a.exec();
}
请注意,在上面的代码中,我们使用 lambda 表达式来定义 timeout 槽。lambda 表达式是一个匿名函数,它可以直接在信号和槽连接中使用。
此外,请确保正确设置定时器的时间间隔,并在 QApplication::exec() 调用之前启动它以确保其正常工作。