当前位置:首页 > 文章列表 > 数据库 > MySQL > mysql 的这个痛点,用 elasticsearch 轻松解决

mysql 的这个痛点,用 elasticsearch 轻松解决

来源:SegmentFault 2023-02-24 12:25:43 0浏览 收藏

本篇文章主要是结合我之前面试的各种经历和实战开发中遇到的问题解决经验整理的,希望这篇《mysql 的这个痛点,用 elasticsearch 轻松解决》对你有很大帮助!欢迎收藏,分享给更多的需要的朋友学习~

大家好,我是月白。

写这篇文章不是对比 mysql 和 elasticsearch 的优劣(它们生而不同,没啥好比的),而是想分享一下最近在工作上遇到的一个查询问题和这个问题的解决过程。对于 elasticsearch,我也还是处在略懂阶段,要不是因为这次工作需要,我可能不会去研究它?

好了,回到正题,由于内部工作调整,接收了一个公司的边缘项目,体量并不大,几十万的用户数量。然而,就是这区区的几十万用户数量,导致了mysql in 查询参数过多的问题,运营在管理后台查询客户列表速度缓慢甚至一度陷入瘫痪。

你可能会想,是不是代码写的太烂了或者前期设计考虑不周?

e18d20c94006dfe0-3cdd6892e1ea4e8e-5fd0bb2a3b67d491916c6556801d6eae.jpeg

其实这个也能理解,毕竟产品的需求是多变的,考虑不周是常有的事。这个列表查询原本只有几个简单的字段查询,而且都是客户表单表内的字段查询,随着产品的变更,查询条件多达十几个,其中这个标签查询,联表也解决不了问题,那具体是怎么一个情况呢?

别急,让我简单介绍一下

开始你的表演.gif

问题简述

为了集中于描述这个问题,表结构进行了惨无人道的简化,能体会到这个意思就好?
前端的展示就是下面这种分页表格(图片截图自 ant design 官方文档)

企业微信20211021-191939.png

表结构

客户表 custmers

字段类型
idint
namestring
gendertinyint
ageint
remarkstring
created_attimestamp
updated_attimestamp

标签表 tags

字段类型
idint
namestring
created_attimestamp
updated_attimestamp

关联表 customer_tag

字段类型
customer_idint
tag_idint

查询需求

现在产品需要通过客户名字以及客户身上的标签进行查询,支持多个标签同时查询。原来的sql大概是这样的

/*
 获取符合要求的 customer_id 列表 
 查出来一大堆 customer_id
 */
select customer_id from custmer_tag where tag_id in (传入的tag_id);

/*
 通过 customer_id 查询
 每翻一页都得经历这一大堆id的in查询,id过多还会导致代码直接崩溃
*/
select * from customers where id in (一大堆id) limit 10 offset 0; 

问题显而易见了吧,in 查询内参数过多,不仅效率低下,极端情况还会导致sql过长程序崩溃。

看了第一眼我觉是不是可以拯救一下(慢就慢一点,先让程序不异常),于是换成下面的语句:

select * from customers where id in (select customer_id from custmer_tag where tag_id in (传入的 tag_id) group by customer_id));

但是仔细看了一下业务逻辑我就放弃了,多个 tag_id 查询 要支持 and 和 or 的查询逻辑,

select customer_id from custmer_tag where tag_id in (1,2,3) group by customer_id
这句子查询 sql 就是 or 关系查询,customer 只需要存在任何一个 tag_id 就满足查询条件。但是如果是 and 逻辑呢?要查出同时存在标签 1,2,3 的客户,那么这条语句就不适用了。当然,如果一定要用 sql 去查,也许也能查出来,这里我就没有再试了,毕竟就算子查询行得通,效率也是十分低下的,不是长久之计。

解决方案

那该如何解决呢?我的第一反应就是先通过 es 查询出符合条件的 customer 表的 id,然后再通过id查询数据,这样对整个业务逻辑改动最小,效率也完全没有问题,毕竟原来的查询及组装数据逻辑十分复杂,涉及到五六张表联查和后续数据处理,实在不想做过多改动(常规职场保命)

4e8872a8f8104b737b669bacc7903cc8.jpg

开始优化

搭建 elasticsearch 服务

这个是运维的活,我提需求就行了。

数据写入 es

这个得我干了?
由于需要查询的字段涉及了多张表,索性把所有相关字段和customer的基本信息写入到 es,方便后续同样需要查询的业务(后面还真的用到了,而且还追加了字段)

字段确定了之后,如何实时更新呢?在每个业务修改和插入的点触发写入和更新的操作?
显然不是,这样写既容易写不全面,也需要很大的机械化工作,显然不是生活在水深火热之中的程序员该干的事。那么怎么做呢?

这时候,如果我们能像mysql从库那样,把数据都同步过来,然后我们更新一下 es,岂不是完美。说干就干,在通过一番折腾之后(主要是监听binlog),终于是解决了数据入库的问题。

重构代码

现在的代码逻辑变成了这样:

  1. 从 es 分页查询出 customer id 100, 200, 300
  2. 把原来 sql 的所有 where 条件删除,添加 where id in (100,200,300),其他逻辑不用动

至此,业务重构完成,查询速度轻轻松松提高百倍,那缺点是什么呢?

!!!要花钱!!!!!

充钱能解决.gif

后话

虽然问题目前是解决了,但从这件事中,我体会到了 es 便利之处,决定进一步学习一番。这篇文章涉及到的 es 和 mysql 监听等相关内容后续更新吧!

就酱,祝大家工作顺利!我是月白,一枚在互联网苟且偷生的猿。

好了,本文到此结束,带大家了解了《mysql 的这个痛点,用 elasticsearch 轻松解决》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多数据库知识!

版本声明
本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
APIJSON 4.7.2 发布,BAT 技术专家贡献生态项目APIJSON 4.7.2 发布,BAT 技术专家贡献生态项目
上一篇
APIJSON 4.7.2 发布,BAT 技术专家贡献生态项目
MySQL里的日志文件
下一篇
MySQL里的日志文件
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    514次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    499次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • SEO  AI Mermaid 流程图:自然语言生成,文本驱动可视化创作
    AI Mermaid流程图
    SEO AI Mermaid 流程图工具:基于 Mermaid 语法,AI 辅助,自然语言生成流程图,提升可视化创作效率,适用于开发者、产品经理、教育工作者。
    671次使用
  • 搜获客笔记生成器:小红书医美爆款内容AI创作神器
    搜获客【笔记生成器】
    搜获客笔记生成器,国内首个聚焦小红书医美垂类的AI文案工具。1500万爆款文案库,行业专属算法,助您高效创作合规、引流的医美笔记,提升运营效率,引爆小红书流量!
    681次使用
  • iTerms:一站式法律AI工作台,智能合同审查起草与法律问答专家
    iTerms
    iTerms是一款专业的一站式法律AI工作台,提供AI合同审查、AI合同起草及AI法律问答服务。通过智能问答、深度思考与联网检索,助您高效检索法律法规与司法判例,告别传统模板,实现合同一键起草与在线编辑,大幅提升法律事务处理效率。
    704次使用
  • TokenPony:AI大模型API聚合平台,一站式接入,高效稳定高性价比
    TokenPony
    TokenPony是讯盟科技旗下的AI大模型聚合API平台。通过统一接口接入DeepSeek、Kimi、Qwen等主流模型,支持1024K超长上下文,实现零配置、免部署、极速响应与高性价比的AI应用开发,助力专业用户轻松构建智能服务。
    768次使用
  • 迅捷AIPPT:AI智能PPT生成器,高效制作专业演示文稿
    迅捷AIPPT
    迅捷AIPPT是一款高效AI智能PPT生成软件,一键智能生成精美演示文稿。内置海量专业模板、多样风格,支持自定义大纲,助您轻松制作高质量PPT,大幅节省时间。
    659次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码