位置: 编程技术 - 正文

MySQL实现树状所有子节点查询的方法(mysql设计树形数据库)

编辑:rootadmin

推荐整理分享MySQL实现树状所有子节点查询的方法(mysql设计树形数据库),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql树状查询,mysql树形结构设计,mysql实现树查询,mysql设计树形数据库,mysql树形结构设计,mysql树形结构设计,mysql 树,mysql 树状结构,内容如对您有帮助,希望把文章链接给更多的朋友!

本文实例讲述了MySQL实现树状所有子节点查询的方法。分享给大家供大家参考,具体如下:

在Oracle 中我们知道有一个 Hierarchical Queries 通过CONNECT BY 我们可以方便的查了所有当前节点下的所有子节点。但很遗憾,在MySQL的目前版本中还没有对应的功能。

在MySQL中如果是有限的层次,比如我们事先如果可以确定这个树的最大深度是4, 那么所有节点为根的树的深度均不会超过4,则我们可以直接通过left join 来实现。

但很多时候我们无法控制树的深度。这时就需要在MySQL中用存储过程来实现或在你的程序中来实现这个递归。本文讨论一下几种实现的方法。

样例数据:

树形图如下

方法一:利用函数来得到所有子节点号。

创建一个function getChildLst, 得到一个由所有子节点号组成的字符串.

使用我们直接利用find_in_set函数配合这个getChildlst来查找

优点: 简单,方便,没有递归调用层次深度的限制 (max_sp_recursion_depth,最大) ;

缺点:长度受限,虽然可以扩大 RETURNS varchar(),但总是有最大限制的。

MySQL目前版本( 5.1.-community)中还不支持function 的递归调用。

方法二:利用临时表和过程递归

MySQL实现树状所有子节点查询的方法(mysql设计树形数据库)

创建存储过程如下。createChildLst 为递归过程,showChildLst为调用入口过程,准备临时表及初始化。

调用时传入结点

depth 为深度,这样可以在程序进行一些显示上的格式化处理。类似于oracle中的 level 伪列。sno 仅供排序控制。这样你还可以通过临时表tmpLst与数据库中其它表进行联接查询。

MySQL中你可以利用系统参数 max_sp_recursion_depth 来控制递归调用的层数上限。如下例设为.

优点 : 可以更灵活处理,及层数的显示。并且可以按照树的遍历顺序得到结果。

缺点 : 递归有的限制。

方法三:利用中间表和过程

(本方法由yongyupost提供样子改编)创建存储过程如下。由于MySQL中不允许在同一语句中对临时表多次引用,只以使用普通表tmpLst来实现了。当然你的程序中负责在用完后清除这个表。

执行完后会产生一个tmpLst表,nLevel 为节点深度,sCort 为排序字段。

使用方法

优点 : 层数的显示。并且可以按照树的遍历顺序得到结果。没有递归限制。

缺点 : MySQL中对临时表的限制,只能使用普通表,需做事后清理。

以上是几个在MySQL中用存储过程比较简单的实现方法。

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》、《MySQL数据库锁相关技巧汇总》及《MySQL常用函数大汇总》

希望本文所述对大家MySQL数据库计有所帮助。

MySQL统计函数GROUP_CONCAT使用陷阱分析 本文实例分析了MySQL统计函数GROUP_CONCAT使用中的陷阱。分享给大家供大家参考,具体如下:最近在用MySQL做一些数据的预处理,经常会用到group_concat函数

mysql group_concat()函数用法总结 本文实例讲述了mysqlgroup_concat()函数用法。分享给大家供大家参考,具体如下:group_concat(),手册上说明:该函数返回带有来自一个组的连接的非NULL值的字

Java数据类型与MySql数据类型对照表 本文讲述了Java数据类型与MySql数据类型对照表。分享给大家供大家参考,具体如下:类型名称显示长度数据库类型JAVA类型JDBC类型索引(int)VARCHARL+NVARCHARja

标签: mysql设计树形数据库

本文链接地址:https://www.jiuchutong.com/biancheng/347873.html 转载请保留说明!

上一篇:mysql使用GROUP BY分组实现取前N条记录的方法(Mysql使用教程)

下一篇:MySQL统计函数GROUP_CONCAT使用陷阱分析

  • 汇算清缴补交所得税后报表需要调整吗
  • 新个税计算公式怎么输入excel
  • 外经证核销反馈表
  • 哪些商业保险可以扣除个人所得税
  • 从农民个人手里获取资源
  • 递延资产放在资产负债表哪里
  • 企业用商业汇票支付购货款
  • 为什么要抵消损益
  • 海关进口货物如何消杀
  • 免税企业减免所得税政策
  • 小规模企业差额征收税率
  • 存款保险能取出来钱吗
  • 小规模纳税人代收水电费
  • 个人出租场地个人所得税
  • 如何计算工程预付款
  • 合同资产和工程存货的区别
  • 应收款收不回账务处理
  • 外籍人员在境内取得所得在我国应该计征个人所得税
  • 公司地址变更代办需要多少钱
  • 车船使用牌照税收多少
  • 包装物计价
  • 差额纳税和全额纳税
  • 华为p30分屏怎么操作
  • 外购的礼品送客户怎么做分录小规模
  • 利润分配会计处理时间
  • 税金及附加审计说明怎么写
  • 进项票与实际支出金额不符
  • 安装固定资产的费用
  • 如何解决windows7台试电脑蓝屏问题
  • Win10 1809 17763.2268 更新发布:附更新修复内容汇总
  • 企业备用金预借多久到账
  • gws.exe是啥
  • php程序开发范例宝典光盘
  • 发票盖章有讲究吗
  • php include path
  • 农村合作社免所得税吗
  • 转销股票会计分录
  • 小微企业的季度所得税怎么计算
  • php 常用算法
  • 用python处理图像
  • 首个ChatGPT开发的应用上线;ChatMind思维导图工具;中文提示词大全;Copilot平替 | ShowMeAI日报
  • 增值税普通发票查询真伪
  • 增值税预征税率是多少
  • 债权资产包括哪些会计科目
  • 怎么开电子专用增值税发票
  • python框架的作用
  • 使用二氧化碳灭火器时人应该站在什么位置
  • mysql可以存什么
  • php如何判断是移动还是pc
  • 其他支出怎么做账
  • 外购产品捐赠
  • 买新车检测
  • 企业所得税预缴申报表
  • 新公司成立的文案
  • 联营单位投入的款项
  • 发票什么情况下可以作废
  • 员工借款后离职怎么处理
  • 无形资产摊销怎么计算月摊销额
  • 个人所得税专项扣除能抵多少
  • 工程发票可以作废吗
  • win8.1无法进入系统
  • mac音频设置在哪里
  • linux中vim命令详解
  • window 查看端口
  • 怎样设置win10
  • win10系统中怎么打开IE浏览器
  • 详细测试就是全部测试
  • 批处理脚本怎么写
  • linux .tar文件
  • 开发 工具
  • 初步了解的英文
  • Windows上使用PD虚拟机
  • 国税总局201439号公告
  • 增值税发票增版增量怎么办理
  • 所得税季度预缴,年度汇算清缴
  • 爱信诺开票系统怎么安装
  • 工商变更信息如何在网上打印?
  • 办理税务需要开户许可证吗
  • 农民专业合作社章程完整版
  • 广东税务微信公众号微办税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设