位置: 编程技术 - 正文

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三层架构)

  • 个体户定额超了怎么收费
  • 夏天单位发防暑物品的通知
  • 金税四期上线了吗什么时候上线
  • 费用先付款后收到发票做账
  • 房地产预售啥意思
  • 小企业会计准则2023电子版
  • 收回已冲销的坏账分录
  • 企业劳务外包员工有五险一金吗
  • 回购股份进行股权激励会计分录
  • 收到银行承兑会计分录
  • 变更许可证情况说明书模板
  • 土地储备机构也称为什么
  • 进项票异常如何自查
  • 公司没有员工怎么零申报
  • 小规模免征增值税政策
  • 如何在国税网站下载财务报表
  • 一般纳税人增值税申报操作流程
  • 发票抵扣后对方恶意冲红
  • 运输费未取得运输专用发票怎么抵扣?
  • 公司投资另外一个公司全资占股需要什么流程
  • 预缴企业所得税是含税还是不含税
  • 金蝶采购发票怎么红冲
  • 小规模纳税人如何交增值税
  • 如何正确使用好薪酬调查结果
  • 少数股东持股比例
  • 什么是摊余成本计量的金融资产
  • 工业厂房修建需要哪些手续
  • 增值税专用发票有几联?
  • fpzs1是什么文件可以删除吗
  • 小规模年底税金怎么做账
  • 销售自行开发的房地产
  • 关联方的四种认证方式
  • node安装配置环境变量
  • YOLOv5网络结构组成
  • labview实例教程
  • vue el-tabs
  • source命令怎么用
  • php递归算法经典题目
  • 只有销售才能使你成功的名言
  • 建厂购买材料的会计科目
  • 签劳动合同员工突然离职怎么办
  • 预提费用待摊费用改为什么科目
  • 个税申报的本期收入是应发工资吗
  • discuz怎么使用
  • 帝国cms使用手册
  • 数据库管理中负责数据模式定义的数据库语言是
  • mysql null+1
  • 股权变更后税务登记
  • 收款预缴增值税怎么做账
  • 进料加工转内销会计处理
  • 营改增是从什么时候开始实施的
  • 工会经费教育经费计提比例
  • 发票系统中监控怎么设置
  • 固定资产清理费用账务处理
  • 生产成本比主营业务成本大
  • 待转销项税额对应科目
  • 个体户需要报税吗?需要报哪些税?
  • sql 修改表的字段名称
  • sql server 2000安装好打开不显示名称和服务原因
  • 游戏卡怎么打开
  • windows无法启动wlanautoconfig服务
  • win10正版系统禁止设置密码
  • ubuntu获取当前路径
  • win7系统运行卡怎么办
  • jquery easyui开发指南
  • js怎么检查错误
  • vue缓存数据
  • shell脚本编程100例
  • jquery获取table的tr
  • javascript怎么学
  • 初步了解的英文
  • 税务系统福利
  • 通州区税务局办税大厅电话号码
  • 人工智能在税务领域应用中的风险与规制
  • 上海地铁和公交乘车码
  • 河北华盛税务师事务所
  • 缴纳车辆购置税的会计处理
  • 达州房管局备案查询系统
  • 造纸及纸制品业属于什么行业
  • 普通发票开具时写材料一批需要附什么清单?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设