华为云征文|Flexus云服务X实例应用,通过QT连接华为云MySQL,进行数据库的操作,数据表的增删改查

news2024/9/23 3:12:08

在这里插入图片描述

引出


4核12G-100G-3M规格的Flexus X实例使用测评第3弹:Flexus云服务X实例应用,通过QT连接华为云MySQL,进行数据库的操作,数据表的增删改查

什么是Flexus云服务器X实例

官方解释:

Flexus云服务器X实例是新一代面向中小企业和开发者打造的柔性算力云服务器,可智能感知业务负载,适用于电商直播、企业建站、开发测试环境、游戏服务器、音视频服务等中低负载场景。相较于Flexus应用服务器L实例,Flexus云服务器X实例的优势包含:提供丰富的公共镜像、可灵活自定义vCPU内存配比、智能感知业务动态升降配,负载范围更高等。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

QT连接华为云MySQL

创建连接

通过QSqlDatabase设置和华为云数据库的连接,需要指定驱动,然后设置主机端口,数据库名称,用户名和密码

bool MainWindow::connectMySQL(){
    qDebug() << "\n======进行数据库的链接====";

    dbWeb = QSqlDatabase::addDatabase("QODBC"); // 使用 QMYSQL 驱动
    dbWeb.setHostName(""); // 云数据库的主机地址
    dbWeb.setPort(3306); // 端口
    dbWeb.setDatabaseName("huawei"); // 数据库名称
    dbWeb.setUserName("root"); // 用户名
    dbWeb.setPassword(""); // 密码

    if (!dbWeb.open()) {
        qDebug() << "Database error occurred:" << dbWeb.lastError().text();
        return false;
    }

    qDebug() << "连接成功";
    return true;
}

数据库操作和表创建

查询现有的数据库

查询现有的所有数据库,通过QT中提供的QSqlQuery进行查询

void MainWindow::queryDataBase(QSqlDatabase db){
    // 查询数据库的库
    qDebug() << "\n========查询库========";
    QSqlQuery query(db);
    if(query.exec("SHOW DATABASES")){
        while (query.next()) {
            QString databaseName = query.value(0).toString();
            qDebug() << "DB" << databaseName;
        }
    }else {
        qDebug() << "error:" << dbWeb.lastError().text();
    }
}

控制台打印出查询的结果

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

创建数据库

执行新建数据库的操作,通过query进行执行

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

函数功能优化,支持输入数据库的名称进行新建数据库

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

void MainWindow::createDataBase(QSqlDatabase db, QString dbName){
    qDebug() << "\n=======创建数据库" << dbName << "=======";
    queryDataBase(db);

    // 新建数据库
    QSqlQuery query(db);
    QString q = "CREATE DATABASE IF NOT EXISTS " + dbName;
    if(!query.exec(q)){
        qDebug() << "error:" << db.lastError().text();
    }

    queryDataBase(db);
}

在库中创建表

在ODBC中设置数据库

首先在ODBC中编辑连接,选择DataBase为想要插入的表,选择Database下拉菜单,可以看到我们放个创建的数据表,这里选择example_db这个数据库

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

编写代码执行,在数据库中创建一张新的表

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

	    QSqlQuery query(db);
        QString createTableQuery = R"(CREATE TABLE IF NOT EXISTS Person (
            id INTEGER,
            name TEXT,
            age INTEGER
        ))";

        if (!query.exec(createTableQuery)) {
            qDebug() << "Error: Unable to create table." << query.lastError();
        }

数据表的操作–增删改查

数据增加插入

通过qt往华为云的数据库中插入数据,我们设置了主键自增,所以只需要传名字和年龄即可;

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

bool MainWindow::insertData(QSqlDatabase db,const QString &name,int age){
//    qDebug() << "\n========插入数据=======";
    QSqlQuery query(db);
    query.prepare("INSERT INTO Person (name, age) VALUES (:name, :age)");
    query.bindValue(":name", name);
    query.bindValue(":age", age);

    if (!query.exec()) {
        qDebug() << "Error: Unable to insert data into table 'Person'." << query.lastError();
        return false;
    }
    return true;
}

数据的删除

两种删除的方式:

1.通过id删除,通过数据表的主键进行删除,一次删除一个数据;

2.通过名字删除,会一次删除多行数据;

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

bool MainWindow::deleteByName(QSqlDatabase db, const QString &name){
    QSqlQuery query(db);

    query.prepare("DELETE FROM Person WHERE name = :name");
    query.bindValue(":name", name);

    if (!query.exec()) {
        qDebug() << "Error: Unable to delete data from table 'Person' by name." << query.lastError();
        return false;
    }

    return true;
}

bool MainWindow::deleteByID(QSqlDatabase db, int id){
    QSqlQuery query(db);

    query.prepare("DELETE FROM Person WHERE id = :id");
    query.bindValue(":id", id);

    if (!query.exec()) {
        qDebug() << "Error: Unable to delete data from table 'Person' by id." << query.lastError();
        return false;
    }

    return true;
}

数据的修改

选择id为特定值的数据进行修改,可以同时修改名字和年龄,也可以只修改名字,或者只需改年龄;

如果年龄输入-1,则只修改名字

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

如果名字为空,则只修改年龄

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

bool MainWindow::updateByID(QSqlDatabase db, int id, const QString &newName,int newAge){

    QSqlQuery query(db);

    // 构建更新SQL语句
    QString updateQuery = "UPDATE Person SET";
    bool nameToUpdate = !newName.isEmpty();
    bool ageToUpdate = newAge != -1;

    if (nameToUpdate) {
        updateQuery += " name = :name";
    }
    if (ageToUpdate) {
        if (nameToUpdate) {
            updateQuery += ",";
        }
        updateQuery += " age = :age";
    }
    updateQuery += " WHERE id = :id";

    query.prepare(updateQuery);

    if (nameToUpdate) {
        query.bindValue(":name", newName);
    }
    if (ageToUpdate) {
        query.bindValue(":age", newAge);
    }
    query.bindValue(":id", id);

    if (!query.exec()) {
        qDebug() << "Error: Unable to update data in table 'Person' by id." << query.lastError();
        return false;
    }

    return true;

}

数据的查询

首先重写实体类的<< 方法,提供格式化输出函数,方便控制台打印查看

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

QDebug operator<<(QDebug dbg, const Person &data) {
    dbg.nospace() << "person("
           << QString::number(data.id) << ","
           << data.name  << ","
           << QString::number(data.age)  << ")";
    return dbg.space();
}

根据ID查询单个

设置了主键自增,是唯一的,所有通过id查询,会查询到一个数据;

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

Person MainWindow::queryById(QSqlDatabase db, int id){
    QSqlQuery query(db);

    query.prepare("SELECT name, age FROM Person WHERE id = :id");
    query.bindValue(":id", id);

    if (!query.exec()) {
        qDebug() << "Error: Unable to query data from table 'Person' by id." << query.lastError();
        return Person(-1,"",-1);
    }

    if (query.next()) {
        QString name = query.value("name").toString();
        int age = query.value("age").toInt();
        return Person(id, name, age);
    }

    return Person(-1,"",-1);;
}

根据name查询多个

人员的名字会重复,一次性会查询出多个,所以用一个容器进行数据的接收。

![外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传](https://img-home.csdnimg.cn/images/20230724024159.

// 根据名字查询多个
std::vector<Person> MainWindow::queryByName(QSqlDatabase db, const QString &name){
    QSqlQuery query(db);

    query.prepare("SELECT id, name, age FROM Person WHERE name = :name");
    query.bindValue(":name", name);

    std::vector<Person> persons;

    if (!query.exec()) {
        qDebug() << "Error: Unable to query data from table 'Person' by name." << query.lastError();
        return persons;
    }

    while (query.next()) {
        int id = query.value("id").toInt();
        QString name = query.value("name").toString();
        int age = query.value("age").toInt();
        persons.emplace_back(id, name, age);
    }

    return persons;
}

总结

4核12G-100G-3M规格的Flexus X实例使用测评第3弹:Flexus云服务X实例应用,通过QT连接华为云MySQL,进行数据库的操作,数据表的增删改查

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2101418.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【python】如何用python代码快速生成二维码

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…

【算法思想·二叉树】思路篇

本文参考labuladong算法笔记[东哥带你刷二叉树&#xff08;思路篇&#xff09; | labuladong 的算法笔记] 本文承接 【算法思想二叉树】纲领篇&#xff0c;先复述一下前文总结的二叉树解题总纲&#xff1a; 二叉树解题的思维模式分两类&#xff1a; 1、是否可以通过遍历一遍二…

数据结构——单链表相关操作

zhuzhu1、结构框图&#xff1a; 2、增删改查&#xff1a; 定义链表节点和对象类型 /*************************************************************************> File Name: link.h> Author: yas> Mail: rage_yashotmail.com> Created Time: Tue 03 Sep 2024…

ServiceStage集成Sermant实现应用的优雅上下线

作者&#xff1a;聂子雄 华为云高级软件工程师 摘要 优雅上下线旨在确保服务在进行上下线操作时&#xff0c;能够平滑过渡&#xff0c;避免对业务造成影响&#xff0c;保证资源的高效利用。Sermant基于字节码增强的技术实现了应用优雅上下线能力&#xff0c;应用发布与运维平…

摩博会倒计时!OneOS操作系统抢先了解!

2024年第二十二届中国国际摩托车博览会&#xff08;摩博会&#xff09;临近&#xff0c;中移物联OneOS与智能硬件领域佼佼者恒石智能宣布强强合作&#xff0c;与9月13日至16日在重庆国家会展中心共同展现多款Model系列芯片&#xff08;Model3、Model4、Model3C、Model3A&#x…

I2C软件模拟时序的基本要素

目录 前言 一、关于I2C 二、正文 1.引脚的配置 2.I2C的起始和终止时序 3.发送一个字节 4.接收一个字节 5.应答信号 6.指定地址写和指定地址读 总结 前言 环境&#xff1a; 芯片&#xff1a;STM32F103C8T6 Keil&#xff1a;V5.24.2.0 本文主要参考江科大教程&#…

系统架构师考试学习笔记第三篇——架构设计高级知识(11)软件可靠性基础知识

本章知识点&#xff1a; 第11课时主要学习软件可靠性基本概念、建模、管理、设计、测试和评价等内容。本课时内容侧重于概念知识,根据以往全国计算机技术与软件专业技术资格(水平)考试的出题规律,考查的知识点多来源于教材,扩展内容较少。根据考试大纲,本课时知识点会涉及单项选…

注册安全分析报告:央视网

前言 由于网站注册入口容易被黑客攻击&#xff0c;存在如下安全问题&#xff1a; 暴力破解密码&#xff0c;造成用户信息泄露短信盗刷的安全问题&#xff0c;影响业务及导致用户投诉带来经济损失&#xff0c;尤其是后付费客户&#xff0c;风险巨大&#xff0c;造成亏损无底洞…

day47——面向对象特征之继承

一、继承&#xff08;inhert&#xff09; 面向对象三大特征&#xff1a;封装、继承、多态 继承&#xff1a;所谓继承&#xff0c;是类与类之间的关系。就是基于一个已有的类&#xff0c;来创建出一个新类的过程叫做继承。主要提高代码的复用性。 1.1 继承的作用 1> 实现…

16、修改Markdown Preview Enhanced默认样式

前言 vscode的markdown preview enhanced插件的主题并不一定符合每个人的审美&#xff0c;所以有的时候需要自定义,笔者根据网上大佬的文章整合了下自定义修改Markdown Preview Enhanced默认样式的方法&#xff0c;模板在文章中&#xff0c;大家可以直接使用&#xff0c;希望能…

【数据结构】反射,枚举你必须知道的相关知识

前言&#xff1a; &#x1f31f;&#x1f31f;本期讲解关于反射以及枚举&#xff0c;希望能帮到屏幕前的你。 &#x1f308;上期博客在这里&#xff1a;http://t.csdnimg.cn/7D225 &#x1f308;感兴趣的小伙伴看一看小编主页&#xff1a;GGBondlctrl-CSDN博客 目录 &#x1f…

获得并修改硬件序列号--CPU、主板、内存、硬盘等(有源码)

大家都知道很多Anti Cheat会封硬件序列号&#xff0c;所以本文探索一下如何get and modify序列号。 这个服务是比较贵的: 于是有了研究一下的想法。 思路: 1. 通过厂商自带的程序刷新固件。 2. 自己写驱动修改。 思路1不讨论&#xff0c;要拿到厂商去修改&#xff0c;很不方…

台球助教陪练预约系统源码开发

随着科技的发展和人们对生活质量要求的提高&#xff0c;体育运动的数字化趋势日益明显。台球作为一种集休闲娱乐与竞技于一体的运动项目&#xff0c;在全球范围内拥有广泛的爱好者群体。为了更好地满足这部分人群的需求&#xff0c;开发一个高效的台球助教陪练预约系统变得尤为…

国家超算互联网入选国家数据局“全国一体化算力网应用优秀案例”

在2024年8月29日举行的中国国际大数据产业博览会上&#xff0c;国家数据局公布了首批“全国一体化算力网应用优秀案例”。 这一举措是在经过严格的评审过程后&#xff0c;挑选了包括“国家超算互联网”在内的25个创新平台和方案&#xff0c;它们代表了当前算力网建设的先进与创…

【ssh】环境问题汇总

问题1.同时显示两个不同的 Conda 环境&#xff0c;如图 (base) 环境 是 Conda 安装后默认激活的环境。 (ani) 是手动创建的另一个 Conda 环境。 解决&#xff1a;执行conda deactivate。如果 (ani) 环境多次激活&#xff0c;需要多次执行 conda deactivate 才能回到 base 环境…

【论文分享】sNPU: Trusted Execution Environments on Integrated NPUs 24‘ISCA

目录 AbstractINTRODUCTIONBACKGROUND AND RELATED WORKTrusted Execution Environment (TEE)Neural Processing Unit (NPU)Integrated NPU v.s. Discrete NPU Multi-tasking Requirements for NPUsLow NPU utilization for a single ML workloadSimultaneous execution of bot…

jquery swiper插件的用法

一、Swiper插件简介 Swiper是一个纯JavaScript打造的滑动特效插件&#xff0c;面向手机、平板电脑等移动终端&#xff0c;同时也支持桌面浏览器。Swiper开源、免费、稳定、使用简单且功能强大&#xff0c;是架构移动终端网站的重要选择。 它支持触摸滑动、响应式设计、循环滑动…

基于Java+SpringBoot+Vue+MySQL的地方美食分享网站

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、SSM项目源码 系统展示 基于SpringBootVue的地方美食分享网站【附源码文档】、前后…

NXP i.MX8系列平台开发讲解 - 4.1.3 GPSD 使用

专栏文章目录传送门&#xff1a;返回专栏目录 Hi, 我是你们的老朋友&#xff0c;主要专注于嵌入式软件开发&#xff0c;有兴趣不要忘记点击关注【码思途远】 文章目录 关注星号公众号&#xff0c;不容错过精彩 作者&#xff1a;HywelStar 目录 1. 认识GPSD 2. 安装GPSD 2.…

哪些好用的待办事项清单值得推荐:待办任务清单app

在现代快节奏的生活中&#xff0c;我们每个人都面临着大量的待办事项。无论是工作中的紧急任务&#xff0c;还是生活中的琐碎事务&#xff0c;这些事情常常让我们感到应接不暇。为了更好地管理这些待办事项&#xff0c;将它们列成清单&#xff0c;并设置明确的完成时间节点&…