mysql connector c++ libmysqlcppconn8 使用的坑记录

在 CMakeList.txt 中引用 libmysqlcppconn8 之后编译报错 :

CMakeFiles/omas.dir/src/db/db_operator.cpp.o: In function `mysqlx::abi2::r0::string::traits<char>::from_str(mysqlx::abi2::r0::string&, std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > const&)':
/usr/local/include/mysqlx/devapi/common.h:220: undefined reference to `mysqlx::abi2::r0::string::Impl::from_utf8(mysqlx::abi2::r0::string&, std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > const&)'
CMakeFiles/omas.dir/src/db/db_operator.cpp.o: In function `mysqlx::abi2::r0::string::traits<char>::to_str[abi:cxx11](mysqlx::abi2::r0::string const&)':
/usr/local/include/mysqlx/devapi/common.h:225: undefined reference to `mysqlx::abi2::r0::string::Impl::to_utf8[abi:cxx11](mysqlx::abi2::r0::string const&)'
CMakeFiles/omas.dir/src/db/db_operator.cpp.o: In function `mysqlx::abi2::r0::SessionSettings::SessionSettings(mysqlx::abi2::r0::string const&)':
/usr/local/include/mysqlx/devapi/settings.h:524: undefined reference to `mysqlx::abi2::r0::common::Settings_impl::set_from_uri(std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > const&)'
collect2: error: ld returned 1 exit status
make[2]: *** [CMakeFiles/omas.dir/build.make:149: omas] Error 1
make[1]: *** [CMakeFiles/Makefile2:73: CMakeFiles/omas.dir/all] Error 2
make: *** [Makefile:84: all] Error 2

解决方法:
在 CMakeLists.txt 中加上

add_definitions(-D_GLIBCXX_USE_CXX11_ABI=0)

解决方法来自: https://stackoverflow.com/questions/54022842/connecting-c-to-mysql-using-mysql-c-connector-8/54040470#54040470 , 这上面原因解释的也很清楚,这里只做记录。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
是的,可以直接在 Qt 中使用 MySQL Connector/C++ 来连接和操作 MySQL 数据库。MySQL Connector/C++ 是官方提供的一个 C++ 接口,用于在 C++ 程序中与 MySQL 数据库进行交互。要在 Qt 中使用 MySQL Connector/C++,你需要按照以下步骤进行设置: 1. 下载和安装 MySQL Connector/C++:你可以从 MySQL 官网上下载适合你系统的 MySQL Connector/C++ 版本,并按照安装指南进行安装。 2. 在 Qt 项目中添加 MySQL Connector/C++ 的头文件路径和库文件路径:在 Qt 项目的 .pro 文件中添加以下行,将 MySQL Connector/C++ 的头文件路径和库文件路径添加到项目中: ``` INCLUDEPATH += /path/to/mysql-connector-c++/include LIBS += -L/path/to/mysql-connector-c++/lib -lmysqlcppconn ``` 请将 "/path/to/mysql-connector-c++" 替换为你自己的 MySQL Connector/C++ 安装路径。 3. 在 Qt 项目中包含 MySQL Connector/C++ 的头文件:在需要使用 MySQL Connector/C++ 的源文件中,添加如下的 include 语句: ``` #include <mysql_driver.h> #include <mysql_connection.h> ``` 4. 使用 MySQL Connector/C++ 连接和操作 MySQL 数据库:你可以使用 MySQL Connector/C++ 提供的类和方法来连接和操作 MySQL 数据库。例如,可以使用 `sql::mysql::MySQL_Driver` 类来创建一个 MySQL 连接对象,并使用该对象执行 SQL 查询和更新操作。 注意:在使用 MySQL Connector/C++ 连接数据库之前,确保已经启动了 MySQL 服务器,并且已经创建了相应的数据库和表。 这些是使用 MySQL Connector/C++ 在 Qt 中连接和操作 MySQL 数据库的基本步骤。你可以根据具体的需求进一步深入学习和使用 MySQL Connector/C++ 的功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值