QT连接MySQL数据库问题

  • Post author:
  • Post category:mysql


项目背景:QT连接MySQL数据库问题


提示:这里简述项目相关背景:

例如:项目场景:示例:通过蓝牙芯片(HC-05)与手机 APP 通信,每隔 5s 传输一批传感器数据(不是很大)


问题描述:No QMySQL driver, the driver failed to load

没有QMYSQL驱动,驱动加载失败

在github下载一个QMYSQL的驱动,把两个文件放到sqldrivers文件夹下

数据库的数据导入qt乱码

修改my.ini文件,将三个端口改为utf8


提示:这里描述项目中遇到的问题:

例如:数据传输过程中数据不时出现丢失的情况,偶尔会丢失一部分数据

APP 中接收数据代码:

@Override
        public void run() {
            bytes = mmInStream.read(buffer);
            mHandler.obtainMessage(READ_DATA, bytes, -1, buffer).sendToTarget();
        }



原因分析:


提示:这里填写问题的分析:

例如:Handler 发送消息有两种方式,分别是 Handler.obtainMessage()和 Handler.sendMessage(),其中 obtainMessage 方式当数据量过大时,由于 MessageQuene 大小也有限,所以当 message 处理不及时时,会造成先传的数据被覆盖,进而导致数据丢失。




解决方案:


提示:这里填写该问题的具体解决方案:

例如:新建一个 Message 对象,并将读取到的数据存入 Message,然后 mHandler.obtainMessage(READ_DATA, bytes, -1, buffer).sendToTarget();换成 mHandler.sendMessage()。



版权声明:本文为Jason_Chen__原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。