ubuntu20 编译安装alisql 5.6.23 [sql/CMakeFiles/sql.dir/build.make:962: sql/CMakeFiles/sql.dir/sql_acl.cc

在Ubuntu20上编译alisql 5.6.32时遇到错误,错误与C语言中的字符串和字符表示有关。'C'表示字符,而"C"则代表字符串的地址。问题出在使用单引号''的地方,改为双引号""后解决了问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ubuntu20 编译安装 alisql 5.6.32 报错:

/srv/mysql/src/sql/sql_acl.cc:3071:59: error: ISO C++ forbids comparison between pointer and integer [-fpermissive]
 3071 |     if (combo->plugin.str == NULL || combo->plugin.str == '\0')
      |                                                           ^~~~
make[2]: *** [sql/CMakeFiles/sql.dir/build.make:962: sql/CMakeFiles/sql.dir/sql_acl.cc.o] Error 1
make[1]: *** [CMakeFiles/Makefile2:5081: sql/CMakeFiles/sql.dir/all] Error 2
make: *** [Makefile:163: all] Error 2

C语言中 单引号和双引号的区别, "C" 表示的是一个字符串的收地址,'C' 表示的是一个字符;

此问题将 单引号的 '\0'  改成 双引号的 "\0"


# 我的mysql安装目录:/srv/mysql; 数据目录:/srv/data;
if [ -f /srv/mysql/src/sql/sql_acl.cc ];then
    # 取出 3071行的内容
    tem=`sed -n '3071p' /srv/mysql/src/sql/sql_acl.cc
### 重新编译 QT 的 MySQL 驱动程序 要在 Ubuntu 系统中重新编译 QT 的 MySQL 驱动程序,可以遵循以下方法: #### 准备工作 确保系统已安装必要的依赖项。这包括 MySQL 客户端开发库 `libmysqlclient-dev` 或者 MariaDB 开发库 `libmariadbclient-dev`[^2]。 运行以下命令来更新软件包并安装所需的工具和库: ```bash sudo apt-get update sudo apt-get install build-essential libmysqlclient-dev ``` 如果使用的是 MariaDB,则替换为: ```bash sudo apt-get install libmariadbclient-dev ``` #### 获取源码 进入 QT 源码目录中的插件部分。通常位于 `$QT_DIR/src/plugins/sqldrivers/` 中。如果没有完整的 QT 源码,可以从官网下载对应版本的源代码[^3]。 假设已经安装了 QT 并知道路径,执行如下操作: ```bash cd $QT_DIR/src/plugins/sqldrivers/ ``` #### 创建构建环境 创建一个新的临时目录用于构建驱动程序,并复制必要文件到该目录: ```bash mkdir /tmp/qt-mysql-build cd /tmp/qt-mysql-build $QT_DIR/bin/qmake "$QT_DIR/src/plugins/sqldrivers/" \ "INCLUDEPATH+=/usr/include/mysql" \ "LIBS+=-L/usr/lib/x86_64-linux-gnu/ -lmysqlclient" ``` 上述命令指定了 MySQL 头文件位置 `/usr/include/mysql` 和链接库位置 `/usr/lib/x86_64-linux-gnu/`[^5]。 #### 构建与安装 完成配置后,继续进行实际的编译过程: ```bash make sudo make install ``` 此步骤会生成 QMYSQL 插件并将它放置到适当的位置以便 QT 能够识别。 --- ### 常见问题处理 1. **找不到 `libmysqlclient.so`** 如果遇到缺少动态链接库的情况,可能是因为未正确安装客户端库或其路径不在默认搜索范围内。通过安装 `libmysqlclient-dev` 可以解决这个问题[^1]。 2. **qmake 报错** 当 qmake 找不到指定的头文件或库时,需确认 `INCLUDEPATH` 和 `LIBS` 参数设置无误。例如,某些系统可能会将库命名为 `-lmysqlclient_r`,此时应调整 LIBS 设置为匹配的实际名称。 --- ### 测试新驱动 为了验证新的 QMYSQL 驱动是否成功加载,在终端输入以下命令查看可用 SQL 驱动列表: ```bash $QT_DIR/bin/sqltest ``` 或者编写简单的测试应用程序尝试连接 MySQL 数据库。 ---
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值