灯火互联
管理员
管理员
  • 注册日期2011-07-27
  • 发帖数41778
  • QQ
  • 火币41290枚
  • 粉丝1086
  • 关注100
  • 终身成就奖
  • 最爱沙发
  • 忠实会员
  • 灌水天才奖
  • 贴图大师奖
  • 原创先锋奖
  • 特殊贡献奖
  • 宣传大使奖
  • 优秀斑竹奖
  • 社区明星
阅读:3519回复:0

[SQL Server]试下SQL2005 Common Table Expressions(CET)递归

楼主#
更多 发布于:2012-12-13 15:04


试下SQL2005 Common Table Expressions(CET)递归

已经有很多朋友分享过了,自己亲身操作过,随便记录下来是给自己备忘,
以后用到时不用乱找。

图片:20121212014219165.jpg



WITH cet_depart
AS
(
   SELECT depart_id, depart_name FROM dbo.Depart
   WHERE depart_id = '004'    --入口
   UNION ALL    --递归时必要
   SELECT d.depart_id, d.depart_name FROM  depart d INNER JOIN cet_departc
   ON CAST (c.depart_id AS INT) = d.upper_depart_id  --递归条件
)

SELECT * FROM cet_depart
OPTION (MAXRECURSION 20)    --最大递归次数

结果集:  

图片:20121212014220606.jpg



喜欢0 评分0
游客

返回顶部