当前位置:   article > 正文

[收藏] 三种 无限级分类 的数据库设计方案(菜单,,权限管理)_数据库无限层级分类设计方案

数据库无限层级分类设计方案

转载 三种 无限级分类 的数据库设计方案

***适合(菜单,,权限管理)的数据库设计***
  • 1

第一种方案:

表为两张,一张分类表,一张信息表。
( 一级分类和二级分类合并成一张表)
在这里插入图片描述

TypeID 指一级二级分类的ID(唯一标识、主键) 序列自增从1开始。

TypeName 指一级二级分类的名字

ParentID 指二级分类所属一级分类TypeID (若为一级分类则填”0”与二级分类加以区分)

countNumber 指一级图书包含二级图书的个数

在这里插入图片描述

数据库查询一级分类信息的SQL

select typeid,typename,parentid,countnumber 
from t_booktype   where parentid='0'
  • 1
  • 2

数据查询二级分类信息(利用表的自连接)

select  child.typeid,child.typename,
child.parentid,child.countnumber 		
from t_booktype child ,t_booktype  parent 
where child.parentid=parent.typeid
  • 1
  • 2
  • 3
  • 4

第二种方案:

设置parentID为varchar类型,将父类id都集中在这个字段里,用符号隔开,比如:1,3,6
这样可以比较容易得到各上级分类的ID,而且在查询分类下的信息的时候,可以使用如:Select * From information Where cID Like “1,3%”。不过在添加分类和转移分类的时候操作将非常麻烦。

以上两种方案地址:http://search.phpres.com/phpres-top2007,98552.html

第三种方案:

每级分类递增两位数字,这样,每级分类的数目限定在100个之间,分类方法主要为编码法;
示例:
一级分类:01,02,03
二级分类:0101,0102,0103,0201,0202…
三级分类:010101,010102,010103,010104…
(但这样,怎么分二三级菜单??额外的判断?有电麻烦)

数据库查询时使用 like '01%'就可得到一级分类01下的所有子分类,非常方便!
如果要列出所有分类的树型结构,只需用一条语句select * from pro_class order by code,再稍微处理一下就可。(其中,pro_class为产品分类表,code为类别编码)。

设计的数据库结构如下:

id: 类别id,主键
classname: 类名
classcode: 类别编码
parent: 父id
left_child: 最左孩子id(或第一个孩子)
right_sibling: 右兄弟id
layer: 层级(第一级类别为1,第2级类别2,以此类推)

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/2023面试高手/article/detail/686005
推荐阅读
相关标签
  

闽ICP备14008679号