EaBIM一直以来积极响应国家“十二五”推进建筑业信息化的号召,对建筑领域的信息技术开展深入技术交流和探讨!致力于打造“BIM-建筑师-生态技术”三位一体综合资源交流共享平台,希望为BIM与可持续设计理念及技术的普及做出微小的贡献!!!

EaBIM

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

搜索
查看: 8007|回复: 211
打印 上一主题 下一主题

[数据库程序设计] 各式各样的 无限级分类 的数据库设计方案

[复制链接]

1514

主题

7465

帖子

1万

积分

admin

Rank: 10Rank: 10Rank: 10Rank: 10Rank: 10Rank: 10Rank: 10Rank: 10Rank: 10Rank: 10

积分
12404

社区QQ达人

跳转到指定楼层
楼主
发表于 2014-1-9 15:22:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

第一种方案:
表为两张,一张分类表,一张信息表。
表1:
`ID` int(10),
`cID` tinyint(3) ,
`title` varchar(255),
表2:
`cID` tinyint(3) ,
`parentID` tinyint(3),  
`order` tinyint(3) ,
`name` varchar(255),
这样可以根据cID = parentID来判断上一级内容,运用递归至最顶层 。
第二种方案:
设置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,以此类推)

以上三种的缺点?优点?还有其它方案吗?

回复: [收集] 各式各样的 无限级分类 的数据库设计方案 wuxudong 回复于 2009-04-05 16:55
还有一个方案:
分类等价于一棵树, 每个节点增加两个属性: left, right.
然后按逆时针方向遍历整个树, 按遍历顺序给left,right赋值。
对这样的一颗树, 所有 left < node.left & right > node.right 的就是node的 祖先节点


回复: [收集] 各式各样的 无限级分类 的数据库设计方案 红薯 回复于 2009-04-06 07:56
第三种方案并不能做无限级分类!!
第二种方案完全违反数据库设计范式
其实分类表一个就足以表达无限级的父子节点关系,就是通过增加一个父节点编号,但要便利一个树出来可能需要的查询太多了,解决的办法就是一次性把这张表全load出来,然后在程序里运算得到想要的树状结构。

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
收藏收藏 转播转播 分享分享 分享淘帖 支持支持 反对反对
工作时间:工作日的9:00-12:00/13:30-18:00,节假日不在线,请勿留言

1514

主题

7465

帖子

1万

积分

admin

Rank: 10Rank: 10Rank: 10Rank: 10Rank: 10Rank: 10Rank: 10Rank: 10Rank: 10Rank: 10

积分
12404

社区QQ达人

推荐
 楼主| 发表于 2014-8-11 09:42:29 | 只看该作者
顶楼主,帮你顶起来
工作时间:工作日的9:00-12:00/13:30-18:00,节假日不在线,请勿留言
推荐
发表于 2016-1-21 09:15:48 | 只看该作者

很不错,支持一下。

5

主题

851

帖子

1342

积分

BIM经理

Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6

积分
1342
4F
发表于 2014-3-12 15:08:37 | 只看该作者
路过!!!
不发表意见……

0

主题

843

帖子

1280

积分

BIM经理

Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6

积分
1280
5F
发表于 2014-4-23 11:58:30 | 只看该作者
(*^__^*) 嘻嘻……

8

主题

843

帖子

1340

积分

BIM经理

Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6

积分
1340
8F
发表于 2014-5-21 14:50:24 | 只看该作者
顶......
楼下跟上.....

0

主题

843

帖子

1280

积分

BIM经理

Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6

积分
1280
10F
发表于 2014-5-23 17:06:15 | 只看该作者
路过!!!
不发表意见……

12

主题

854

帖子

1923

积分

BIM经理

Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6

积分
1923
12F
发表于 2014-6-6 11:49:09 | 只看该作者
(*^__^*) 嘻嘻……

12

主题

221

帖子

549

积分

BIM专业负责人

Rank: 4Rank: 4Rank: 4Rank: 4

积分
549

社区QQ达人

14F
发表于 2014-6-16 12:12:45 | 只看该作者
可以 学习下

19

主题

878

帖子

1359

积分

BIM经理

Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6

积分
1359
16F
发表于 2014-7-21 16:05:51 | 只看该作者
顶......
楼下跟上.....
*滑块验证:
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|EaBIM网 ( 苏ICP备2020058923号-1  苏公网安备32011502011255号

GMT+8, 2024-11-23 10:22

Powered by Discuz! X3.2 Licensed

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表