章节10实验--Ubuntu18.04 Qt MySQL libqsqlmysql.so

news2024/9/20 16:32:56

  前言:

内容参考《操作系统实践-基于Linux应用与内核编程》一书的示例代码和教材内容,所做的读书笔记。本文记录再这里按照书中示例做一遍代码编程实践加深对操作系统的理解。

引用:

《操作系统实践-基于Linux应用与内核编程》

作者:房胜、李旭健、黄玲、李哲

出版社:清华大学出版社

资源:

 教材资源

链接: https://caiyun.139.com/m/i?1A5Ch36dl1whD  提取码:jdQe

课件和电子资料源码

链接: https://caiyun.139.com/m/i?1A5CvEKY07Uzs  提取码:xyv0

参考链接:

QT mysql 配置 编译libqsqlmysql.so ubuntu-CSDN博客

QT-5.12: QSqlDatabase: QMYSQL driver not loaded 错误及解决方案-CSDN博客

正文:

1. 我的环境:

VirtualBox + Ubuntu18.04 Linux 桌面版 + Qt5.14.2 + MySQL

2. Qt聊天程序编译执行

2.1 执行提示Qt SQL驱动不支持MySQL

《操作系统实践-基于Linux应用与内核编程》第10章--实验 Qt聊天程序-CSDN博客

在按照《操作系统实践-基于Linux应用于内核编程》第10章-实验 Qt聊天程序,这一节博文中对照着电子资源提供的“QChatServer”的源码,动手把示例聊天程序"QChatSerer" 写到Ubuntu18.04 Qt5.14.2 版本的Qt Creator编辑器中。

编译执行"QChatSerer"的源码,在聊天服务器Qt程序连接MySQL数据的时候,Qt程序连接MySQl数据库失败,并提示错误。

QSqlQuery::prepare: database not open
QSqlQuery::exec: database not open
QSqlDatabase: QMYSQL driver not loaded
QSqlDatabase: available drivers: QSQLITE QODBC QODBC3 QPSQL QPSQL7

从Qt应用程序的错误输出提示来看,Qt程序连接 MySQL 数据的原因是应为当前没有加载 Qt mysql 驱动,当前我们的Ubuntu18.04 Linux Qt支持的 mysql驱动有“QSQLITE QODBC QODBC3 QPSQL QPSQL7”等,却没有没有 MySQL的驱动。

Qt sql驱动没有支持的MySQL数据库的原因是:

Qt SQL模块已默认不编译mysql驱动,导致mysql驱动缺失,错误提示如下(可用数数据库驱动不含mysql驱动,执行方法一和二);

QSqlDatabase: QMYSQL driver not loaded
QSqlDatabase: available drivers: QSQLITE QODBC QODBC3 QPSQL QPSQL7

2.2 编译Qt libqsqlmysql.so 库

参考引用链接博文里的步骤,在Ubuntu18.04 Linux 虚拟机上编译 Qt libqsqlmysql.so 库。

进入Qt5.14.2安装目录下面的 '5.14.2/Src/qtbase/src/plugins/sqldrivers/mysql' 子目录

cd 5.14.2/Src/qtbase/src/plugins/sqldrivers/mysql

编辑 mysql.pro 文件,注释掉文件中的 ' #QMAKE_USE += mysql '

#QMAKE_USE += mysql

在文件加上如下路径名(把路径名替换成自己的路径名)

INCLUDEPATH+=/usr/include/mysql
LIBS+=-L/usr/lib/x86_64-linux-gnu/ -lmysqlclient

可以通过如下命令‘ mysql_config --cflags --libs ’获取到自己的路径名

~$ mysql_config --cflags --libs
-I/usr/include/mysql 
-L/usr/lib/x86_64-linux-gnu -lmysqlclient -lpthread -lm -lrt -latomic -lssl -lcrypto -ldl
~$

注意:我在修改mysql.pro文件时不小心出现了如下错误,在你修正这个文件时请注意避免。

###错误,不小心在 ‘INCLUDEPATH+=’后面,多加了'-I'两个字符。

#INCLUDEPATH+=-I/usr/include/mysql  (错误)
LIBS+=-L/usr/lib/x86_64-linux-gnu/ -lmysqlclient


###正确的写法是,INCLUDEPATH+=’后面直接接路径,不加'-I'。

INCLUDEPATH+=/usr/include/mysql
LIBS+=-L/usr/lib/x86_64-linux-gnu/ -lmysqlclient

执行 ' qmake mysql.pro '  命令,进行编译。如果提示如下错误,说明 'qmake'还没有安装,执行 apt 命令安装 qtmake。

Command 'qmake' not found, but can be installed with:

sudo apt install qtchooser

提示执行 ' sudo apt install qtchooser ' 安装qmake。这里我们不需要安装'qtchooser',我们使用Qt5.14.2安装目录里的qmake。

sudo apt install qtchooser

使用‘ find -name qmake ’命令找到Qt5.14.2 安装目录里的qmake

dimon@dimon-VirtualBox:~/Qt5.14.2$ find -name qmake
./Examples/Qt-5.14.2/qmake
./Tools/QtCreator/share/qtcreator/templates/wizards/projects/qmake
./Docs/Qt-5.14.2/qmake
./5.14.2/Src/qtbase/tests/auto/tools/qmake
./5.14.2/Src/qtbase/qmake
./5.14.2/Src/qtbase/qmake/doc/snippets/qmake
./5.14.2/Src/qtbase/examples/qmake
./5.14.2/gcc_64/bin/qmake
dimon@dimon-VirtualBox:~/Qt5.14.2$ 

从输出看到在我的当前环境配置里 ' ./5.14.2/gcc_64/bin/qmake ' ,Qt5.14.2 安装的qmake的路径。执行 ' ./5.14.2/gcc_64/bin/qmake -v '查看下 qmake的版本信息

dimon@dimon-VirtualBox:~/Qt5.14.2$ ./5.14.2/gcc_64/bin/qmake -v
QMake version 3.1
Using Qt version 5.14.2 in /home/dimon/Qt5.14.2/5.14.2/gcc_64/lib
dimon@dimon-VirtualBox:~/Qt5.14.2$

使用qamake完整路径执行 ‘ /home/dimon/Qt5.14.2/5.14.2/gcc_64/bin/qmake mysql.pro ’ 命令(把路径名替换成你自己环境里的路径名)。如果提醒如下错误:

~$ /home/dimon/Qt5.14.2/5.14.2/gcc_64/bin/qmake mysql.pro
Cannot read /home/dimon/Qt5.14.2/5.14.2/Src/qtbase/src/plugins/sqldrivers/qtsqldrivers-config.pri: No such file or directory

~$

错误提醒我们找不到文件' 5.14.2/Src/qtbase/src/plugins/sqldrivers/qtsqldrivers-config.pri  '。进入上一级目录' 5.14.2/Src/qtbase/src/plugins/sqldrivers ',

dimon@dimon-VirtualBox:~/Qt5.14.2/5.14.2/Src/qtbase/src/plugins/sqldrivers$ grep qtsqldrivers-config.pri ./* -n
grep: ./db2: Is a directory
grep: ./ibase: Is a directory
grep: ./lib: Is a directory
grep: ./mkspecs: Is a directory
grep: ./mysql: Is a directory
grep: ./oci: Is a directory
grep: ./odbc: Is a directory
grep: ./plugins: Is a directory
grep: ./psql: Is a directory
./qsqldriverbase.pri:4:include($$shadowed($$PWD)/qtsqldrivers-config.pri)
grep: ./sqlite: Is a directory
grep: ./sqlite2: Is a directory
grep: ./tds: Is a directory
dimon@dimon-VirtualBox:~/Qt5.14.2/5.14.2/Src/qtbase/src/plugins/sqldrivers$

修改文件 ‘ ./qsqldriverbase.pri ’ 注释掉 如下一句。 

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

再次执行' qmake mysql.pro' ,命令执行成功并生成 Makefile

qmake mysql.pro

 执行 ' make ',进行编译,编译成功

make

执行 ' make install ',进行安装,安装成功。

make install

2.3 Qt应用程序连接MySQL数据库成功

通过上面的步骤成功在 Ubuntu18.04 Linux 虚拟机上编译 Qt5.14.2 的MySQL数据库连接驱动后,再次执行我们的QChartServer聊天程序,已经可以正确连接系统上的MySQL数据库了。

3. 问下百度AI这个问题

问题已经解决完了,我们测试下最近的正能AI编程服务工具,看下正能AI能不能在解决这类问题时,给我们一些灵感。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1532759.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

软考高级:结构化需求分析概念和例题

作者:明明如月学长, CSDN 博客专家,大厂高级 Java 工程师,《性能优化方法论》作者、《解锁大厂思维:剖析《阿里巴巴Java开发手册》》、《再学经典:《Effective Java》独家解析》专栏作者。 热门文章推荐&am…

通过jsDelivr实现Github的图床CDN加速

最近小伙伴们是否发现访问我的个人博客http://xiejava.ishareread.com/图片显示特别快了? 我的博客的图片是放在github上的,众所周知的原因,github访问不是很快,尤其是hexo博客用github做图床经常图片刷不出来。一直想换图床&…

构建一个前端智能停车可视化系统

引言 随着城市化进程的加速,停车难问题日益突出。智能停车可视化系统通过实时展示停车场的车位信息,帮助用户快速找到空闲车位,提高停车效率。 目录 引言 一、系统设计 二、代码实现 1. 环境准备 2. 安装依赖 3. 创建停车场组件 4. 集…

时序预测 | Matlab实现BiTCN-BiLSTM双向时间卷积神经网络结合双向长短期记忆神经网络时间序列预测

时序预测 | Matlab实现BiTCN-BiLSTM双向时间卷积神经网络结合双向长短期记忆神经网络时间序列预测 目录 时序预测 | Matlab实现BiTCN-BiLSTM双向时间卷积神经网络结合双向长短期记忆神经网络时间序列预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 1.Matlab实现BiTCN…

本地主机连接Linux虚拟机中的mongodb,并使用studio 3T连接,同时项目启动连接mongodb刷新数据库

本部分只做个人纪录 ** 1.安装mongodb ** 本部分为尚硅谷的电影推荐系统的文档,具体以实际存放位置为准 // 通过WGET下载Linux版本的MongoDB [bigdatalinux ~]$ wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel62-3.4.3.tgz// 将压缩包解压到…

Python 深度学习第二版(GPT 重译)(二)

四、入门神经网络:分类和回归 本章涵盖 您的第一个真实世界机器学习工作流示例 处理矢量数据上的分类问题 处理矢量数据上的连续回归问题 本章旨在帮助您开始使用神经网络解决实际问题。您将巩固从第二章和第三章中获得的知识,并将所学应用于三个新…

Java newInstance方法学习

用newInstance与用new是有区别的,区别在于创建对象的方式不一样,前者是使用类加载机制; newInstance方法要求该 Class 对应类有无参构造方法; 执行 newInstance()方法实际上就是使用对应类的无参构造方法来创建该类的实例&#x…

Golang 异步(bsd/linux)io

Golang 异步(bsd/linux)io 在日常开发中,读写文件的底层调用函数是syscall.Read/Write。一切都是围绕这两个函数展开的,不过有时候需要或者就是单纯想异步执行。liburing是linux上一个很好的原生异步io库,这里需要适配bsd派系的系统&#xf…

Redis面试题以及答案

1. 什么是Redis?它主要用来什么的? Redis,英文全称是Remote Dictionary Server(远程字典服务),是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并…

00. 认识 Java 语言与安装教程

认识 Java Java 在 20 多年发展过程中,与时俱进,为了适应时代的需要,经历过两次重大的版本升级,一个是 Java 5,它提供了泛型等重要的功能。另一个是提供了 Lambda 表达式等重要的功能的 Java 8。 一些重要的 Java 的…

GitHub配置SSH Key(详细版本)

GitHub配置SSH Key的目的是为了帮助我们在通过git提交代码是,不需要繁琐的验证过程,简化操作流程。比如新建的仓库可以下载, 但是提交需要账号密码。 步骤 一、设置git的user name和email 如果你是第一次使用,或者还没有配置过的话需要操作…

linux内核input子系统概述

目录 一、input子系统二、关键数据结构和api2.1 数据结构2.1.1 input_dev2.1.2 input_handler2.1.3 input_event2.1.4 input_handle 2.2 api接口2.2.1 input_device 相关接口input_device 注册流程事件上报 2.2.2 input handle 相关接口注册 handle指定 handle 2.2.3 input han…

Python 深度学习第二版(GPT 重译)(一)

前言 序言 如果你拿起这本书,你可能已经意识到深度学习在最近对人工智能领域所代表的非凡进步。我们从几乎无法使用的计算机视觉和自然语言处理发展到了在你每天使用的产品中大规模部署的高性能系统。这一突然进步的后果几乎影响到了每一个行业。我们已经将深度学…

Java与Go:指针

在计算机内存中,每个变量都有一个唯一的地址,指针就是用来保存这个地址的变量。通过指针,我们可以间接地访问和修改存储在该地址处的数据。今天我们来聊一聊Java和Go指针,预告一下,我们需要借助C语言做一些小小的比较。…

Jmeter Ultimate Thread Group 和 Stepping Thread Group

线程组:使用复杂场景的性能测试 有时候我们做性能测试时,只依靠自带的线程组,显示满足不了性能测试中比较复杂的场景,下面这两种线程组可以帮助你很好的完成复杂的场景 第一种:Stepping Thread Group 在取样器错误后…

详解ThreadLocal

为什么出现ThreadLocal ? 在多线程环境下,如果多个线程同时修改一个公共变量,可能会出现线程安全问题,即该变量的最终结果可能出现异常。为了解决线程安全问题,JDK提供了很多技术手段,比如使用synchronize…

软考高级:软件架构风格-虚拟机风格概念和例题

作者:明明如月学长, CSDN 博客专家,大厂高级 Java 工程师,《性能优化方法论》作者、《解锁大厂思维:剖析《阿里巴巴Java开发手册》》、《再学经典:《Effective Java》独家解析》专栏作者。 热门文章推荐&am…

练习 10 Web [MRCTF2020]你传你呢

和test5一样,文件上传限制为图片,使用.htaccess文件让上传成功图片木马文件进行执行 开屏暴击,差点去世 尝试上传文件 各种过滤,但是能传图片,这里就不写了,我做过的test5遇到过的重复内容 直接尝试在te…

HarmonyOS/OpenHarmony应用开发-DevEco Studio 在MAC上启动报错

报错截图 报错详细内容 ------------------------------------- Translated Report (Full Report Below) -------------------------------------Process: devecostudio [8640] Path: /Applications/DevEco-Studio.app/Contents/MacOS/devecos…

ab (Apache benchmark) - 压力/性能测试工具

Apache benchmark(ab) 安装window安装使用方法 - bin目录运行使用方法 - 任意目录运行 linux安装 基本命令介绍常用参数:输出结果分析: ab的man手册 安装 window安装 官网下载链接:https://www.apachehaus.com/cgi-bin/download…