有些同仁对于 JeeSite 4 中的树表设计不太了解,本应简单的方法就可实现,却写了很多复杂的语句和代码,所以有了这篇文章。
在 JeeSite 4 中的树表设计我还是相对满意的,这种设计比较容易理解,不会太依赖数据库的语法,对兼容多数据库比较好。相比网上大牛的左右值树设计简单了很多,并且可随时调换父节点,并级联更新所有子节点数据。
看下表字段说明我们发现除了父级节点外又多了很多辅助字段,这写字段的维护可能会稍微影响我们的插入和更新性能, 但是这将极大的简化了我们的查询,并不限深度。废话不多说,下面我们一同来就来看看都有哪些好处。
树表字段说明
字段名 | 说明 |
---|---|
xxx_code | 节点编码(xxx表示用户自定义名称) |
xxx_name | 节点名称(xxx表示用户自定义名称) |
以下是树表关键字段: | |
parent_code | 节点上级编码 |
parent_codes | 节点所有上级编码(快速检索下级节点) |
tree_sort | 当前层级排序号(decimal类型) |
tree_sorts | 树节点的完整排序号,10位数字组成(快速整树排序) |
tree_leaf | 是否是末级,是否叶子节点(0:否,1:是,char类型) |
tree_level | 节点层次级别(从0开始,decimal类型,快速分级查询,根据层级缩进) |
tree_names | 节点的全名称(用“/”分隔,快速获取当前节点完整路径) |
以下是树表可选字段: | |
status | 节点状态(0:正常,1:删除,2:停用) |
create_by | 创建者用户编码 |
create_date | 数据创建时间 |
update_by | 更新者用户编码 |
update_date | 数据更新时间 |
下面以区域树表举例
定义实体Entity
用户自定义的节点编码是area_code