注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

北漂的小羊

Java编程,开发者,程序员,软件开发,编程,代码。新浪微博号:IT国子监

 
 
 

日志

 
 
关于我

在这里是面向程序员的高品质IT技术学习社区,是程序员学习成长的地方。让我们更好地用技术改变世界。请关注新浪微博号: IT国子监(http://weibo.com/itguozijian)

网易考拉推荐

sql 递归查询备忘  

2012-10-27 18:18:43|  分类: SQL Server |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

数据库表结构:
sql 递归查询备忘 - 天涯草 - 天涯草
 
 
sql语句:
(获取四级类别)
select distinct *  from 
(select *  from LEVEL_INFO where LEVEL_INFO.id='1' union  
select n2.* from LEVEL_INFO n1,LEVEL_INFO n2 where n1.id='1' and n2.parentid=n1.id 
union 
select n3.* from LEVEL_INFO n3,( 
select n2.* from LEVEL_INFO n1,LEVEL_INFO n2 where n1.id='1' and n2.parentid=n1.id) t2 where t2.id=n3.parentid 
union 
select n4.* from LEVEL_INFO n4,( 
select n3.* from LEVEL_INFO n2,LEVEL_INFO n3 where n2.parentid='1' and n3.parentid=n2.id) t3 where t3.id=n4.parentid 
) a


接下来从网上找到了一个获取五级的方法:
  1. select distinct *  
  2.   from (select *  
  3.           from news_types  
  4.          where news_types.id = 1  
  5.         union  
  6.         select n2.*  
  7.           from news_types n1, news_types n2  
  8.          where n1.id = 1  
  9.            and n2.parentid = n1.id  
  10.         union  
  11.         select n3.*  
  12.           from news_types n3,  
  13.                (select n2.*  
  14.                   from news_types n1, news_types n2  
  15.                  where n1.id = 1  
  16.                    and n2.parentid = n1.id) t2  
  17.          where t2.id = n3.parentid  
  18.         union  
  19.         select n4.*  
  20.           from news_types n4,  
  21.                (select n3.*  
  22.                   from news_types n3,  
  23.                        (select n2.*  
  24.                           from news_types n1, news_types n2  
  25.                          where n1.id = 1  
  26.                            and n2.parentid = n1.id) t2  
  27.                  where t2.id = n3.parentid) t3  
  28.          where t3.id = n4.parentid  
  29.         union  
  30.         select n5.*  
  31.           from news_types n5,  
  32.                (select n4.*  
  33.                   from news_types n4,  
  34.                        (select n3.*  
  35.                           from news_types n3,  
  36.                                (select n2.*  
  37.                                   from news_types n1, news_types n2  
  38.                                  where n1.id = 1  
  39.                                    and n2.parentid = n1.id) t2  
  40.                          where t2.id = n3.parentid) t3  
  41.                  where t3.id = n4.parentid) t4  
  42.          where t4.id = n5.parentid  
  43.         ) a; 


  评论这张
 
阅读(184)| 评论(1)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2016