c++使用mysqlclient库开发mysql

使用libmysqlclient库对mysql进行c++开发

安装

sudo apt update && sudo apt install libmysqlclient-dev -y

封装客户端

一般都是封装一个客户端类进行开发,如下的mysql.hpp:

#pragma once
#include <mysql/mysql.h>
#include <string>// mysql的客户端操作类
#pragma once
#include <mysql/mysql.h>
#include <string>
#include <ctime>// mysql的客户端操作类
class MySql {
public:MySql();                            // 初始化数据库连接资源~MySql();                           // 释放连接接资源bool connect(const std::string& ip, const uint16_t port, const std::string& user, const std::string& password, const std::string& dbname);                     // 连接数据库bool update(std::string sql);       // 更新(insert, delete, update都是这个接口)MYSQL_RES* query(std::string sql);  // 查询操作MYSQL* GetConnection();             // 获取连接void refreshAliveTime() { aliveTime_ = std::clock(); }            //每次进队列刷新时间std::clock_t GetAliveTime() { return std::clock() - aliveTime_; } //获取存活时间 ms
private:MYSQL* conn_;                       //一条连接std::clock_t aliveTime_;            //记录在队列后的存活时间(配合数据库连接池使用的)
};MySql::MySql() {conn_ = mysql_init(nullptr);
}MySql::~MySql() {if (conn_) {mysql_close(conn_);}
}bool MySql::connect(const std::string& ip, const uint16_t port, const std::string& user, const std::string& password, const std::string& dbname) {MYSQL* p = mysql_real_connect(conn_, ip.c_str(), user.c_str(), password.c_str(), dbname.c_str(), port, nullptr, 0);if (p) {// C和C++代码默认的编码字符是ASCII,如果不设置,从MySQL上拉下来的中文会乱码mysql_query(conn_, "set names gbk");} return p; //p若为空不就是false吗
}bool MySql::update(std::string sql) {return !mysql_query(conn_, sql.c_str());
}MYSQL_RES* MySql::query(std::string sql) {if (mysql_query(conn_, sql.c_str())) {return nullptr;}return mysql_use_result(conn_);/* 查询返回后一般这样操作   if (res) {MYSQL_ROW row;while (row = mysql_fetch_row(res)) {//赋值给res,且res不空//根据自己的表字段来获取数据std::cout << row[0] << std::endl;std::cout << row[1] << std::endl;std::cout << row[2] << std::endl;std::cout << row[3] << std::endl;}}mysql_free_result(res);*/
}
MYSQL* MySql::GetConnection() {return conn_;
}

使用示例

可参考https://github.com/1412771048/chatserver/tree/main

#include <iostream>
#include "mysql.hpp"int main() {MySQL mysql;if (!mysql.connect()) {return -1;}if (mysql.update("insert into user(id,name,age,sex) values(%d,'%s', %d,'%s')", 0, "zhang san", 18, "male")) {std::cout << "update success" << std::endl;}else {std::cout << "update failed" << std::endl;}auto res = mysql.query("select * from user");if (res) {MYSQL_ROW row;while (row = mysql_fetch_row(res)) {//赋值给res,且res不空//根据自己的表字段来获取数据std::cout << row[0] << std::endl;std::cout << row[1] << std::endl;std::cout << row[2] << std::endl;std::cout << row[3] << std::endl;}mysql_free_result(res);}else {std::cout << "query failed" << std::endl;}
}

编译:

g++ 1.cpp -lmysqlclient

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

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

相关文章

EPSON推出可定制晶振技术支持

什么叫做定制晶振呢?定制晶振又可以称为订制&#xff0c;订做晶振&#xff0c;爱普生可编程晶振可在0.67MHz~166MHz频率范围内实现任意频率烧录订制。定制频率晶振是基于PLL技术的一次频率烧录的振荡器&#xff0c;在没有温补的情况下也能够产生稳定的频率输出。单CMOS频率输出…

什么才是正确的领域驱动实现架构?

作为一种系统建模方法&#xff0c;DDD同样涉及系统的体系架构设计。区别于分布式、事件驱动、消息总线等架构设计方法&#xff0c;DDD中的架构设计关注前面各章所介绍的聚合、实体、值对象、领域事件、应用服务以及资源库之间的交互方式和风格&#xff0c;并在设计思想上有其独…

基于Go编写一个人员管理系统案例

代码结构 人员结构体 package entity// 结构体&#xff1a;人 type Person struct {Id intName stringSex stringAge int }// 构造函数 func NewPerson(id int, name, sex string, age int) *Person {return &Person{Id: id,Name: name,Sex: sex,Age: age,} }人员…

【AutoGPT】踩坑帖(follow李鱼皮)

本文写于2024年5月7日 参考视频&#xff1a;AutoGPT傻瓜式使用教程真实体验&#xff01; 对应文章&#xff1a;炸裂的AutoGPT&#xff0c;帮我做了个网站&#xff01; 平台&#xff1a;GitPod 云托管服务 原仓库已经改动很大&#xff0c;应使用的Repo为&#xff1a;Auto-GPT-ZH…

服务器拒绝登陆:Permission denied (publickey,password)

在账号密码正确的情况下&#xff0c;登陆服务器出现Permission denied (publickey,password)错误。 主要原因是shell软件&#xff08;比如zsh软件&#xff09;卸载后&#xff0c;主机的默认shell配置未改成可使用的shell软件&#xff08;比如系统默认的bash&#xff09; 通过…

人工智能将改变科研?从胰腺癌早筛到新药研发

去年底英国《自然》杂志刊文预测的2024年十大科学进展中&#xff0c;人工智能的进步和ChatGPT人工智能占据前两位。那么&#xff0c;人工智能对于科学而言&#xff0c;它的哪些成果将带来有益的发展&#xff1f;今天我们请知名科普作者张田勘来聊聊这个话题。 &#xff08;1&am…

互联网巨头新战场:百度高管抖音首秀背后的营销变革与争议浪潮

在这个流量为王的时代&#xff0c;每一次跨界尝试都可能成为行业瞩目的焦点。5月7日&#xff0c;中国互联网巨头百度的公关副总裁璩静&#xff0c;以其独特的姿态&#xff0c;踏入了短视频的风口浪尖——抖音平台。这一看似寻常的举动&#xff0c;实则在业界激起了千层浪&#…

C语言 | Leetcode C语言题解之第76题最小覆盖子串

题目&#xff1a; 题解&#xff1a; char* minWindow(char* s, char* t) {int tLen strlen(t);int hash[256] { 0 };for (int i 0; i < tLen; i)hash[t[i]];for (int i 0; i < 256; i) {if (0 hash[i])hash[i] INT_MIN;}int left, right, count, start, minLen, s…

VBA 创建透视表,录制宏,自动化报表

目录 一. 数据准备二. 需求三. 准备好报表模板四. 执行统计操作&#xff0c;录制宏4.1 根据数据源创建透视表4.2 填充数据到报表4.3 结束宏录制 五. 执行录制好的宏&#xff0c;自动化报表 一. 数据准备 ⏹数据源1 姓名学科成绩丁志敏语文91李平平语文81王刚语文64张伊语文50…

【C++数据结构】string的模拟实现

为了更好的使用C中的标准库&#xff0c;下面是对string一些比较重要的接口进行模拟实现&#xff0c;有需要借鉴即可。 这里给出string文档地址链接&#xff0c;方便对照&#xff1a;LINK 目录 1.string结构的设计2.string构造函数2.1构造函数分开写2.2构造函数一块写2.3拷贝构造…

再学Java基础——HashMap和Hashtable

HashMap和Hashtable在Java中都是用于存储键值对的数据结构&#xff0c;但它们之间存在一些重要的区别。以下是它们之间的主要差异&#xff1a; 线程安全性&#xff1a; Hashtable是线程安全的&#xff0c;它的每个方法&#xff08;如put和get&#xff09;都是同步的&#xff0…

城市运行管理服务平台架构

城市运行管理服务平台是一种集成化的信息系统&#xff0c;其根本宗旨在于推动城市的高效运作与精细管理&#xff0c;进而提升广大市民的生活质量&#xff0c;并致力于实现城市的长期、稳定与可持续发展。 一、平台架构 1、核心优势 2、7个应用系统 &#xff08;1&#xff09;…

C++聊天服务器数据库创建

创建数据库chat show databases&#xff1a;展示所有的数据库 create database chat&#xff1a;创建一个数据库chat use chat&#xff1a;使用数据库 创建表User、Friend、AllGroup、GroupUser、OfflineMessage 表User包含&#xff1a;用户id、用户名、用户密码、当前登录…

78.子集

1.题目 子集 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/subsets/ 2.思路 3.C代码实现 class Solution { public:vector<vector<int>> ret;vector<int> path;vector<vector<int>> subsets(vector<int>& …

详解Go语言Map

Map的声明 使用make()函数定义Map map_name : make(map[KeyType]valueType,initialCapacity)KeyType是键的类型&#xff0c;ValueType是值的类型&#xff0c;initialCapacity是可选参数&#xff0c;用于指定map的初始容量。 使用map关键字定义Map m : map[string]int {&quo…

MySQL: Buffer Pool概念整理

一. 简介 MySQL中的Buffer Pool是InnoDB存储引擎用来缓存表数据和索引的内存区域。这是InnoDB性能优化中最关键的部分之一。通过在内存中缓存这些数据&#xff0c;InnoDB可以极大减少对磁盘I/O的需求&#xff0c;因为从内存中读取数据远比从磁盘读取要快得多。因此&#xff0c…

项目管理在软件工程中的实践方法

软件工程是一个复杂的过程&#xff0c;涉及到需求分析、设计、编码、测试和维护等多个阶段。有效的项目管理对于确保软件项目成功至关重要。以下是结合附件内容&#xff0c;关于项目管理在软件工程中实践的一些方法。 1. 明确项目愿景和目标 在项目启动之初&#xff0c;项目经…

基于Seata实现分布式事务实现

Seata 是一个开源的分布式事务解决方案&#xff0c;它提供了高性能和简单易用的分布式事务服务。Seata 将事务的参与者分为 TC&#xff08;Transaction Coordinator&#xff09;、TM&#xff08;Transaction Manager&#xff09;和 RM&#xff08;Resource Manager&#xff09;…

在word中使用tab键对齐文本时,会删除光标所在文字

问题 在word中使用tab键对齐文本时&#xff0c;会删除光标所在文字。 原因 先按了insert键&#xff0c;输入模式改为改写模式。 解决办法 再按一次insert键&#xff0c;切换到插入模式。

淘宝电商商家ERP订单接口接入指南:对接ERP与淘宝系统的数据桥梁

最近几年&#xff0c;电商发展如火如荼&#xff0c;一方面互联网企业在推互联网 和O2O&#xff0c;同时很多传统企业也在积极互联网&#xff0c;通过各种电商平台拓展销售渠道&#xff0c;有些还同时建有自建的电商平台。这些电商平台通常下单&#xff0c;结算&#xff0c;促销…