要使用CMake編譯MySQL客戶(hù)端程序,首先確保已經(jīng)安裝了MySQL服務(wù)器和客戶(hù)端庫(kù)
創(chuàng)建一個(gè)新的文件夾,例如mysql_client_cmake
,并在其中創(chuàng)建兩個(gè)文件:CMakeLists.txt
和main.cpp
。
編輯CMakeLists.txt
文件,添加以下內(nèi)容:
cmake_minimum_required(VERSION 3.0)
project(mysql_client_cmake)
set(CMAKE_CXX_STANDARD 11)
# 添加MySQL客戶(hù)端庫(kù)
find_package(MySQL REQUIRED)
include_directories(${MYSQL_INCLUDE_DIRS})
add_executable(mysql_client main.cpp)
# 鏈接MySQL客戶(hù)端庫(kù)
target_link_libraries(mysql_client ${MYSQL_LIBRARIES})
main.cpp
文件,添加以下內(nèi)容:#include<iostream>
#include<mysqlx/xdevapi.h>
int main() {
const std::string url = "mysqlx://username:password@localhost";
try {
mysqlx::Session session(url);
mysqlx::Schema schema = session.getSchema("test");
mysqlx::Table table = schema.getTable("test_table");
// 插入數(shù)據(jù)
table.insert("name", "age")
.values("John Doe", 30)
.execute();
// 查詢(xún)數(shù)據(jù)
mysqlx::RowResult result = table.select().execute();
std::cout << "Rows in the table:"<< std::endl;
for (const auto &row : result) {
std::cout<< row[0].get<std::string>() << ", "<< row[1].get<int>()<< std::endl;
}
} catch (const std::exception &e) {
std::cerr << "Error: " << e.what()<< std::endl;
return 1;
}
return 0;
}
請(qǐng)將username
和password
替換為實(shí)際的MySQL用戶(hù)名和密碼。
mysql_client_cmake
文件夾,然后運(yùn)行以下命令:mkdir build
cd build
cmake ..
make
./mysql_client
這將連接到MySQL服務(wù)器,插入數(shù)據(jù)并查詢(xún)數(shù)據(jù)。請(qǐng)注意,這個(gè)示例使用了MySQL Connector/C++ 8.0的X DevAPI,因此需要MySQL 8.0或更高版本。如果你使用的是較舊的MySQL版本,可能需要使用不同的API。