笨蛋学C++之 C++对数据库实现CRUD

2024-05-02 01:04
文章标签 c++ 实现 数据库 crud 笨蛋

本文主要是介绍笨蛋学C++之 C++对数据库实现CRUD,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

笨蛋学C++ 之 C++对数据库实现CRUD

  • 头文件
    • testcrud.h
  • 源文件
    • testcrud.cpp
    • main.cpp

头文件

testcrud.h

#pragma once
#include <mysql.h>
#include <iostream>
#include <vector>
#include <cstring> // 包含字符串操作相关的头文件
using namespace std;typedef struct Test {int id;string name;Test(){}// 添加一个构造函数Test(int id, string name){this->id = id;this->name = name;}
}Test;class testCrud{testCrud();~testCrud();
public://创建单例模式static testCrud* getInstance() {static testCrud instance; // 创建一个静态实例return &instance;        // 返回这个静态实例的地址}
public:bool test_insert(Test &test);bool test_update(Test& test);bool test_delete(Test& test);vector<Test> test_select(string condition = "");private:MYSQL* con;const char* host = "127.0.0.1";const char* user = "root";const char* password = "数据库密码";const char* database_name = "数据库名";const int port = 3306;
};

源文件

testcrud.cpp

#include <iostream>
#include "test-crud.h"
using namespace std;testCrud::testCrud() {// 设置链接con = mysql_init(NULL);// 设置编码mysql_options(con, MYSQL_SET_CHARSET_NAME, "GBK");// 声明链接if (!mysql_real_connect(con, host, user, password, database_name, port, NULL, 0)) {cerr << "Failed to connect to database Error: " << mysql_error(con) << endl;exit(1);}
}
testCrud::~testCrud() {//关闭连接mysql_close(con);}//插入
bool testCrud::test_insert(Test& test) {char sql[1024];sprintf_s(sql, sizeof(sql), "INSERT INTO test (id,name) VALUES (%d,'%s')", test.id, test.name.c_str());if (mysql_query(con, sql)) {cerr << "Failed to insert to database Error: " << mysql_error(con) << endl;return false;}return true;
}
//修改
bool testCrud::test_update(Test& test) {char sql[1024];sprintf_s(sql, sizeof(sql), "UPDATE test SET name = '%s' WHERE id = %d", test.name.c_str(),test.id);if (mysql_query(con, sql)) {cerr << "Failed to update to database Error: " << mysql_error(con) << endl;return false;}return true;
}
//删除
bool testCrud::test_delete(Test& test) {char sql[1024];sprintf_s(sql, sizeof(sql), "DELETE FROM test WHERE id = %d",test.id);if (mysql_query(con, sql)) {cerr << "Failed to delete to database Error: " << mysql_error(con) << endl;return false;}return true;
}
//查询
vector<Test> testCrud::test_select(string condition) {vector<Test> testList;char sql[1024];//若condition为空,查出所有的数据sprintf_s(sql, sizeof(sql), "SELECT * FROM test %s", condition.c_str());if (mysql_query(con, sql)) {cerr << "Failed to select to database Error: " << mysql_error(con) << endl;return {};}MYSQL_RES* res = mysql_store_result(con);MYSQL_ROW row;while ((row = mysql_fetch_row(res))) {Test test;test.id = atoi(row[0]);test.name = atoi(row[1]);testList.push_back(test);}return vector<Test>();
}

main.cpp

#include <mysql.h>
#include <iostream>
#include <cstring> // 包含字符串操作相关的头文件#include "test-crud.h"
using namespace std;int main(void) {Test test(4, "王九");testCrud::getInstance()->test_update(test); // 调用 update_test 方法return 0;
}

这篇关于笨蛋学C++之 C++对数据库实现CRUD的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Linux在线解压jar包的实现方式

《Linux在线解压jar包的实现方式》:本文主要介绍Linux在线解压jar包的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux在线解压jar包解压 jar包的步骤总结Linux在线解压jar包在 Centos 中解压 jar 包可以使用 u

c++ 类成员变量默认初始值的实现

《c++类成员变量默认初始值的实现》本文主要介绍了c++类成员变量默认初始值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录C++类成员变量初始化c++类的变量的初始化在C++中,如果使用类成员变量时未给定其初始值,那么它将被

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

C++中NULL与nullptr的区别小结

《C++中NULL与nullptr的区别小结》本文介绍了C++编程中NULL与nullptr的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编... 目录C++98空值——NULLC++11空值——nullptr区别对比示例 C++98空值——NUL

C++ Log4cpp跨平台日志库的使用小结

《C++Log4cpp跨平台日志库的使用小结》Log4cpp是c++类库,本文详细介绍了C++日志库log4cpp的使用方法,及设置日志输出格式和优先级,具有一定的参考价值,感兴趣的可以了解一下... 目录一、介绍1. log4cpp的日志方式2.设置日志输出的格式3. 设置日志的输出优先级二、Window

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

Python中将嵌套列表扁平化的多种实现方法

《Python中将嵌套列表扁平化的多种实现方法》在Python编程中,我们常常会遇到需要将嵌套列表(即列表中包含列表)转换为一个一维的扁平列表的需求,本文将给大家介绍了多种实现这一目标的方法,需要的朋... 目录python中将嵌套列表扁平化的方法技术背景实现步骤1. 使用嵌套列表推导式2. 使用itert