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也能读取到
相关推荐
递归不收敛3 小时前
大语言模型(LLM)入门笔记:嵌入向量与位置信息
人工智能·笔记·语言模型
冷雨夜中漫步3 小时前
高级系统架构师笔记——数据库设计基础知识(5)Armstrong公理系统、无损连接和有损连接
笔记·系统架构
im_AMBER4 小时前
算法笔记 05
笔记·算法·哈希算法
Element_南笙5 小时前
吴恩达新课程:Agentic AI(笔记2)
数据库·人工智能·笔记·python·深度学习·ui·自然语言处理
koo3646 小时前
李宏毅机器学习笔记21-26周汇总
人工智能·笔记·机器学习
.小小陈.6 小时前
数据结构2:单链表
c语言·开发语言·数据结构·笔记·学习方法
立志成为大牛的小牛6 小时前
数据结构——二十三、并查集的终极优化(王道408)
开发语言·数据结构·笔记·学习·程序人生·考研
全栈游侠7 小时前
04-优先级与延时链表
笔记
im_AMBER7 小时前
React 01
前端·javascript·笔记·react.js·前端框架·web
稻草猫.7 小时前
文件 IO
java·笔记·后端·java-ee·idea