QSqlDatabase、QSqlQuery、QSqlRecord、Sqlite用法

2024-06-07 21:04

本文主要是介绍QSqlDatabase、QSqlQuery、QSqlRecord、Sqlite用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用QSqlDatabase、QSqlQuery、QSqlRecord、Sqlite数据库实现一个简单的界面查询

1. 创建Sqlite数据库,表

mainwindow.cpp

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include "QSqlDatabase"
#include "QSqlQuery"
#include "QSqlError"
#include "QMessageBox"
#include "QFileDialog"
#include "QSqlRecord"MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow)
{ui->setupUi(this);// ui->openBtn->setEnabled(true);// ui->qryBtn->setEnabled(false);
}MainWindow::~MainWindow()
{delete ui;
}//打开数据库连接
void MainWindow::on_openBtn_clicked()
{QString aFile= QFileDialog::getOpenFileName(this,"选择文件","","SQLite 数据库(*.db3)");if (aFile.isEmpty())return;DB = QSqlDatabase::addDatabase("QSQLITE"); //添加 SQLITE 数据库驱动DB.setDatabaseName(aFile);// QTextCodecif (!DB.open()) {QMessageBox::critical(NULL, "错误", "数据库连接失败", QMessageBox::Ok, QMessageBox::Ok);qDebug() << "FAIL" << DB.lastError().text();} else {QMessageBox::information(NULL, "信息", "数据库连接成功");qDebug() << "SUCCESS";// ui->openBtn->setEnabled(false);// ui->qryBtn->setEnabled(true);}
}void MainWindow::on_qryBtn_clicked()
{qryModel= new QSqlQueryModel(this);selModel= new QItemSelectionModel(qryModel,this);// ui->tableView->model()ui->tableView->setModel(qryModel);ui->tableView->setSelectionModel(selModel);qryModel->setQuery("SELECT id,name, Gender, gender, hobby "" FROM t_user ORDER BY id");if (qryModel->lastError().isValid()){QMessageBox::information(this, "错误", "数据表查询错误,错误信息\n"+qryModel->lastError().text());return;}QSqlRecord rec= qryModel->record(); //获取空记录,用于获取字段序号//设置字段显示标题qryModel->setHeaderData(rec.indexOf("id"),Qt::Horizontal, "序号");qryModel->setHeaderData(rec.indexOf("name"), Qt::Horizontal, "姓名");qryModel->setHeaderData(rec.indexOf("gender"), Qt::Horizontal, "性别");qryModel->setHeaderData(rec.indexOf("hobby"), Qt::Horizontal, "爱好");
}

mainwindow.h文件

#ifndef MAINWINDOW_H
#define MAINWINDOW_H#include <QMainWindow>
#include <QSqlDatabase>
#include <QSqlQueryModel>
#include <QItemSelectionModel>QT_BEGIN_NAMESPACE
namespace Ui {
class MainWindow;
}
QT_END_NAMESPACEclass MainWindow : public QMainWindow
{Q_OBJECTpublic:MainWindow(QWidget *parent = nullptr);~MainWindow();
private:QSqlDatabase DB; //数据库连接QSqlQueryModel *qryModel; //Query数据模型QItemSelectionModel *selModel; //选择模型private slots:void on_openBtn_clicked();void on_qryBtn_clicked();private:Ui::MainWindow *ui;
};
#endif // MAINWINDOW_H

结果

这篇关于QSqlDatabase、QSqlQuery、QSqlRecord、Sqlite用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1040289

相关文章

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

C#使用SQLite进行大数据量高效处理的代码示例

《C#使用SQLite进行大数据量高效处理的代码示例》在软件开发中,高效处理大数据量是一个常见且具有挑战性的任务,SQLite因其零配置、嵌入式、跨平台的特性,成为许多开发者的首选数据库,本文将深入探... 目录前言准备工作数据实体核心技术批量插入:从乌龟到猎豹的蜕变分页查询:加载百万数据异步处理:拒绝界面

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

java之Objects.nonNull用法代码解读

《java之Objects.nonNull用法代码解读》:本文主要介绍java之Objects.nonNull用法代码,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录Java之Objects.nonwww.chinasem.cnNull用法代码Objects.nonN

JavaScript Array.from及其相关用法详解(示例演示)

《JavaScriptArray.from及其相关用法详解(示例演示)》Array.from方法是ES6引入的一个静态方法,用于从类数组对象或可迭代对象创建一个新的数组实例,本文将详细介绍Array... 目录一、Array.from 方法概述1. 方法介绍2. 示例演示二、结合实际场景的使用1. 初始化二

一文带你了解SpringBoot中启动参数的各种用法

《一文带你了解SpringBoot中启动参数的各种用法》在使用SpringBoot开发应用时,我们通常需要根据不同的环境或特定需求调整启动参数,那么,SpringBoot提供了哪些方式来配置这些启动参... 目录一、启动参数的常见传递方式二、通过命令行参数传递启动参数三、使用 application.pro

关于@RequestParam的主要用法详解

《关于@RequestParam的主要用法详解》:本文主要介绍关于@RequestParam的主要用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 基本用法2. 默认值3. 可选参数4. 绑定到对象5. 绑定到集合或数组6. 绑定到 Map7. 处理复杂类

SQL中的CASE WHEN用法小结

《SQL中的CASEWHEN用法小结》文章详细介绍了SQL中的CASEWHEN函数及其用法,包括简单CASEWHEN和CASEWHEN条件表达式两种形式,并通过多个实际场景展示了如何使用CASEWH... 目录一、简单CASE WHEN函数:二、CASE WHEN条件表达式函数三、常用场景场景1:不同状态展

Linux find 命令完全指南及核心用法

《Linuxfind命令完全指南及核心用法》find是Linux系统最强大的文件搜索工具,支持嵌套遍历、条件筛选、执行动作,下面给大家介绍Linuxfind命令完全指南,感兴趣的朋友一起看看吧... 目录一、基础搜索模式1. 按文件名搜索(精确/模糊匹配)2. 排除指定目录/文件二、根据文件类型筛选三、时间

Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)

《Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)》:本文主要介绍Java导入、导出excel的相关资料,讲解了使用Java和ApachePOI库将数据导出为Excel文件,包括... 目录前言一、引入Apache POI依赖二、用法&步骤2.1 创建Excel的元素2.3 样式和字体2.