位置: 编程技术 - 正文

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

  • 房地产企业的样板房费用计入哪个科目
  • 增值税的免税项目有哪些
  • 费用多报销了,但已经给了,怎么办
  • 发票专用章和财务章区别
  • 无票收入应该怎么做
  • 承兑找零怎么做账务处理
  • 建筑 分包
  • 收到的增值税
  • 公司亏损多久可以申请解散
  • 行政单位暂付款怎么记账
  • 住宿发票抵扣怎么做账
  • 支出没有发票怎么做账
  • 公司股权转移怎么办理
  • 收取线路维护费合法吗
  • 新办企业地税要备案吗
  • 房地产开发企业应交税费科目
  • 小规模纳税人季报还是月报?
  • 个人所得税有哪几种
  • 个人所得税app入职时间不对
  • 小微企业所得税减免政策2023
  • 形式发票需要报关吗
  • 企业资产损失会计处理
  • 固定资产出租收入属于其他业务收入吗
  • 增值税留抵税额会计科目
  • 员工有多处收入怎么申报个人所得税
  • doc文档隐藏
  • swstrtr.exe - swstrtr是什么进程
  • 流动资产周转率计算公式
  • 小规模纳税人开票限额是多少
  • 电脑桌面图标如何更改自定义图片
  • linux禁止ip访问80端口
  • osXYosemite怎么更新
  • 如何设置win10电脑开机不黑屏
  • 正常运行英文
  • 冲减其他应收款需要领导审批吗
  • 对公帐户收款
  • 购货方获得现金折扣的会计分录怎么写
  • PHP:imagettfbbox()的用法_GD库图像处理函数
  • PHP:zip_entry_read()的用法_Zip函数
  • 坎塔布莱恩
  • wordpress用什么语言编写
  • 建筑安装收入会计分录
  • resnet+unet
  • 文化体育用品批发城有哪些
  • 预收账款包括哪些内容具体明细
  • python中insert函数怎么用
  • 13个点的普票可以抵税吗
  • mysql事务类型
  • 计提法定盈余公积是什么意思
  • 收外汇是一定要交税吗
  • 销售自己使用过的物品免税吗
  • 盈余公积提取是什么意思
  • 残疾人保障金为负数
  • 用友结算成本处理在哪里
  • 商场联营方案
  • 暂估金额与发票金额的区别
  • 支票存根联可以涂改吗
  • 建筑业外包工程包括哪些
  • 用SQL脚本读取Excel中的sheet数量及名称的方法代码
  • Linux下安装mysql-5.6.12-linux-glibc2.5-x86_64.tar.gz
  • centos怎么设置
  • w10语言栏
  • linux系统配置命令
  • win7如何新建用户
  • winxp鼠标右键菜单栏怎么改
  • win8应用商店废了
  • 详解linux中systemd命令的运行级别与其常见应用
  • unity性能优化工具
  • jquery密码验证
  • js的settimeout方法
  • shell while 小于
  • bat 远程连接
  • go 与 python
  • node.js gui
  • js相等和全等
  • package.json里面的配置
  • python压缩文件为gz
  • javascript身份证号验证
  • 重庆税务登录
  • 个人所得税的通知
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设