第八天:gec6818arm开发板和Ubuntu中安装并且编译移植mysql驱动连接QT执行程序

一、Ubuntu18.04中安装并且编译移植mysql驱动程序连接qt执行程序

1 、安装Mysql

sudo apt-get install mysql-serverapt-get isntall mysql-clientsudo apt-get install libmysqlclient-d

2、查看是否安装成功,即查看MySQL版本

mysql --version       

3、MySQL启动与关闭命令

service mysql start  # 启动
service mysql stop  # 关闭

4、设置用户和密码

(1)先输入以下命令

cd /etc/mysql
sudo cat debian.cnf

(2)你会得到以下类似结果
在这里插入图片描述
(3)根据user 和 password输出结果, 编辑命令 mysql -u( u s e r ) − p (user) -p(user)−p(password),不用写括号,括号是方便看

mysql -udebian-sys-maint -p2STJ4ZfRtNhqe4Aw    
#最好是复制过来以免出错,不要把 -u  -p 忽略掉,且u,p后面无空格

(4)至此 已经进入到了MySQL系统中了

5、改密码
依次输入以下数据库语句(也可以全部复制直接输入运行)

show databases;
use mysql;
update user set authentication_string=PASSWORD('自己的密码') where user='root';
update user set plugin="mysql_native_password"; 
flush privileges;
quit;

6、登录

service mysql stop  # 关闭
service mysql start  # 启动
mysql -uroot -p密码
或者
mysql -uroot -p #回车
再输入密码

如果现在连接mysql会报错,没有mysql驱动如下类似报错:

QSqlDatabase: QMYSQL driver not loaded
QSqlDatabase: available drivers: QSQLITE QMYSQL QMYSQL3 QPSQL QPSQL7
db open err: “Driver not loaded Driver not loaded”

7.编译移植mysql驱动(这一过程究极复杂,建议参考以下其他博客结合参照,请注意,如果你是按照我的博客一步一步安装的,即QT版本是5.9,则有快速简单方法,直接看第8步)

(1)保险起见,再次执行以下命令安装一遍libmysqlclient-dev

sudo apt-get install libmysqlclient-dev

(2)进入QT安装目录的源码目录(如果安装 时没有选择源码,重新安装下),找到MySql驱动源码目录
如:/home/csgec/Qt5.9.1/5.9.1/Src/qtbase/src/plugins/sqldrivers/mysql

(3)在上述mysql目录下执行qmake命令,记住qmake命令路径是否和你一样正确,生成Makefile

/home/csgec/Qt5.9.1/5.9.1/gcc_64/bin/qmake “INCLUDEPATH+=/usr/include/mysql” “LIBS+=-L/usr/lib/x86_64-linux-gnu/ -lmysqlclient” mysql.pro

注:如果出错:
Project ERROR: Library ‘mysql’ is not defined.
则打开mysql.pro文件注释掉QMAKE_USE +=mysql这行
如果出错:
qtsqldrivers-config.pri没找到
则下载QT5.9.1的源码包,到相应目录拷贝过来就可以。(安装包中居然没有这个文件,但源码包中有)

(4)分别执行以下命令

cd  /home/csgec/Tools/qt-everywhere-opensource-src-5.9.1/qtbase/src/plugins/sqldrivers
cp qtsqldrivers-config.pri /home/csgec/Qt5.9.1/5.9.1/Src/qtbase/src/plugins/sqldrivers
make
make install

(5)生成的库所在的目录: /home/csgec/Tools/qt-everywhere-opensource-src-5.9.1/qtbase/plugins/sqldrivers/

把libqsqlmysql.so放到qt安装目录/plugins/sqldrivers/里面即可

8.编译移植mysql驱动简单方法
我提供了已经移植编译好的驱动文件,大家点击下载放在相应的目录即可

自此MySQL安装完成,自己可以在Ubuntu中编写qt程序直接连接mysql了

二、gec6818arm开发板中安装并且编译移植mysql驱动程序连接qt执行程序

快速方法:移植先看:
当前文件夹都是我移植好的库和源码包,后面移植生成的库都放在了当前文件夹下,其中mysql-arm.tar.gz 是 我已经移植好的mysql在arm平台下的源码包,
qt-everywhere-opensource-src-5.9.1.tar.gz是QT的官方源码包(用于后面我们移植QT-mysql)

不想移植的看这:
-》在开发板的QT库的目录下/opt/EMqt5.9-gec/plugins 创建mkdir sqldrivers
-》拷贝libqsqlmysql.so到sqldrivers目录下
-》建立软连接 ln -s /opt/armqt5.5-gec/plugins/sqldrivers/libqsqlmysql.so /lib/libqsqlmysql.so
libqsqlmysql.so已经上传了,自己可以[点击下载](上面那个下载了就不用重复下载,放一起了)(https://download.csdn.net/download/xqmids99/88362750)
-》配置好mysql服务器支持远程连接(详见页底)

--------------------------------------------mysql完整版(包括客户端和服务器端)-----------------------------------------------------

1.将mysql-arm.tar.gz下载到开发板,解压mysql-arm.tar.gz到/usr/local目录下
–》tar -zxvf mysql-arm.tar.gz -C /usr/local

2.将mysql.server拷贝到开发板/etc/init.d/目录下

  1. 将my.conf文件拷贝到/etc目录下

不过因为我们粤嵌的开发板flash较小,我们选择只移植mysql的客户端,连接pc端的mysql

—————————————————------- C语言 客户端版————————————————————————————
(具体移植方法见http://blog.csdn.net/liangzhuangdongtou/article/details/51782557–》》》可能会有所出入,遇到问题自己解决一下呗)

1.拷贝libmysqlclient.so.16.0.0 到开发板/lib目录下,并建立软连接,命令如下
ln -s libmysqlclient.so.16.0.0 libmysqlclient.so.16
ln -s libmysqlclient.so.16.0.0 libmysqlclient.so

2.拷贝libmysqlclient_r.so.16.0.0文件到开发板/lib目录下,并建立软连接libmysqlclient_r.so.16
ln -s libmysqlclient_r.so.16.0.0 libmysqlclient_r.so.16
ln -s libmysqlclient_r.so.16.0.0 libmysqlclient_r.so

3.拷贝 mysql_client_test到开发板/bin目录下,并将权限修改为777
可用 mysql_client_test --help查看使用方法(mysql_client_test用于测试mysql连接,此步骤可以忽略)

使用方法:mysql_client_test -h ip–database=数据库名 -u 用户 -p密码1
——》mysql_client_test -h 192.168.1.17 --database=student -u root -p123456

–》连接成功会出现以下信息

#####################################
client_connect
#####################################

Establishing a connection to ‘192.168.1.17’ …OK
Connected to MySQL server version: 5.7.17-log (50717)

———————————————————QT客户端版————————————————————————

  1. QT使用mysql需要先编译好arm平台下的mysql(详见 http://blog.csdn.net/liangzhuangdongtou/article/details/51782557)

    -》过程有些麻烦

    赶时间的话可选择以下方案
    将我移植好的源码包 mysql-arm.tar.gz 解压放到/usr/local目录下
    -》tar -zxvf /mnt/hgfs/share/mysql-arm.tar.gz -C /usr/local

上面的完成后,接下来需要编译对应ARM平台的QT的mysql驱动(当然需要先移植好QT到开发板,还没有移植的同学看下之前的笔记咯)

(由于我们已经移植好的粤嵌qt库没有支持mysql, 此时我们需要编译 QT-mysql,)

a)解压源码包tar -zxvf qt-everywhere-opensource-src-5.5.0.tar.gz -C /opt
tips:QT源码包每一级都会有.pro文件,所以我们可以单独编译我们所需要的

b)进入解压后的源码包目录
1)cd /opt/qt-everywhere-opensource-src-5.5.0/qtbase/src/plugins/sqldrivers/mysql
2)执行/opt/armqt5.5-gec/bin/qmake “INCLUDEPATH+=/usr/local/mysql/include/mysql” “LIBS+=-L/usr/local/mysql/lib/mysql -lmysqlclient_r” mysql.pro

3)倘若一切步骤顺利的话,会出现以下信息rm -f libqsqlmysql.so

arm-linux-gnueabi-g++ -Wl,–no-undefined -Wl,-O1 -Wl,–enable-new-dtags -Wl,-rpath,/opt/armqt5.5-gec/lib -shared -o libqsqlmysql.so .obj/main.o .obj/qsql_mysql.o .obj/moc_qsql_mysql_p.o -L/home/tiydy/armlib/tslib/lib -L/home/tiydy/armlib/freetype/lib -L/home/tiydy/armlib/fontconfig/lib -L/usr/local/mysql/lib/mysql -lmysqlclient_r -L/opt/armqt5.5-gec/lib -lQt5Sql -lQt5Core -lpthread
mv -f libqsqlmysql.so …/…/…/…/plugins/sqldrivers/

    即在/opt/qt-everywhere-opensource-src-5.5.0/qtbase/plugins/sqldrivers目录下出现libqsqlmysql.so-》》》libqsqlmysql.so这个是我们想要的4)拷贝libsqlmysql.so到开发板上a) 我这里是/opt/armqt5.5-gec/plugins -》先创建mkdir sqldrivers-》拷贝libqsqlmysql.so到sqldrivers目录下-》建立软连接 ln -s /opt/armqt5.5-gec/plugins/sqldrivers/libqsqlmysql.so   /lib/libqsqlmysql.so到此就大功告成了!!!!5)最后下载mysql_test目录下的测试程序(mysql_test)到开发板测试一下吧

--------------------让mysql支持远程连接--------------------------------------------
方法1.在windows进入cmd命令行(当然也可以在图形界面上修改)
-》mysql -u root -p
-》use mysql;
-》update user set host = ‘%’ where user = ‘root’;
-》select host, user from user;

方法2:有兴趣自己找下吧!!

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

STP生成树协议基本配置示例---STP逻辑树产生和修改

STP是用来避免数据链路层出现逻辑环路的协议,运行STP协议的设备通过交互信息发现环路,并通过阻塞特定端口,最终将网络结构修剪成无环路的树形结构。在网络出现故障的时候,STP能快速发现链路故障,并尽快找出另外一条路径…

Selenium-介绍下其他骚操作

Chrome DevTools 简介 Chrome DevTools 是一组直接内置在基于 Chromium 的浏览器(如 Chrome、Opera 和 Microsoft Edge)中的工具,用于帮助开发人员调试和研究网站。 借助 Chrome DevTools,开发人员可以更深入地访问网站&#xf…

SpringMVC初级

文章目录 一、SpringMVC 概述二、springMVC步骤1、新建maven的web项目2、导入maven依赖3、创建controller4、创建spring-mvc.xml配置文件(本质就是spring的配置件)5、web.xml中配置前端控制器6、新建a.jsp文件7、配置tomcat8、启动测试 三、工作流程分析…

【Vue】如何搭建SPA项目--详细教程

🎬 艳艳耶✌️:个人主页 🔥 个人专栏 :《Spring与Mybatis集成整合》《springMvc使用》 ⛺️ 生活的理想,为了不断更新自己 ! 目录 1.什么是vue-cli 2.安装 2.1.创建SPA项目 2.3.一问一答模式答案 3.运行SPA项目 3…

UML活动图

在UML中,活动图本质上就是流程图,它描述系统的活动、判定点和分支等,因此它对开发人员来说是一种重要工具。 活动图 活动是某件事情正在进行的状态,既可以是现实生活中正在进行的某一项工作,也可以是软件系统中某个类…

【element-ui】form表单动态修改rules校验项

在项目开发过程中,该页面有暂存和提交两个按钮,其中暂存和提交必填项校验不一样,此时需要动态增减必填项校验 ,解决方法如下: 增加rules校验项 this.$set(this.formRules,name,[{required:true,message:请输入名称,t…

润和软件HopeStage与华宇信息TAS应用中间件完成产品兼容性互认证

近日,江苏润和软件股份有限公司(以下简称“润和软件”)HopeStage 操作系统与北京华宇信息技术有限公司(以下简称“华宇信息”)TAS应用中间件软件完成产品兼容性测试。 测试结果表明,企业级通用操作系统Hope…

【Windows Server 2012 R2搭建FTP站点】

打开服务器管理器——添加角色和功能 下一步 下一步 下一步 选择FTP服务器,勾上FTP服务和FTP扩展,点击下一步 安装 安装完成关闭 打开我们的IIS服务器 在WIN-XXX主页可以看到我们的FTP相关菜单 右键WIN-XXXX主页,添加FTP站点 输入站点名称-FT…

前端面试手撕编程之ES+算法

目录 ES6 防抖 节流 防抖、节流应用 改变this call typeof this ! function context context || window context._this this delete context._this bind: return _this.apply(context, [...arguments].slice(1)); 深拷贝 !arr|| arr null || typeo…

【分布式计算】七、同步 synchronization 重难点

两个协议: 1、NTP(Network Time Protocal)–>广泛使用    机器周期向时间服务器获取准确时间   2、没有协议名称 − > -> −>没有广泛使用    时间服务器周期扫描所有机器,计算时间平均值;导致时间服务器负载…

【数据结构】时间、空间复杂度

⭐ 作者:小胡_不糊涂 🌱 作者主页:小胡_不糊涂的个人主页 📀 收录专栏:浅谈数据结构 💖 持续更文,关注博主少走弯路,谢谢大家支持 💖 时间、空间复杂度 1. 算法效率3. 时…

应用程序处理:TCP模块的处理

1、应用程序处理 首先应用程序会进行编码处理,这些编码相当于 OSI 的表示层功能; 编码转化后,邮件不一定马上被发送出去,这种何时建立通信连接何时发送数据的管理功能,相当于 OSI 的会话层功能。 2、TCP 模块的处理 …

Acer宏碁暗影骑士5笔记本AN517-54原装出厂Win10系统工厂模式

宏基电脑原厂WINDOWS10系统自带所有硬件的驱动、NITROSENSE风扇键盘控制中心、Office办公软件、出厂主题壁纸LOGO、 Acer Care Center、Quick Access等预装程序 链接:https://pan.baidu.com/s/1Ovui_CvsUaF-TX0NbuhEVg?pwdcrmv 提取码:crmv 所需要工…

Hadoop-sqoop

sqoop 1. Sqoop简介及原理 简介: Sqoop是一款开源的工具,主要用于在Hadoop(Hive)与传统的数据库(mysq1.postgresql..)间进行数据的传递,可以将一个关系型数据库(例如: MySQL ,Oracle ,Postgres等)中的数据导进到Hadoop 的HDFS中&…

2、Window上的 虚拟机端口 暴露到 宿主机局域网教程

今天在公司的服务器主机上捣鼓虚拟机,要在虚拟机上安装一个oracle,虚拟机和主机能互相ping通的前提下,要将虚拟机上的端口号暴露在主机上,让项目组内的所有员工的电脑都能访问到该oracle数据库。 也就是电脑A 访问主机&#xff0…

计算机网络运维方向综合知识大全

一. 基础知识 1. 网络的组成 组成部分:硬件、软件、协议 硬件主要由主机(也称端系统)、通信链路(如双绞线、光纤)、交换设备(如路由器、交换机等)和通信处理机(如网卡)等组成。软件主要包括各种…

【SpringCloud】微服务技术栈入门1 - 远程服务调用、Eureka以及Ribbon

目录 远程服务调用RestTemplate Eureka简要概念配置 Eureka 环境设置 Eureka ClientEureka 服务发现 Ribbon工作流程配置与使用 Ribbon饥饿加载 远程服务调用 RestTemplate RestTemplate 可以模拟客户端来向另外一个后端执行请求 黑马给出的微服务项目中,有两个 …

【深度学习实验】前馈神经网络(六):自动求导

目录 一、实验介绍 二、实验环境 1. 配置虚拟环境 2. 库版本介绍 三、实验内容 0. 导入必要的工具包 1. 标量求导 2. 矩阵求导 3. 计算图 一、实验介绍 PyTorch提供了自动求导机制,它是PyTorch的核心功能之一,用于计算梯度并进行反向传播。自动求…

使用Java将PPT、PPTX和PDF转换为图片

从Office到图片—使用Java实现文件格式转换 PDF转图片1. 万事第一步2. 撸代码 PPT/PPTX转图片1. 万事第一步2. 撸代码验收一下 最近小雨遇到了一个需求,需要在前端小程序中嵌入展示Office文件的功能。然而,前端使用开源组件进行在线预览会导致性能消耗较…

windows下gvim的配置

一、vim配置文件 "查看自己的vimrc所在的目录 "在命令模式下 :echo $MYVIMRC"打开自己的vimrc文件 "在命令模式下 :e $MYVIMRC 二、排版 "查看自己当前的字体及大小 "在命令模式下 :set guifont?"设置默认的字体为仿宋_GB2312&#xff…