Ubuntu编译MySQL驱动连接QT

1、安装MySQL

安装MySQL软件以及驱动。

复制代码
sudo apt-get install mysql-server

sudo apt install mysql-client

sudo apt-get install libmysqlclient-dev

2、编译qmysql驱动

2.1、修改mysql.pro

找到Qt源码中的mysql.pro项目文件,一般位于:/opt/Qt/5.15.2/Src/qtbase/src/plugins/sqldrivers/mysql文件夹下。

如果非root用户,则需要更改mysql文件夹所在目录的权限,以便修改文件内容。

可使用命令:

复制代码
sudo chmod -R 777 /opt/Qt/5.15.2/Src/qtbase/src/plugins/sqldrivers/

1)修改mysql.pro文件:

#注释这一行

#QMAKE_USE += mysql

2)修改qsqldriverbase.pri文件:

For QMAKE_USE in the parent projects.

#注释这一行

#include($$shadowed($$PWD)/qtsqldrivers-config.pri)

#添加这一行

include(./configure.pri)

2.2、编译

在mysql.pro文件夹中打开终端,执行命令:

复制代码
qmake "INCLUDEPATH+=/usr/include/mysql" "LIBS+=-L/usr/lib/ -lmysqlclient" mysql.pro
make
sudo make install

注:1)qmake前面不用sudo;2)如果qmake命令不能识别,设置Qt环境变量;3)确认INCLUDEPATH+和LIBS+目录是否正确;

在/opt/Qt/5.15.2/gcc_64/plugins/sqldrivers路径下可以看到libqsqlmysql.so库文件:

3、配置MySQL

3.1、查询用户信息

驱动编译好后,Qt软件还是不能连接数据库,显示:

MySQL数据库连接失败: "Access denied for user 'root'@'localhost' QMYSQL: Unable to connect"

这是因为一般出现这种情况多数是安装新版本mysql,root密码是随机的,也不是空密码,所以要通过查看随机密码进入,再进行修改原来的密码。

输入命令查询用户信息。

复制代码
sudo cat /etc/mysql/debian.cnf

显示如下:

输入命令:

复制代码
mysql -u debian-sys-maint -p

输入debian.cnf对应的用户密码登录进去,输入命令查看用户列表。

复制代码
use mysql;
select user,plugin from user;

3.2、修改root账户

修改root 账户密码格式。

复制代码
# 修改其密码格式
update user set plugin='mysql_native_password' where user='root'; 
# 查询其用户
select user,plugin from user; 
# 刷新权限
flush privileges;

3.3、更改root账户密码

修改root账户密码为:root。

复制代码
# 修改root账号密码
alter user 'root'@'localhost' identified by 'root';
# 在次刷新权限
flush privileges;
# 退出登录
exit

可以输入命令:mysql -u debian-sys-maint -p 再输入密码root登录进去了。

也可以使用MySQL Workbench界面登录。

将root账户的密码改为Qt程序中的连接密码:

复制代码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'xxxxxxxx';
#xxxxxxxx是你要更改的密码

使用QT也成功连接到数据库,打开了软件界面:

相关推荐
驱动探索者2 分钟前
影石Insta360发展史:从深圳公寓到全球影像创新标杆
linux
Wang's Blog11 分钟前
Linux小课堂: SSH 免密登录原理与实现之基于公钥认证的安全连接机制
linux·安全·ssh
戴草帽的大z35 分钟前
交叉编译FFmpeg:从x264到RK3588部署实战
linux·ffmpeg·rk3588·h.264·aarch64
qiuiuiu4131 小时前
正点原子RK3568学习日志19- Linux错误处理 字符驱动框架完全体
linux·服务器·学习·ubuntu
如果是君1 小时前
【git使用】ubuntu下利用git工具提交一个工程
linux·git·ubuntu
橘颂TA1 小时前
【Linux】 层层递进,抽丝剥茧:调度队列、命令行参数、环境变量
linux·运维·服务器·c/c++
X_szxj1 小时前
Volatility2在kali安装
linux·运维·服务器
像风一样!2 小时前
NFS文件存储
linux·服务器·网络·nfs文件存储
MOYIXIAOWEIWEI2 小时前
rocky 9.5系统安装zabbix监控实现邮件告警
ubuntu·zabbix·rocky
大聪明-PLUS2 小时前
Linux 中的 DNS 工作原理(一):从 getaddrinfo 到 resolv.conf
linux·嵌入式·arm·smarc