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也成功连接到数据库,打开了软件界面:

相关推荐
2301_7717172110 分钟前
解决mysql报错:1406, Data too long for column
android·数据库·mysql
绘梨衣54723 分钟前
Docker+FastAPI+MySQL 项目部署报错汇总
mysql·docker·fastapi
cui_ruicheng35 分钟前
Linux进程间通信(三):System V IPC与共享内存
linux·运维·服务器
dvjr cloi36 分钟前
MySQL Workbench菜单汉化为中文
android·数据库·mysql
蚰蜒螟1 小时前
深入 Linux 内核同步机制:从 futex 到 spinlock 的完整旅程
linux·windows·microsoft
运维全栈笔记1 小时前
Linux安装配置Tomcat保姆级教程:从部署到性能调优
linux·服务器·中间件·tomcat·apache·web
czlczl200209251 小时前
利用“延迟关联”优化 MySQL 巨量数据的深分页查询
数据库·mysql
dllmayday2 小时前
Linux 上用终端连接 WiFi
linux·服务器·windows
俺不要写代码3 小时前
数据库:函数
数据库·mysql
峥无3 小时前
Linux系统编程基石:静态库·动态库·ELF文件·进程地址空间全景图
linux·运维·服务器