位置: 编程技术 - 正文

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

  • 实际发的工资跟个人所得税不一样
  • 发票开错抬头做红字发票的账务处理
  • 个体工商户税务申报一年几次
  • 职工薪酬实际金额包括发放往年工资吗
  • 商业折扣和现金折扣的入账金额
  • 电子税务局税种核定怎么操作
  • 工商银行资产负债表
  • 收款收据写着投诉有效吗
  • 如何调整其他应付款
  • 关联企业如何取消
  • 银行存款未达账项包括
  • 三证合一后没有去税务局登记会怎么样
  • 试运营和正式运营间隔
  • 税务师几年内考完几门
  • 视同销售如何纳税调整?
  • 企业所得税清算报备是什么意思
  • 电子发票开给个人怎么处理?
  • 怎么判断分红前已提取足够法定公积金?
  • 基本户没开 可以销户吗
  • 跨年的暂估成本怎么冲回
  • 计提个人社保会计分录实操
  • 有什么好方法可以让小孩子少吃糖
  • 销售需要安装的商品,只能在安装和检验完毕后确认收入
  • 六千元左右
  • 废旧物资处理计入什么科目
  • windows 查询进程
  • 农场新区
  • php 读取大excel
  • 金融商品转让业务包括
  • 什么是增值税普票和专票
  • 自然人税收管理系统扣缴客户端app
  • thinkphp框架入门
  • 税务变更登记需要带的资料有哪些
  • 税控盘全额抵扣发票怎么勾选
  • 标书注意事项与如何制作标书
  • 什么是企业的应付账款
  • 工会收取的工会经费应缴纳增值税
  • mongodb快速入门
  • 制作费开票属于什么编码类型
  • 股票股利怎么理解
  • 固定资产折旧方法一经确定不得随意变更
  • 印花税申报怎么更正采集处理
  • 银行承兑汇票是商业汇票吗
  • 金融商品转让一半增值税
  • 付款人和开票人必须相符吗
  • 贷款用途不符合规定有啥危害
  • 如何认定隐匿转移遗产
  • 扣缴个人所得税怎么计算
  • 其他应付为负数什么意思
  • 保证合同的要件
  • 不是公司股东的情况说明模板
  • 支付个人运费没有发票怎么办
  • 园林绿化公司的税率是多少
  • 税控系统维护费可以全额抵扣吗
  • 残疾人保障金的工资按实发还是应发
  • SQL Server"错误 21002: [SQL-DMO]用户 * 已经存在问题解决
  • ubuntu安装指南
  • macbookpro隐藏
  • windows xp 2021 r3
  • Mac上Parallels Desktop共享虚拟机怎么设置 Mac上Parallels Desktop共享虚拟机设置步
  • win8系统崩溃按f8没用
  • 明日之后白树高地怎么钓凤尾鱼
  • 怎样修改linux用户名和密码
  • javascript概述及作用
  • bat脚本延迟执行命令
  • python创建二维数据表
  • Android开发中遇到的问题及解决方案
  • scrapy爬虫教程
  • 慎用是能用还是不能用
  • javascript的对象主要包括
  • 编写一个bash脚本程序,用for循环实现
  • unity做app
  • shell读取文本内容到变量
  • python获取entry里输入的值
  • android documents
  • 广西税务怎么交城乡养老保险
  • 车辆购置税是国家收还是地方收
  • 海南省税务局网站
  • 提租补贴什么标准发放
  • 深圳税局电子税务局
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设