MYSQL C++鏈接接口編程

使用MYSQL 提供的C++接口來訪問數據庫,官網比較零碎,又不想全部精讀一下,百度CSDN都是亂七八糟的,大部分不可用

官網教程地址
https://dev.mysql.com/doc/connector-cpp/1.1/en/connector-cpp-examples-connecting.html

網上之所以亂七八糟,主要是MYSQL提供了3個接口兩個包,使用兩種語言交叉編程. 可以用GCC編輯C語言調用C++接口. 可以用C++語言調用C接口.

分別是C 接口, C++接口?MYSQLX接口. 三個接口兩個包.

C包和C++包,?C++包(Connector/C++)里面從官網下載,

而C包從MYSQL服務端包里摳出來.

C++包里面包含JDBC接口和MYSQLX, 怎么JDBC不是JAVA的應用接口嗎?
不知道為什么用這4個字母!?今天我們得用JDBC目錄下的C++接口

C接口文件?libmysqlclient.so,?libmysqlclient.a?分靜態和動態.從服務端解壓LIB獲得, 頭文件從INCLUDE獲得.

圖片

另外 開發包可以通過YUM來安裝

yum install –y libmysqlclient-dev
yum install –y libmysqlcppconn-dev

sudo?rpm?-ivh?mysql-connector-c++-devel-8.0.20-1.el7.x86_64.rpm?--nodeps?--force
sudo?rpm?-ivh?mysql-connector-c++-8.0.20-1.el7.x86_64.rpm?--nodeps?--force
sudo?rpm?-ivh?mysql-connector-c++-jdbc-8.0.20-1.el7.x86_64.rpm?--nodeps?--force
?

從官網下載

https://downloads.mysql.com/archives/community/

圖片

之所以選擇8.0.11 是基于 CENTOS7 環境. C++要求比較多 最煩的是OPENSSL的版本,還有GLIBC版本,以及BOOST版本, 太高了還對GCC版本有要求.?升級GCC版本?還得涉及CMAKE,MAKE版本涉及. 這就太扯了,我就是為了這點多巴胺快樂.要我付出那么多痛苦.?這時跟PYTHON沒啥區別. 還不如用GO簡單!

查看系統對應GLIBC?版本

[root@dsmart=>lib]$ldd --versionldd (GNU libc) 2.17Copyright (C) 2012 Free Software Foundation, Inc.This is free software; see the source for copying conditions.  There is NOwarranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.Written by Roland McGrath and Ulrich Drepper.

查看系統對應的OPENSSL??版本

[shark@sharkdb=>DelBigTable]$openssl version -aOpenSSL 1.0.1e-fips 11 Feb 2013built on: Tue Jun 17 17:23:54 UTC 2014platform: linux-x86_64options:  bn(64,64) md2(int) rc4(16x,int) des(idx,cisc,16,int) idea(int) blowfish(idx) compiler: gcc -fPIC -DOPENSSL_PIC -DZLIB -DOPENSSL_THREADS -D_REENTRANT -DDSO_DLFCN -DHAVE_DLFCN_H -DKRB5_MIT -m64 -DL_ENDIAN -DTERMIO -Wall -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches   -m64 -mtune=generic -Wa,--noexecstack -DPURIFY -DOPENSSL_IA32_SSE2 -DOPENSSL_BN_ASM_MONT -DOPENSSL_BN_ASM_MONT5 -DOPENSSL_BN_ASM_GF2m -DSHA1_ASM -DSHA256_ASM -DSHA512_ASM -DMD5_ASM -DAES_ASM -DVPAES_ASM -DBSAES_ASM -DWHIRLPOOL_ASM -DGHASH_ASMOPENSSLDIR: "/etc/pki/tls"engines:??rdrand?dynamic

安裝BOOST開發庫

[root@sharkdb test_connect_mysql8]# yum install boost-devel已加載插件:fastestmirror, langpacksLoading mirror speeds from cached hostfile * base: linux.mirrors.es.net * extras: centos-distro.1gservers.com * updates: opencolo.mm.fcix.net正在解決依賴關系--> 正在檢查事務---> 軟件包 boost-devel.x86_64.0.1.53.0-28.el7 將被 安裝--> 解決依賴關系完成

YUM 安裝開發庫

yum install –y libmysqlclient-dev  #C語言接口
yum?install?–y?libmysqlcppconn-dev?#C++語言接口

一般會安裝在這兩個目錄下

/usr/local/mysql/include/usr/local/mysql/lib

還需要向公共目錄安裝軟鏈接

ln?-s?/usr/local/mysql/libmysqlclient.so.18?/usr/lib/libmyqlclient.so

目錄不一定正確?可能是 /usr/lib64/mysql/lib...??==>/usr/sbin/lib/....

頭文件

安裝在系統目錄下 使用尖掛號<>

C語言頭文件

#include?<stdio.h>#include <mysql.h>

C++語言頭文件

#include <iostream>#include <mysql_connection.h>#include <mysql_driver.h>#include <cppconn/driver.h>#include <cppconn/resultset.h>#include <cppconn/statement.h>

因為我們通過從官網下載C++鏈接接口,所以不YUM 安裝了

進行解壓?tar –zxvf

圖片

解壓后進入兩到三級目錄查看

可以看到2個子目錄?分別是C++接口和分布式接口

庫目錄有3個庫文件,加密庫LIBCRYPTO.SO
,鏈接庫LIBMYSQLCPPONN.SO
LIBSSL.SO庫,靜態鏈接庫libmysqlcppconn-static.a

另外個MYSQLCPPONN8 忘記干啥子用的.沒關系反正不使用它

圖片

MYSQL C++接口應用?基礎需要3個動態鏈接庫就行了

把?INCLUDE?和LIB放入項目目錄下

cp  -r include/  /home/Project/CPP_MYSQLCp –r  lib64/ /home/Project/CPP_MYSQL

用VIM 編輯我們的代碼,這里我們用雙引號

#include?<iostream>
#include?"include/jdbc/mysql_connection.h"
#include?"include/jdbc/mysql_driver.h"
#include?"include/jdbc/cppconn/driver.h"
#include?"include/jdbc/cppconn/resultset.h"
#include?"include/jdbc/cppconn/statement.h"using?namespace?std;
using?namespace?sql;int?main()?
{try?{//?創建MySQL連接Driver*?driver?=?get_driver_instance();Connection*?con?=?driver->connect("tcp://192.168.0.62:3306",?"manjo_lts",?"tR9zWedofe@soeeJf");//?連接到test數據庫con->setSchema("lts");//?執行一條查詢語句Statement*?stmt?=?con->createStatement();ResultSet*?res?=?stmt->executeQuery("SELECT?*?FROM?lts_cron_job_queue");while?(res->next())?{cout?<<?res->getString("job_id")?<<?endl;}//?清理連接資源delete?res;delete?stmt;delete?con;}?catch?(SQLException&?e)?{cout?<<?"SQLException:?"?<<?e.getErrorCode()?<<?"?"?<<?e.what()?<<?endl;}return?0;
}??????????//?內存分配失敗?

編譯命令

[root@sharkdb test_connect_mysql8]# cat makeDebug rm -f nohup.outnohup g++ -g main.cpp -std=c++11 -I ./include  -L./lib64  -lmysqlcppconn  -lssl -lcrypto  -Wl,-rpath,'lib64' -o main.exe

編譯命令解釋:

-g?帶調試信息
-std=c++11??使用C++11標準?或者高版本std=c++17
-I?大寫i?表示頭文件從當前目錄找
-L?動態鏈接庫目錄
-l??哪個動態鏈接庫的文件名,?要掐頭取尾??mysqlcppconn??ssl?crypto
-Wl,-rpath,'lib64'?表示?運行過程中動態庫優先搜索目錄??本地子目錄lib64
-o?main.exe?輸出可執行文件

重點就是 WL,-RPATH?運行時候先從程序所在的目錄下找動態庫

運行OK

[root@sharkdb test_connect_mysql8]# ./main.exe E3786A77EE4745719884FB6145701571D61AE3215C1A432CA0406ED5DFCDDA68D00A13194BD545C2BC3FEFA889BAFD02D3FEC2C5E7994FFEADE2B4DBBC89EA8D04C49E96CE034E61A6D53AC3EF6B6DE699ADE95D5F914A69AEAE7DC0B9B30344C8F136D2F5BF4CA6AB6C244AB62DC351C56A7CAC73AF48D4B7269D1A6082F1F6F8C6D0E5E07642DD90F749E331C771FAE4D2B686E92844A0BA3B8A3609605109C3F7233062E447B08748E5A470BA1938

測試平臺移植

編譯只帶

 g++ -g main.cpp -std=c++11 -I ./include  -L./lib64  -lmysqlcppconn -Wl,-rpath,'lib64' -o main.exe

運行報丟失兩個動態庫

[root@dsmart=>CPP_MYSQL]$./main2.exe ./main2.exe: error while loading shared libraries: libssl.so.1.0.0: cannot open shared object file: No such file or directory[root@dsmart=>CPP_MYSQL]$./main2.exe ./main2.exe: error while loading shared libraries: libcrypto.so.1.0.0: cannot open shared object file: No such file or directory

把兩個移到LIB64目錄下.?注意軟鏈接不生效

運行就OK了

其它知識

OPENSSL版本

[root@dsmart=>mysql-]$openssl version
OpenSSL 1.0.2k-fips 26 Jan 2017

系統OPENSSL?安裝包

]$rpm -aq | grep opensslopenssl-devel-1.0.2k-26.el7_9.x86_64openssl-libs-1.0.2k-26.el7_9.x86_64openssl-1.0.2k-26.el7_9.x86_64

卸載

rpm -e openssl-1.0.2k --nodeps

安裝
基本很難找到RPM的

rpm -ivh openssl-1.1.1n-1.el7.x86_64.rpm --nodeps

二進制安裝模式

去官網下載1.1.1

https://www.openssl.org/source/old/1.1.1/index.html

2.?執行以下命令進行編譯和安裝:

./config
make
make test
sudo make install

基本編譯有錯誤. 我就沒有繼續折騰下去了

AI推薦的?MYSQLX接口用法, 本仙沒有測試通過!

#include?<iostream>
#include?<mysqlx/xdevapi.h>int?main()?{try?{mysqlx::Session?session("localhost",?3306,?"username",?"password",?"database");//?創建一個schemamysqlx::Schema?schema?=?session.getSchema("database",?true);//?創建一個表schema.createTable("table_name",?true,[](mysqlx::TableBuilder?&builder)?{builder.addColumn("id",?mysqlx::ColumnType::INT,?true).primaryKey();builder.addColumn("name",?mysqlx::ColumnType::STRING);});//?插入一行數據mysqlx::Table?table?=?schema.getTable("table_name");table.insert("name").values("Alice").execute();//?查詢數據mysqlx::RowResult?result?=?table.select("name").where("name?=?:name").bind("name",?"Alice").execute();for?(const?mysqlx::Row?&row?:?result)?{std::cout?<<?"Name:?"?<<?row[0]?<<?std::endl;}}?catch?(const?std::exception?&e)?{std::cerr?<<?"Error:?"?<<?e.what()?<<?std::endl;}return?0;
}
 
推薦閱讀

GCC 內聯匯編

用VSCODE 編輯編譯調試MYSQL8
用C去刪除MYSQL日志表數據完善篇

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/710953.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/710953.shtml
英文地址,請注明出處:http://en.pswp.cn/news/710953.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

C++ //練習 10.9 實現你自己的elimDups。測試你的程序,分別在讀取輸入后、調用unique后以及調用erase后打印vector的內容。

C Primer&#xff08;第5版&#xff09; 練習 10.9 練習 10.9 實現你自己的elimDups。測試你的程序&#xff0c;分別在讀取輸入后、調用unique后以及調用erase后打印vector的內容。 環境&#xff1a;Linux Ubuntu&#xff08;云服務器&#xff09; 工具&#xff1a;vim 代碼…

Flask g對象和插件

四、Flask進階 1. Flask插件 I. flask-caching 安裝 pip install flask-caching初始化 from flask_cache import Cache cache Cache(config(CACHE_TYPE:"simple" )) cache.init_app(appapp)使用 在視圖函數上添加緩存 blue.route("/") cache.cached(tim…

django5生產級部署和并發測試(開發者服務器和uvicorn服務器)

目錄 1. 創建django項目2. 安裝壓力測試工具3. 安裝生產級服務器uvicorn4. 多進程部署 1. 創建django項目 在桌面創建一個名為django_test的項目&#xff1a; django-admin startproject django_test然后使用cd命令進入django_test文件夾內&#xff0c;使用開發者服務器運行項…

前端架構: 腳手架包管理工具之lerna的全流程開發教程

Lerna 1 &#xff09;文檔 Lerna 文檔 https://www.npmjs.com/package/lernahttps://lerna.js.org [請直達這個鏈接] 使用 Lerna 幫助我們做包管理&#xff0c;并不復雜&#xff0c;中間常用的命令并不是很多這里是命令直達&#xff1a;https://lerna.js.org/docs/api-referen…

掌匯云 | FBIF個性化票務系統,展會活動數據好沉淀

“把票全賣光&#xff01;賣到一票難求&#xff0c;現場座無虛席。” 賣票人和買票人可能永遠不在一個頻道上。 2022年辦活動&#xff0c;就是一個字&#xff0c;搏&#xff01;和“黑天鵝”趕時間&#xff0c;能不能辦不由主辦方說了算。這種情況在2023年得到了改善&#xff…

【字典樹】【KMP】【C++算法】3045統計前后綴下標對 II

作者推薦 動態規劃的時間復雜度優化 本文涉及知識點 字符串 字典樹 KMP 前后綴 LeetCode:3045統計前后綴下標對 II 給你一個下標從 0 開始的字符串數組 words 。 定義一個 布爾 函數 isPrefixAndSuffix &#xff0c;它接受兩個字符串參數 str1 和 str2 &#xff1a; 當 st…

C++——內存管理(new和delete)詳解

目錄 C/C內存管理 案例&#xff1a;變量在內存中到底會在哪&#xff1f; New和delete Operator new和operator delete函數 New和delete的原理 對內置類型 對自定義類型 定位new New/delete和malloc/free的區別 C/C內存管理 C/C內存管理分布圖&#xff1a;&#xff08;從…

項目案例:圖像分類技術在直播電商中的應用與實踐

一、引言 在數字化浪潮的推動下&#xff0c;電商行業迎來了一場革命性的變革。直播電商&#xff0c;作為一種新興的購物模式&#xff0c;正以其獨特的互動性和娛樂性&#xff0c;重塑著消費者的購物習慣。通過實時的直播展示&#xff0c;商品的細節得以清晰呈現&#xff0c;而互…

matlab:涉及復雜函數圖像的交點求解

matlab&#xff1a;涉及復雜函數圖像的交點求解 在MATLAB中求解兩個圖像的交點是一個常見的需求。本文將通過一個示例&#xff0c;展示如何求解兩個圖像的交點&#xff0c;并提供相應的MATLAB代碼。 畫出圖像 首先&#xff0c;我們需要繪制兩個圖像&#xff0c;以便直觀地看…

【JavaEE】_HttpServletResponse類

目錄 1. 核心方法 2. 關于setStatus(400)與sendError 2.1 setStatus(400) 2.2 sendError 3. setHeader方法 4. 構造重定向響應 4.1 使用setHeader和setStatus實現重定向 4.2 使用sendRedirect實現重定向 本專欄已有文章介紹HttpServlet和HttpServletRequest類&#…

仿真科普|CAE技術賦能無人機 低空經濟蓄勢起飛

喝一杯無人機送來的現磨熱咖啡&#xff1b;在擁堵的早高峰打個“空中的士”上班&#xff1b;乘坐水陸兩棲飛機來一場“陸海空”立體式觀光……曾經只出現在科幻片里的5D城市魔幻場景&#xff0c;正逐漸走進現實。而推動上述場景實現的&#xff0c;就是近年來越來越熱的“低空經…

前端開發——ElementUI組件的使用

文章目錄 1. Tabs標簽頁2. 單選框 el-radio3. 復選框 el-checkbox4. 下拉框 el-select5. 表格 el-table6. 對話框 el-dialog7. 文字提示 el-tooltip8. 抽屜 el-drawer 1. Tabs標簽頁 <template><el-tabs v-model"activeName" tab-click"handleClick&q…

python學生成績管理系統(期末課程作業)

功能介紹 平臺采用B/S結構&#xff0c;后端采用主流的Python語言進行開發&#xff0c;前端采用主流的Vue.js進行開發。本學期的期末作業。開發了1周 功能包括&#xff1a;成績管理、學生管理、課程管理、班級管理、用戶管理、日志管理、系統信息模塊。 源碼地址 https://gi…

c語言求簡單交錯序列前N項和

本題要求編寫程序,計算序列 1 - 1/4 1/7 - 1/10 ... 的前N項之和。 輸入格式: 輸入在一行中給出一個正整數N。 輸出格式: 在一行中按照“sum S”的格式輸出部分和的值S&#xff0c;精確到小數點后三位。題目保證計算結果不超過雙精度范圍。 輸入樣例: 10輸出樣例: su…

如何實現WordPress后臺顯示文章、分類目錄、標簽等的ID?

我們平時在使用WordPress的過程中&#xff0c;偶爾需要用到文章的ID&#xff0c;或分類目錄ID&#xff0c;或標簽ID&#xff0c;或媒體庫ID&#xff0c;或評論ID&#xff0c;或用戶ID等&#xff0c;但是WordPress后臺默認是不顯示它們的ID的。 今天boke112百科就跟大家分享如何…

聚觀早報 | 愛奇藝2023年Q4財報;蘋果將加大AI投入

聚觀早報每日整理最值得關注的行業重點事件&#xff0c;幫助大家及時了解最新行業動態&#xff0c;每日讀報&#xff0c;就讀聚觀365資訊簡報。 整理丨Cutie 3月1日消息 愛奇藝2023年Q4財報 蘋果將加大AI投入 意大利正與多家車企談判 多家企業與百度達成合作 比亞迪宋PL…

Cesium 視頻貼圖

一、創作靈感 a、在cesium中視頻或者圖像在矩形或者圓形中顯示 b、在不使用entity模式下,使用Primitive進行視頻或者圖像渲染 c、在使用Primitive的前提下,需要進行視頻或者圖像貼地 d、不貼地,請跳轉到我的另外一份日志紋理貼圖 二、創建步驟 1、創建圓形或者矩形 創建圓…

SpringBoot集成接口重試Retry

SpringBoot集成接口重試Retry 前言 在實際的應用中&#xff0c;我們經常需要調用第三方API來獲取數據或執行某些操作。然而&#xff0c;由于網絡不穩定、第三方服務異常等原因&#xff0c;API調用可能會失敗。為了提高系統的穩定性和可靠性&#xff0c;我們通常會考慮實現重試…

SDR架構 (一)為什么基帶有I和Q路?

我之前做過自己的RTL-SDR。一直有一個疑惑。為啥rtl2832u芯片有一對差分I路&#xff0c;還有一對差分Q路。差分很好理解是為了抗干擾&#xff0c;但為啥要I和Q呢&#xff1f;并且我也知道不少人在自己修改的時候&#xff0c;保留I路對接在r820t2&#xff08;跟原版一樣&#xf…

整數與IP地址間的轉換(牛客網算法/Javascript Node)

描述 原理&#xff1a;ip地址的每段可以看成是一個0-255的整數&#xff0c;把每段拆分成一個二進制形式組合起來&#xff0c;然后把這個二進制數轉變成 一個長整數。 舉例&#xff1a;一個ip地址為10.0.3.193 每段數字 相對應的二進制數 10 00001010 0 00000000 3 00000011 193…