您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

SQL 关于使用CTE(公用表表达式)的递归查询

2024/6/12 16:10:18发布15次查看
关于使用cte(公用表表达式)的递归查询----sql server 2005及以上版本 公用表表达式 (cte) 具有一个重要的优点,那就是能够引用其自身,从而创建递归 cte。递归 cte 是一个重复执行初始 cte 以返回数据子集直到获取完整结果集的公用表表达式。 当某个查询引用
关于使用cte(公用表表达式)的递归查询----sql server 2005及以上版本
公用表表达式 (cte) 具有一个重要的优点,那就是能够引用其自身,从而创建递归 cte。递归 cte 是一个重复执行初始 cte 以返回数据子集直到获取完整结果集的公用表表达式。
当某个查询引用递归 cte 时,它即被称为递归查询。递归查询通常用于返回分层数据,例如:显示某个组织图中的雇员或物料清单方案(其中父级产品有一个或多个组件,而那些组件可能还有子组件,或者是其他父级产品的组件)中的数据。
递归 cte 可以极大地简化在 select、insert、update、delete 或 create view 语句中运行递归查询所需的代码。在 sql server 的早期版本中,递归查询通常需要使用临时表、游标和逻辑来控制递归步骤流。 
cte 的基本语法结构如下:
) ]as( cte_query_definition )--只有在查询定义中为所有结果列都提供了不同的名称时,列名称列表才是可选的。--运行 cte 的语句为:expression_name;
在使用cte时应注意如下几点:
cte后面必须直接跟使用cte的sql语句(如select、insert、update等),否则,cte将失效。如下面的sql语句将无法正常使用cte:
withcr as(表名 where 条件 )--select * from person.countryregion --如果加上这句话后面用到cr将报错 cr
2. cte后面也可以跟其他的cte,但只能使用一个with,多个cte中间用逗号(,)分隔,如下面的sql语句所示:
withcte1 as(table1 ),cte2 as(table2 where id > 20),cte3 as(table3 where price 100)select a.* from cte1 a, cte2 b, cte3 c where a.id = b.id and a.id = c.id
3. 如果cte的表达式名称与某个数据表或视图重名,香港服务器,则紧跟在该cte后面的sql语句使用的仍然是cte,当然,后面的sql语句使用的就是数据表或视图。
4. cte 可以引用自身,香港服务器,也可以引用在同一 with 子句中预先定义的 cte。
5. 不能在 cte_query_definition 中使用以下子句:
6. 如果将 cte 用在属于批处理的一部分的语句中,那么在它之前的语句必须以分号结尾,如下面的sql所示:
(3); t_tree as(表 where 字段 like @s)t_tree
------------------------------------操作------------------------------------
上面可能对with as说的有点儿啰嗦了,下面进入正题:
老规矩先建表(co_itemnameset):
.(,,(10) collate chinese_prc_ci_as null)
插入数据:
dbo.co_itemnameset ) ) ) ) ) ) ) ) ) ) ) ) ) )
查询插入的数据:
co_itemnameset
结果图:
题目需求是:查询itemid=2及子节点,也就是管理费用和其下属所有节点的信息
操作1:先看看不用cte递归操作的sql语句如下(需要真是的建两个表进行数据的存放和判断,非常麻烦):
;create table #tem(, );create table #list(, ((0)), ((''), );,)select itemid,1from co_itemnameset#list(,,,)select itemid,parentitemid,itemname,1from co_itemnameset() itemid from #tem #tem itemid#tem(,) , co_itemnameset #list(,,,),,, co_itemnameset #list drop table #tem drop table #list
结果图:
操作2:用cte递归操作的sql语句如下:
;)as( co_itemnamesetc.itemid,c.parentitemid,c.itemname,co_itemnameset c inner join co_itemnameset_cte cton c.parentitemid=ct.itemid)co_itemnameset_cte
结果图:
-----------------------------分析(查看msdn的分析)----------------------------
主要分析一下用cte的递归操作:
递归 cte 由下列三个元素组成:
例程的调用。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product