树的表结构应该怎么设计?请给点建议

ZengXi 2003-02-16 05:06:42
比如
node
child
child
child
child
...
child
...
child
...
node
child
child
...
层次无限(至少是很大)
对应这样的数据结构应该如何设计表以及如何查询比较好呢?
是用一张表还是多表?
谢谢
...全文
24 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
milchcow 2003-02-17
  • 打赏
  • 举报
回复
TABLE( ID,parentID,NAME)

当为根结点时,将PARENTID设为一个固定值,如“0”
happydreamer 2003-02-16
  • 打赏
  • 举报
回复
table(son_id,parent_id,name)---这个方法比较好

or

table
id name
001 省级总公司
001001 市级公司1
001002 市级公司2
001003 市级公司3
001001001 市级1下面有县级1
001002001 市级2下面有县级1
001002002 市级2下面有县级2

abcddcba 2003-02-16
  • 打赏
  • 举报
回复
create table tree ( node int, child int, weight int)
pengdali 2003-02-16
  • 打赏
  • 举报
回复
declare @a table (TC_Id int,TC_PID int,TC_Name varchar(200))
insert @a values(1,0,'中国')
insert @a values(2,0,'美国')
insert @a values(3,0,'加拿大')
insert @a values(4,1,'北京')
insert @a values(5,1,'上海')
insert @a values(6,1,'江苏')
insert @a values(7,6,'苏州')
insert @a values(8,7,'常熟')
insert @a values(9,6,'南京')
insert @a values(10,6,'无锡')
insert @a values(11,2,'纽约')
insert @a values(12,2,'旧金山')

declare @tmp1 table (TC_Id int,TC_PID int,TC_Name varchar(200),lev int)
insert @tmp1 select *,1 from @a where tc_ID=1
while exists(select 1 from @a a,@tmp1 b where a.tc_pid=b.tc_ID and a.tc_ID not in (select tc_ID from @tmp1))
insert @tmp1 select a.*,1 from @a a,@tmp1 b where a.tc_pid=b.tc_ID and a.tc_ID not in (select tc_ID from @tmp1)
select * from @tmp1

22,207

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧