位置: 编程技术 - 正文

MySQL多层级结构-树搜索介绍(mysql三层架构)

编辑:rootadmin

推荐整理分享MySQL多层级结构-树搜索介绍(mysql三层架构),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql三层架构,mysql多层级表设计,mysql 层级关系,mysql多级树,mysql分层架构,mysql 层级关系,mysql有几层,mysql多层级表设计,内容如对您有帮助,希望把文章链接给更多的朋友!

基本上在每个系统中都有那么几张表是自关联父子关系的结构。往往有很多人都是使用pid来做关联。在刚进入IT行业时使用CAKEPHP框架编写WEB的时候,使用它里面的一个ACL plugin实现权限管理的时候。发现一个表结构硬是不明白是怎么回事。具体表结构如下:

我们可以看到上面 acos 表用有lft、rght这两个字段。起初我根本就不明白这两个是做什么用的,几次直接修改数据导致数据错乱。

1.2. 原理解释

其实这就是树的后续遍历的每个节点的左值、右值。如下图表示:

1.3. 树的使用(引用上图树结构)

构造数据

查找 '节点4' 的所有子节点

思路:我们只要查找出 节点左值在 '节点4' 左值和右值之间的节点通俗说法:能被 '节点4' 包住的节点,通过左节点和右节点来判断是否被 '节点4' 包住。

查找 '节点6' 的所有父节点思路: 找出 左值小于 '节点6' 并且 右值大于 '节点6' 的节点。通俗说法: 找出那个节点能将 '节点6' 给包住。

MySQL多层级结构-树搜索介绍(mysql三层架构)

计算 '节点4' 的深度如果是MySQL5.7 需要修改sql_mode

获取 '节点4' 的所有子节点, 和相关深度

插入数据数据的插入是一件相当麻烦的事,需要更新节点的所有父节点的右值和和所有孩子节点的 '左值、右值'如上图,如果我们想为 '节点4' 添加一个孩子 '节点'(为了不给自己挖坑,我们将添加的孩子放在父节点的最左边),就是将 '节点' 放在 '节点5' 的左边。如下图:

最终我们获得的结果,如下图:

上图 '紫色' 的是节点需要变更的左值和右值,'绿色' 的是新增节点的值。更新思路:1、将左值大于 '节点4' 的左值的节点的左值 加2。2、将右值大于 '节点4' 的左值的节点的右值 加2。

插入思路1、将 '节点' 的左值设置为 '节点4' 的左值 加、将 '节点' 的右值设置为 '节点4' 的左值 加2

验证

1.4. 总结

这种树结构一般会用在查询多增加修改少的场景中(比如地区表,类别表之类的)。在现实中其实还有些表的数据字段很多,并且具有层级关系。但是他们层级关系并不需要实时的那么准确(最终能达到数据数据一直就行),这是我们会将这种层级关系的字段和主表分开放在另外一个表。这样为了加快更新。如果实时更新影响到了性能,这是我们会考虑使用kafka(我们还没有发现性能很差)。

MySQL多层级结构-区域表使用树详解 1.1.前言前面我们大概介绍了一下树结构表的基本使用。在我们项目中有好几块有用到多层级的概念。下面我们哪大家都比较熟悉的区域表来做演示。1.2.

解决Mysql数据库插入数据出现问号(?)的解决办法 首先,我用的mysql数据库是5.7.版本。出现的问题:1.插入数据显示错误,插入不成功,出现:Incorrectstringvalue:'xCDxF5xD5xBCxBExA9'forcolumn'Sname'atrow.插

Mysql最新版本的数据库安装教程(5.7) 默认情况,在CentOS6.8下通过yum安装的是5.1.版本,现在需求是安装5.7版本。Mysql官方网站:

标签: mysql三层架构

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

上一篇:MySQL中易被我们忽略的细节(mysql为什么很受大家青睐)

下一篇:MySQL多层级结构-区域表使用树详解(mysql三层架构)

  • 增值税发票验真伪怎么验
  • 核定税种可以在哪里申报
  • 增值税税负率举例说明
  • 个税缴款三方协议
  • 券商买卖股票手续费
  • 药店药品成本怎么核算
  • 增值税小规模纳税人免征增值税政策
  • 企业汇算清缴后税务局会不会查
  • 支付银行托管费怎么入账
  • 不能升级win11的二手电脑值得购买吗
  • qq能上,网页打不开怎么回事
  • 小规模购进商品只收到记账联专票
  • 子公司转为分公司,是不是需要缴纳土地增值税
  • 微软笔记本
  • 电子商票到期后多少天有效?
  • 土地使用税的税目写什么
  • php简单聊天室源码
  • 一个php请求的执行过程
  • php入门例子
  • 补提去年的所得税费用是怎么做分录?
  • 如何计算企业所得税税负
  • 转让子公司产生的投资收益在合并层面是不是全部抵消
  • 购买商品或服务赠品法律地位
  • 喝薏米红豆水最佳时间
  • 页面白屏可能原因前端
  • 阿根廷圣克鲁斯省
  • 基于thinkphp的cms
  • 财政专户资金是专项资金吗
  • php oracle 连接池
  • 原材料当废品卖出分录
  • vue property decorator
  • 基于51单片机的电子秤设计
  • web课程设计模板
  • php解析xml文件
  • cmd more命令
  • 未分配利润的核算内容
  • 注册新公司怎么办理
  • mysql ndb innodb
  • 计提年终奖的会计分录
  • python中dataframe的布尔过滤
  • 什么是累积优先股
  • 刷pos机的如何记会计分录
  • 福利费为什么通过应付职工薪酬科目要紧吗
  • 交易性金融资产公允价值变动计入
  • 高速公路费如何开票
  • 增值税纳税申报类型有哪些
  • 公司买车可以抵扣企业所得税吗
  • 公司租赁职工车辆账务处理
  • 进口关税征收方法
  • 退回多交的所得税抵欠税怎么做账
  • 如何做好应收应付会计
  • 装修公司预收款要交增值税吗
  • 支付稿费怎么做凭证
  • 工程施工合同如何核算收入成本?
  • 所得税汇算清缴需要调增的项目
  • 开票系统维护费怎么做账
  • 本年负数去年正数如何算同比
  • 在建工程的进项税额不再分2年抵扣
  • 主营业务税金及附加借贷方向
  • 房地产开发成本和房地产开发产品
  • 将SP2整合进Office 2007的安装包中的方法
  • nec笔记本电脑开机屏幕没反应
  • u盘装win8系统教程图解
  • Mac上Parallels Desktop共享虚拟机怎么设置 Mac上Parallels Desktop共享虚拟机设置步
  • ubuntu搜索工具
  • linux 磁带机
  • python urllib urlopen
  • js添加列表项
  • js计数排序
  • 批处理作用
  • flask开发实例
  • unity怎么设置多个关卡
  • javascript零基础入门
  • jquery设置图片路径
  • javascript面向对象编程 PDF
  • 医疗费发票查询
  • 国家税务总局,河北省税务局
  • 溧阳北站规划图
  • 特殊工种作业人员
  • 未办理税务登记取得专票抵扣
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设