当前位置: 首页 > news >正文

MYSQL递归

查询商品分类分布

WITH RECURSIVE category_tree AS (SELECTid, NAME, parent_id, 0 AS LEVEL,CAST(NAME AS CHAR(1000)) AS PATHFROM categoriesWHERE is_delete = 0 AND STATUS=1 AND (parent_id = 0 OR parent_id IS NULL)UNION ALLSELECTc.id, c.name, c.parent_id, ct.level + 1,CONCAT(ct.path, ' > ', c.name) AS PATHFROM categories cINNER JOIN category_tree ct ON c.parent_id = ct.idWHERE c.is_delete = 0 AND STATUS=1),leaf_categories AS (SELECT ct.*FROM category_tree ct)SELECTlc.path AS NAME,COUNT(p.id) AS VALUE,lc.level AS LEVELFROM leaf_categories lcLEFT JOIN products p ON lc.id = p.category_id AND p.is_delete = 0 AND STATUS=1GROUP BY lc.id, lc.name, lc.path, lc.levelHAVING VALUE >0ORDER BY VALUE DESC

结果

如果只需要查看叶子节点你只需要

选择parent_id不为当前表中任何id的分类,即最底层的分类
leaf_categories AS (SELECT ct.*FROM category_tree ctWHERE  NOT EXISTS (SELECT 1 FROM categories cWHERE c.parent_id = ct.id AND c.is_delete = 0 AND STATUS=1))

http://www.dtcms.com/a/352236.html

相关文章:

  • mysql优化-mysql索引下推
  • Python 将十进制转换为十六进制
  • Linux命令详解+示例(炫彩超全)
  • 2025秋招季:AI笔试破解大规模招聘难题
  • MySQL 面试题系列(四)
  • Pandas 分组聚合进阶:过滤与 apply
  • 【人工智能】神经网络的优化器optimizer(三):RMSProp动态自适应学习率优化器
  • java自定义注解实现
  • 开发electron时候Chromium 报 Not allowed to load local resource → 空白页。
  • 在使用spring ai进行llm处理的rag的时候,选择milvus还是neo4j呢?
  • gorm 枚举查询遇到的问题
  • 【Python】Python日志模块完全指南:从配置到常见错误排查
  • 深入OpenHarmony后台任务“黑匣子”:BackgroundTaskMgr框架全栈解析与实战避坑指南
  • C#编程:贪吃蛇游戏
  • 使用linux+javascript+html+mysql+nodejs+npm+express等构建信息资料采集系统
  • FreeRTOS 同步互斥与任务协作 学习笔记
  • 【Protues仿真】定时器
  • 对讲联动电梯门禁系统通过深度集成对讲、梯控、身份认证三大模块,在提升便捷性的同时,以“权限后置发放+电梯状态闭环检测“为核心,实现安全性与可靠性的双重突破。
  • 解决VSCode无法下载服务器端 Server问的题
  • 当 C++ 用于嵌入式开发:优点和缺点
  • .gitignore 文件相关使用配置
  • 【Redis】安装和基础命令
  • 十、Java面向对象编程入门指南:继承与多态
  • 利用 OpenTelemetry 建设尾部采样
  • 大模型全栈学习路线:4 - 6 个月从入门到实战,打通技术与业务闭环
  • [灵动微电子 霍尔FOC MM32BIN560C]从引脚到应用
  • 《黑客帝国》解构:白帽黑客的极客思维宇宙
  • vue3写一个简单的时间轴组件
  • 【python】python利用QQ邮箱SMTP发送邮件
  • k8s pod resources: {} 设置的含义