使用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 --version
ldd (GNU libc) 2.17
Copyright (C) 2012 Free Software Foundation, Inc.
This is free software; see the source for copying conditions. There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
Written by Roland McGrath and Ulrich Drepper.
查看系統對應的OPENSSL??版本
[shark@sharkdb=>DelBigTable]$openssl version -a
OpenSSL 1.0.1e-fips 11 Feb 2013
built on: Tue Jun 17 17:23:54 UTC 2014
platform: linux-x86_64
options: 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_ASM
OPENSSLDIR: "/etc/pki/tls"
engines:??rdrand?dynamic
安裝BOOST開發庫
[root@sharkdb test_connect_mysql8]# yum install boost-devel
已加載插件:fastestmirror, langpacks
Loading 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_MYSQL
Cp –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.out
nohup 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
E3786A77EE4745719884FB6145701571
D61AE3215C1A432CA0406ED5DFCDDA68
D00A13194BD545C2BC3FEFA889BAFD02
D3FEC2C5E7994FFEADE2B4DBBC89EA8D
04C49E96CE034E61A6D53AC3EF6B6DE6
99ADE95D5F914A69AEAE7DC0B9B30344
C8F136D2F5BF4CA6AB6C244AB62DC351
C56A7CAC73AF48D4B7269D1A6082F1F6
F8C6D0E5E07642DD90F749E331C771FA
E4D2B686E92844A0BA3B8A3609605109
C3F7233062E447B08748E5A470BA1938
測試平臺移植
編譯只帶
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 openssl
openssl-devel-1.0.2k-26.el7_9.x86_64
openssl-libs-1.0.2k-26.el7_9.x86_64
openssl-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日志表數據完善篇