MySQLclient使用笔记

使用libmysqlclient库时,遇到的问题和性能分析总结

需要8.0.16之后版本才支持异步

一、测试情况
  1. 测试环境

    虚拟机:Ubuntu16.04

    CPU:4核

    内存:8G

    数据库表数据量:3万条

    libmysqlclient:8.0.25

  2. 测试量

    执行1万次,比如idwei 1 ~ 30000, 则将id=1 ~ 10000的数据进行更新或查询

  3. 测试写入结论

    对比mysqlclient异步操作、mysqlclient同步操作、odbc方式

    1.InnoDB引擎:

    MySQLclient异步:681ms

    MySQLclient同步:1778ms

    ODBC:1681ms

    2.MySIAM引擎:

    MySQLclient异步:4633ms

    MySQLclient同步:5202ms

    ODBC:5267ms

    3.InnoDB引擎:每次commit

    MySQLclient异步:3367ms

    MySQLclient同步:8308ms

    ODBC:2365ms

  4. 读取测试结论

    1. mysqlclient异步操作(1线程、4连接):200ms
二、使用时的坑
  1. 写入时问题和解决方案

    1. 连接1写入数据,连接2读取,当还没完全写入,连接2就读新写入的数据,则一直读取不到,如果写入等待一会再去读就能取到
    2. 连接1写入,连接1立马读取,也能读取到
    3. 改为自动提交(mysql_autocommit(mysql,true)),则连接1写入数据,连接2立马读取,也能读取到
    4. 连接1写入,连接2执行mysql_reload接口或者操作sql语句:FLUSH PRIVILEGES 之后连接2也能读取到
相关推荐
Olrookie2 分钟前
若依前后端分离版学习笔记(一)——本地部署
笔记·后端·开源
##echo1 小时前
嵌入式Linux裸机开发笔记9(IMX6ULL)GPIO 中断实验(1)
linux·c语言·笔记·单片机·嵌入式硬件
我爱学嵌入式4 小时前
C语言第 9 天学习笔记:数组(二维数组与字符数组)
c语言·笔记·学习
_Kayo_11 小时前
VUE2 学习笔记6 vue数据监测原理
vue.js·笔记·学习
使二颗心免于哀伤14 小时前
《设计模式之禅》笔记摘录 - 10.装饰模式
笔记·设计模式
悠哉悠哉愿意14 小时前
【电赛学习笔记】MaxiCAM 项目实践——与单片机的串口通信
笔记·python·单片机·嵌入式硬件·学习·视觉检测
岩中竹15 小时前
广东省省考备考——常识:科技常识(持续更新)
笔记
Olrookie15 小时前
若依前后端分离版学习笔记(三)——表结构介绍
笔记·后端·mysql
rannn_11116 小时前
Java学习|黑马笔记|Day23】网络编程、反射、动态代理
java·笔记·后端·学习
UQWRJ17 小时前
菜鸟教程 R语言基础运算 注释 和数据类型
笔记