Qt的SQL操作,DELETE,SELECT

#include <QObject>
#include <QSqlDatabase>
#include <QSqlError>
#include <QSqlQuery>
#include <QString>
 
class DatabaseManager : public QObject
    {
    public:
        DatabaseManager(QObject *parent = 0);
        ~DatabaseManager();
 
    public:
        bool openDB();
        bool deletePerson(int id);
 
    private:
        QSqlDatabase db;
    };

Delete a person from the database:

bool DatabaseManager::deletePerson(int id)
    {
    bool ret = false;
    if (db.isOpen())
        {
        QSqlQuery query;
        ret = query.exec(QString("delete from person where id=%1").arg(id));
        }
    return ret;
    }

The rest of the code:

bool DatabaseManager::openDB()
    {
    // Find QSLite driver
    db = QSqlDatabase::addDatabase("QSQLITE");
 
    #ifdef Q_OS_LINUX
    // NOTE: We have to store database file into user home folder in Linux
    QString path(QDir::home().path());
    path.append(QDir::separator()).append("my.db.sqlite");
    path = QDir::toNativeSeparators(path);
    db.setDatabaseName(path);
    #else
    // NOTE: File exists in the application private folder, in Symbian Qt implementation
    db.setDatabaseName("my.db.sqlite");
    #endif
 
    // Open databasee
    return db.open();
    }

以上参考http://developer.nokia.com/community/wiki/Deleting_data_from_a_database_in_Qt

SELECT核心语句

bool DatabaseManager::getPerson(int id, PersonData*& person)
    {
    bool ret = false;
 
    QSqlQuery query(QString("select * from person where id = %1").arg(id));
    if (query.next())
        {
        person->id = query.value(0).toInt();
        person->firstname = query.value(1).toString();
        person->lastname = query.value(2).toString();
        person->age = query.value(3).toInt();
        ret = true;
        }
 
    return ret;
    }

以上参考http://developer.nokia.com/community/wiki/Searching_for_data_in_a_database_in_Qt

 

如果有多个参数,可以是 %1,%2,%3 之后.arg().arg().arg()括号里填对应变量。

转载于:https://www.cnblogs.com/browncrane/p/4209028.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Qt SQL,可以使用QSqlQuery来执行数据库删除操作。具体的删除语句可以通过qry.exec()方法传入一个字符串,包含要执行的SQL语句。例如,可以使用以下代码删除名为"Sys_user"表满足给定条件的记录: QSqlQuery qry(db); qry.exec(QString("delete from Sys_user where name = '%1' and password = '%2';").arg(res1).arg(res2)); 这段代码,res1和res2是要匹配的条件值。同样的方式也可以用来删除其他表的记录,只需修改表名和条件。 另外,当执行数据库删除操作后,已删除的记录所占用的内存并不会自动释放,而是保留为碎片。为了释放这些碎片空间,可以使用vacuum功能。例如,可以像以下代码一样在删除操作后执行vacuum: QSqlQuery qry(db); qry.exec("vacuum"); 执行vacuum操作后,被删除记录所占用的内存碎片将被释放,数据库文件的大小也会相应变小。 总结起来,Qt SQL的删除操作可以通过QSqlQuery的exec()方法执行SQL语句来实现,同时可以使用vacuum功能释放删除操作所占用的内存碎片。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [qtsql删除间隔大量数据](https://blog.csdn.net/qq_37603131/article/details/104131769)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [QtCreator Qt执行SQL语句,select,update,delete,insert](https://blog.csdn.net/psujtfc/article/details/38057421)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值