当前位置: 首页 > wzjs >正文

珠海企业模板建站东莞南城网站开发公司电话

珠海企业模板建站,东莞南城网站开发公司电话,室内设计师优秀简介,兰州网络推广专员数据库简介 关于数据库的基础知识这里就不做介绍了,相关博客可以查看: SQL基础知识 数据库学霸笔记 上面博客都写的比较详细,本文主要介绍如何使用Qt进行数据库相关操作,数据库分为关系型数据库和非关系型数据,关系…

数据库简介

关于数据库的基础知识这里就不做介绍了,相关博客可以查看:

SQL基础知识

数据库学霸笔记

上面博客都写的比较详细,本文主要介绍如何使用Qt进行数据库相关操作,数据库分为关系型数据库和非关系型数据,关系型数据库主要有Sqlite、MySQL、Oracle、SQLServer、PostgreSQL等,非关系型数据库主要有Redis、Cassandra、MongoDB等。这次主要介绍Qt使用SQlite数据库。

基础SQL操作

Qt使用数据库工程文件记得引入sql模块:

QT  += sql

数据库初始化:

    //查看支持的数据库驱动for (const QString &driver : QSqlDatabase::drivers()) {qDebug() << driver;}//建立数据库连接m_Db = QSqlDatabase::addDatabase("QSQLITE");//设置本地数据库文件m_Db.setDatabaseName("test.db");//打开数据库if (!m_Db.open()) { qDebug() << "open db fail"; }//创建表QString execSql =QString("create table if not exists testinfo(name varchar(64),id ""varchar(64),createdate varchar(64))");//遍历输出该数据库中所有表名for (const QString &table : m_Db.tables()) { qDebug() << table; }QSqlQuery query;if (!query.exec(execSql)) { qDebug() << query.lastError().text(); }

上述代码中先查看数据库驱动,数据库驱动是应用程序和数据库之间的桥梁,提供访问数据库所需的工具和 API(应用程序编程接口)。查看程序输出打印:

Qt默认支持一些驱动,可以看到有SQlite,但是没有MySQL,如若要用Qt进行MySQL相关数据库操作则需额外安装相关驱动(本文不作介绍)。然后查看生成了对应的数据库文件test.db。

如何查看这个数据库文件了,我推荐使用DB browser for SQLite,使用比较简单,使用该软件打开对应数据库文件:

可以看到我们在代码中创建的表,点击"浏览数据":

数据库表数据相关操作,无非增删查改四种,界面添加对应按钮,编写对应槽函数代码。

增:

void MainWindow::on_insert_clicked() {if (ui->name->text().isEmpty() || ui->id->text().isEmpty()) { return; }if (!m_Db.isOpen()) { return; }QString name = ui->name->text().trimmed();QString id = ui->id->text().trimmed();QString date = QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss");QString execSql = QString("insert into testinfo (name,id, createdate) ""values('%1', '%2', '%3')").arg(name).arg(id).arg(date);QSqlQuery query;if (!query.exec(execSql)) { qDebug() << query.lastError().text(); }
}

输入数据点击添加按钮:

查看数据表内容:

 可以看到一条数据已经成功添加。

删:

void MainWindow::on_delete_2_clicked() {if (ui->name->text().isEmpty()) { return; }if (!m_Db.isOpen()) { return; }QString name = ui->name->text().trimmed();QString execSql =QString("delete from testinfo where name = '%1';").arg(name);QSqlQuery query;if (!query.exec(execSql)) { qDebug() << query.lastError().text(); }
}

我在数据库中添加了一条数据,然后点击按钮删除对应指定name的数据

点击按钮后数据已删除:

 查:

void MainWindow::on_select_clicked() {QString name = ui->name->text();QString id = ui->id->text();QString execSql = QString();if (name.isEmpty() && id.isEmpty()) {execSql = QString("select * from testinfo");} else if (!name.isEmpty() && id.isEmpty()) {execSql = QString("select * from testinfo where name = '%1'").arg(name);} else if (name.isEmpty() && !id.isEmpty()) {execSql = QString("select * from testinfo where id = '%1'").arg(id);} else {execSql =QString("select * from testinfo where name = '%1' and id = '%2'").arg(name).arg(id);}QSqlQuery query;if (!query.exec(execSql)) {qDebug() << query.lastError().text();} else {while (query.next()) {QSqlRecord rec = query.record(); //获取列QStringList vals;for (int i = 0; i < rec.count(); ++i) {vals.append(rec.value(i).toString());}ui->textEdit->append(vals.join(","));}}
}

执行效果不作演示。(select的where用法比较多,详细可以查看文章开头推荐的第一篇博客)

改:

void MainWindow::on_update_clicked() {//修改指定name的id值if (ui->name->text().isEmpty() || ui->id->text().isEmpty()) { return; }if (!m_Db.isOpen()) { return; }QString name = ui->name->text().trimmed();QString id = ui->id->text().trimmed();QString execSql = QString("update testinfo set id = '%1' where name = '%2'").arg(id).arg(name);QSqlQuery query;if (!query.exec(execSql)) { qDebug() << query.lastError().text(); }
}

根据界面输入的name和id,将指定name的数据id改为指定值:

额外补充:删除表为:drop+表名,该操作会将表中所有数据以及表结果删除,如果只是想删除所有数据则为: truncate+表名。

事务

事务是一组操作的集合,这些操作被视为一个单一的工作单元。事务要么完成所有操作,要么取消所有操作,保持数据库在良好的状态下。

比如我现在要一次性插入多条数据,用事务如下编写:

void MainWindow::on_test_clicked() {//使用事务添加100条数据QStringList sqlList;for (int i = 0; i < 100; ++i) {QString execSql = QString("insert into testinfo (name,id, createdate) ""values('%1', '%2', '%3')").arg(i).arg(i).arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss"));sqlList.append(execSql);}if (!m_Db.isOpen()) { return; }m_Db.transaction(); //开启事务for (const QString &execSql : sqlList) {QSqlQuery query(m_Db);bool b = query.exec(execSql);if (!b) {m_Db.rollback(); //失败进行回滚return;}}m_Db.commit(); //事务提交
}

点击按钮后查看数据内容:

 

内容已添加。 


文章转载自:

http://0BUuOXtc.gwcjq.cn
http://xuV5QYI2.gwcjq.cn
http://oA19kGHS.gwcjq.cn
http://2JnNKCQb.gwcjq.cn
http://o8b7qxVr.gwcjq.cn
http://ZEElzn4l.gwcjq.cn
http://85jqYauE.gwcjq.cn
http://O7AxtGFB.gwcjq.cn
http://mWklUgF9.gwcjq.cn
http://fH4rqmJ2.gwcjq.cn
http://3mebHSor.gwcjq.cn
http://BLuiTUQ9.gwcjq.cn
http://lOAbSW4N.gwcjq.cn
http://kWhBuzQi.gwcjq.cn
http://OnIDLg8o.gwcjq.cn
http://GGLg8uFv.gwcjq.cn
http://ZdZfRhdE.gwcjq.cn
http://ocTZpQXe.gwcjq.cn
http://zdqCLVei.gwcjq.cn
http://ZUJoMR5I.gwcjq.cn
http://W9YQd9iT.gwcjq.cn
http://USTFA2ji.gwcjq.cn
http://d3tAcvTa.gwcjq.cn
http://bOlJbiNe.gwcjq.cn
http://n3FPjeOj.gwcjq.cn
http://iKyJ77b5.gwcjq.cn
http://5QylRtO7.gwcjq.cn
http://whW2evbp.gwcjq.cn
http://ezO5Tc3z.gwcjq.cn
http://6Q0fAf9K.gwcjq.cn
http://www.dtcms.com/wzjs/766933.html

相关文章:

  • 织梦网站搭建如何加强网站安全建设
  • 做网站的属于什么工作类型大理石在哪些网站做宣传
  • 开源外贸网站公司在百度做网站
  • 深圳做响应式网站制作贷款公司通过做网站来给予平台贷款
  • 沈阳专业网站建设报价有批量做基因结构的网站吗
  • 太原建站公司有哪些网站建设公司哪个好呀金融网站建设
  • 专业网站的建设网站模板编辑工具
  • 嘉兴企业网站设计哪家好重庆免费网站建站模板
  • 建立网站 营业执照移动互联网包括三个基本要素( )、( )和( )。
  • 牡丹江3d网站开发seo搜索排名优化公司
  • 盘锦建设资质网站wordpress数据库ip
  • 做那事的网站工作室网页模板
  • 网站游戏制作开发吉林市网站推广
  • 如何给网站续费潮流印花图案设计网站
  • 广州市官网网站建设怎么样wordpress元器件
  • 网站的好处平面设计公司赚钱吗
  • 淘掌门官方网站wordpress h1美化
  • php网站只能打开首页怎么利用百度云盘做网站
  • 自建网站流程2023网站推广入口
  • 外贸网站建设团队物流公司网站方案
  • 怎么在公众号做影视网站小马厂网站建设
  • 设计了网站首页建筑网价格
  • 科凡网站建设公司彩页宣传手册
  • 门网站源码好的网站建设价格
  • 上海企业建站咨询无锡cms建站
  • 学校网站建设项目可行性分析报告沈阳恢复营业通知
  • 成品免费观看网站wordpress jquery.js
  • 网站如何做301跳转专业的广州微网站建设
  • 自己做网站服务器多少钱怀化最新通知今天
  • 网站建设项目描述范文网站的基本组成部分有哪些内容