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也能读取到
相关推荐
saoys27 分钟前
Opencv 学习笔记:轮廓发现(提取 + 绘制全流程)
笔记·opencv·学习
zhangrelay1 小时前
如何让手机电脑流畅飞起低碳节能性能拉满-软件安装篇-ESR-Extended Support Release-延长支持版-LTS
linux·运维·笔记·学习
@––––––2 小时前
论文阅读笔记:The Bitter Lesson (苦涩的教训)
论文阅读·人工智能·笔记
傻小胖3 小时前
6.BTC-网络-北大肖臻老师客堂笔记
笔记·web3·区块链
Lonely 净土3 小时前
第5-10天学习笔记
笔记·学习
EmbedLinX3 小时前
内存池学习笔记(附C++完整实现)
c++·笔记·学习
嵌入式×边缘AI:打怪升级日志3 小时前
USBX虚拟串口源码分析与改造笔记
笔记·学习笔记·usb
BlackWolfSky3 小时前
鸿蒙中级课程笔记3—ArkUI进阶6—ArkUI性能优化实践(长列表加载性能优化)
笔记·华为·harmonyos
马猴烧酒.3 小时前
智能协图云图库学习笔记day6-主流图片优化技术
笔记·学习
静小谢4 小时前
前端mock假数据工具JSON Server使用笔记
前端·笔记·json