- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
介绍
我决定使用 mysql 作为项目的一部分来自学 C++,所以让我为缺乏知识提前道歉。链接、动态和静态库的概念对我来说还是很新的。有了这个,让我们继续吧。
我正在尝试从 C++ 查询 mysql 服务器。理想情况下,我希望最终产品能够在任何架构上运行,并且尽可能少地依赖库。我不希望我的代码的用户必须自己安装任何库(即连接器/C++)。我也想使用 cmake 来编译我的项目。
准备
为了做到这一点,我使用二进制文件
cmake_minimum_required(VERSION 3.1)
project(SQL VERSION 0.1.0)
# enable c++17
set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED True)
set(MYSQL_DIR "/usr/local/mysql-connector-c++-8.0.19")
find_package(Threads REQUIRED)
find_package(Boost REQUIRED)
add_executable(${PROJECT_NAME} main.cpp)
target_include_directories(
${PROJECT_NAME}
PUBLIC
${MYSQL_DIR}/include
${Boost_INCLUDE_DIRS}
)
find_library(SSL_LIB NAMES ssl PATHS ${MYSQL_DIR}/lib64 NO_DEFAULT_PATH)
find_library(CRYPTO_LIB NAMES crypto PATHS ${MYSQL_DIR}/lib64 NO_DEFAULT_PATH)
find_library(MYSQL_LIBS NAMES mysqlcppconn PATHS ${MYSQL_DIR}/lib64)
target_link_libraries(${PROJECT_NAME} ${MYSQL_LIBS} ${SSL_LIB} ${CRYPTO_LIB} Threads::Threads)
#define STATIC_CONCPP
#include <mysql/jdbc.h>
#include <iostream>
#include <vector>
#include <stdexcept>
int main(){
std::cout << "Connector/C++ standalone program example..." << '\n';
sql::Connection *con;
sql::Statement *stmt;
sql::mysql::MySQL_Driver * driver = sql::mysql::get_driver_instance();
con = driver->connect(URI, USER, PASS);
con->setSchema(EXAMPLE_DB);
stmt = con->createStatement();
sql::ResultSet *res = stmt->executeQuery("SELECT * FROM TICKERS");
std::cout << "\t... running " << "SELECT * FROM TICKERS" << "..." <<'\n';
sql::ResultSetMetaData *mtd = res->getMetaData();
while (res->next()){
std::cout << res->getString(1) <<'\t' <<res->getString(2) << '\n';
}
}
cmake ..; cmake --build .
建立我的项目。
Scanning dependencies of target SQL
[ 50%] Building CXX object CMakeFiles/SQL.dir/main.cpp.o
[100%] Linking CXX executable SQL
[100%] Built target SQL
dyld: Library not loaded: libssl.1.1.dylib
Referenced from: /Users/paperino/dev/cpp/learn/mysql/build/./SQL
Reason: image not found
Abort trap: 6
/usr/local/mysql-connector-c++-8.0.19/lib64
复制 libssl 和 libcrypto到我的构建文件夹然后我是
能跑可执行文件。为什么这是必要的,即使我已经使用
find_library
指定了 ssl 和加密库的路径?
It is possible to link your application with the Connector/C++ static library. This way there is no runtime dependency on the connector, and the resulting binary can run on systems where Connector/C++ is not installed.
find_library(MYSQL_LIBS NAMES mysqlcppconn-static PATHS ${MYSQL_DIR}/lib64)
Scanning dependencies of target SQL
[ 50%] Building CXX object CMakeFiles/SQL.dir/main.cpp.o
[100%] Linking CXX executable SQL
Undefined symbols for architecture x86_64:
"_res_9_dn_expand", referenced from:
sql::mysql::srv_list(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, unsigned short&) in libmysqlcppconn-static.a(mysql_connection.cpp.o)
"_res_9_nclose", referenced from:
sql::mysql::srv_list(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, unsigned short&) in libmysqlcppconn-static.a(mysql_connection.cpp.o)
"_res_9_ninit", referenced from:
sql::mysql::srv_list(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, unsigned short&) in libmysqlcppconn-static.a(mysql_connection.cpp.o)
"_res_9_ns_initparse", referenced from:
sql::mysql::srv_list(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, unsigned short&) in libmysqlcppconn-static.a(mysql_connection.cpp.o)
"_res_9_ns_parserr", referenced from:
sql::mysql::srv_list(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, unsigned short&) in libmysqlcppconn-static.a(mysql_connection.cpp.o)
"_res_9_nsearch", referenced from:
sql::mysql::srv_list(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, unsigned short&) in libmysqlcppconn-static.a(mysql_connection.cpp.o)
ld: symbol(s) not found for architecture x86_64
clang: error: linker command failed with exit code 1 (use -v to see invocation)
make[2]: *** [SQL] Error 1
make[1]: *** [CMakeFiles/SQL.dir/all] Error 2
make: *** [all] Error 2
最佳答案
至于 _res_9_dn_expand 和相关的错误,您还需要与“resolv”库链接。将“-lresolv”添加到链接器命令行。在阅读其余部分之前尝试一下。
正如您正确指出的那样,如果您想构建您的应用程序以便不需要额外的文件,您必须链接到 MySQL 的静态库以及 MySQL 所需的所有静态库。要正确链接,您将需要使用用于构建 MySQL 库的相同 OpenSSL 库。
有两条路可以走。要么获取 MySQL 用于构建其现成库的相同版本的 OpenSSL 静态库,要么使用您拥有的 OpenSSL 版本再次编译 MySQL 库。
只是为了增加更多困惑,我上次这样做时 MySQL C++ 连接器依赖于 MySQL 运行时“C”库。我相信这就是 OpenSSL 发挥作用的地方。因此,如果您走“重新编译所有内容”的路线,您可能需要重新编译的不仅仅是 C++ 连接器。
关于c++ - 在 MacOS Catalina 上使用 CMake 编译/链接 mysql-connector-c++,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60749953/
运行 pip install cmake 时出现上述错误在 alpine linux (WSL) 上。 完整错误: /home/user# pip install cmake Collecting c
我的项目依赖 mariadb-connector-c我正在尝试使用 cmake 自动化下载、构建和链接过程。 我目前将项目下载到一个目录中,然后尝试执行生成忍者文件并运行它们,但我根本无法运行 cma
我正在尝试像这样在 cmake 中执行 execute_process execute_process(COMMAND ${CMAKE_COMMAND} -P myScript.cmake 这仅在文件
我想知道如果我没有给它任何变量告诉它在哪里找到它,cmake 如何找到我的 llvm cmake 配置。 我是 LLVM 新手。我正在构建一个 Hello World LLVM pass。我在 Ubu
我正在开发一个使用 CMake 的项目。顶CMakeLists.txt文件包含以下行: cmake_minimum_required(VERSION 3.7.2) # Kittens will die
我正在使用 Meego 1.2 工具链使用 cmake 运行构建(长话短说)。这个特定的工具链需要使用 --sysroot 选项来查找它需要的任何库。 set (CMAKE_CXX_FLAGS "-f
我们有一些源代码处理工具,可以从多个“片段”生成原始汇编文件等内容。 当使用 make 中的这些工具时,我们可以通过让源处理工具发出“依赖文件”来确保最新的构建,就像 gcc 一样-MD 标志。 例如
如何在 MSYS2 中安装和配置“cmake”?我尝试安装以下 MSYS 包 我在运行任何 cmake 命令时都收到以下错误 '''CMakeLists.txt:5 (cmake_minimum_re
有没有办法在 CMake 中得到一个变量列表?具体来说,我想要做的是调用一个现有函数,该函数接受多个变量并检查它们的计算结果是否为 true。 在某些情况下,其中一些变量将是空列表(计算结果为 fal
我有两组测试(功能测试和单元测试),我希望能够指定通过 cmake 运行哪一组。 一组测试是我想通过“make test”运行的单元测试。 另一组测试是我想通过“制作功能测试”来运行的功能测试。 目前
我的目标是查看有关调用 g++ 的详细信息由 cmake 直接调用从命令行。我不关心 make 的输出就这个问题而言。 根据official FAQ和 the accepted answer on a
我有一个生成库的CMake项目。我已经编写了一个CMake脚本FindXXX.cmake来帮助我的图书馆的用户。这样,他们可以使用find_package(XXX)并获取所需的变量。到现在为止还挺好。
当我看到带有命名空间的 CMake 库时,它们总是在表单中Parent::Component . 如果我有一个足够大的库,那么该库的子部分可能包含组件。我想知道是否可以/适合做 ParentProje
CMake 变量和属性似乎完成了非常相似的事情,我一直无法理解它们之间的区别。 它们每个都有自己的文档部分,但两者都会影响构建系统,两者都是“预先存在的”,并且两者都可以基于其他 CMake 命令动态
我有一个包含多个子目录的 CMake 项目,例如: dir1 subdir11 subdir12 dir2 subdir21 subdir22 根 CMakeLists
如果您想将静态库链接到共享库或可执行文件,同时保持所有符号可见(例如,您可以稍后打开它以找到它们),在 Linux/BSD 上执行此操作的一种非可移植方式是使用标志-Wl,--whole-archiv
CMake 自动创建一个 FooTarget.cmake文件例如添加 install(EXPORT FooTargets FILE FooTargets.cmake NAMESPACE Foo
在CMake中,ELSE和ENDIF控制流函数将表达式作为参数。根据文档,这些是optional。那么这些目的是什么?仅仅是为了维护目的而使原始IF表达式更清晰,还是提供某些功能? 最佳答案 正如您所
我是 cmake 的新手,我发现它非常令人沮丧。我试图在构建运行时评估的文件路径中使用通配符,而不是在生成构建时。 我创建了一个构建,它使用 SWIG 为某些 C++ 代码生成 Java 包装器。我可
我可能在谷歌上搜索错误,但我无法找到 .cmake 文件的用途。 我刚刚偶然发现了一个我必须使用的项目的 CMake 工具,我很难理解它是如何工作的。我明白在包含 CMakeLists.txt 的目录
我是一名优秀的程序员,十分优秀!