zoukankan      html  css  js  c++  java
  • 33Sql数据删除与遍历

    数据库的创建、添加、修改、查询、删除都是利用SQL语句和类QSqlQuery的结合。

    QSqlDatabase::database()。可返回当前正在打开的数据库对象。

    数据库的删除

        //获取删除的名字

        QString strName=ui->lineEdit->text();

        //开始事务

    QSqlDatabase::database().transaction();

    //删除该数据,但数据库没有更新,需要事务的提交

        QString strTemp=QString("DELETE FROM  student WHERE sname='%1'").arg(strName);

      //执行

        QSqlQuery query;

    query.exec(strTemp);

    提交事务

    QSqlDatabase::database().commit();

    撤销操作,回到transaction()处

    QSqlDatabase::database().rollback();

    事务:简单来说就等同于一个点。当后面出现错误操作时,可以回滚到该点上,撤销操作。

    遍历数据库

        //查询数据库

        query.exec("SELECT * FROM student;");

        //遍历数据库,输出所有数据

        while(query.next())

        {

            qDebug()<<query.value("id").toInt()

                        <<query.value("sname").toString()

                        <<query.value("age").toString()

                        <<query.value("score").toInt();

    }

    修改数据

    修改数据

        //获取修改的名字

    QString strName1=ui->lineEdit->text();

      //修改后的名字

    QString strName2=ui->lineEdit_2->text();

        //开始事务

    QSqlDatabase::database().transaction();

    //删除该数据,但数据库没有更新,需要事务的提交

        QString strTemp=QString("DELETE FROM  student set  sname=’%1 ’ WHERE sname='%2").arg(strName2).arg(strName1);

      //执行

        QSqlQuery query;

    query.exec(strTemp);

  • 相关阅读:
    关于Android架构那些事
    关于投资那些事
    关于单例模式的N种实现方式
    关于如何避免Android中Bitmap引起的OutOfMemoryError
    关于Java设计模式的一些概况
    阿里云服务器使用记录:服务器运行的网页无法访问
    毕业设计进度:3月22日
    前端框架:bootstrap多个模态框跳转使用时发生的页面左移问题
    毕业设计进度:3月20日
    毕业设计进度:3月19日
  • 原文地址:https://www.cnblogs.com/gd-luojialin/p/9215871.html
Copyright © 2011-2022 走看看