迭代查询

元数据:

迭代查询:

CREATE FUNCTION `vendor_area_child`(rootId INT)
 RETURNS varchar(1000)
BEGIN 
       DECLARE pTemp VARCHAR(1000);  
       DECLARE cTemp VARCHAR(1000);  
       DECLARE nTemp VARCHAR(1000);
      
       SET pTemp = '$';  
       SET cTemp =cast(rootId as CHAR);  
       
       WHILE cTemp is not null DO  
         SET pTemp = concat(pTemp,',',cTemp); 

         SELECT group_concat(id) INTO cTemp
                        FROM pd_vendor_area WHERE FIND_IN_SET(parent_id,cTemp)>0; 
       END WHILE;  

       SELECT group_concat(area_name) INTO nTemp
                        FROM pd_vendor_area WHERE FIND_IN_SET(parent_id,pTemp)>0; 
       RETURN nTemp;  
END;

SELECT
    a.id,
    a.area_name,
    a.chi
FROM
    (
        SELECT
            id,
            area_name,
            vendor_area_child (id) AS chi
        FROM
            pd_vendor_area
        WHERE
            area_type = 1
    ) a
WHERE
    a.chi LIKE '%广州小区%';

转载于:https://www.cnblogs.com/wanhua-wu/p/6119504.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle 迭代查询通常使用递归查询实现。递归查询是一种查询技术,它允许您编写一个查询来引用自身,以便在查询结果中包含递归层次结构。 以下是一个简单的例子,展示如何使用递归查询在 Oracle 中实现迭代查询: 假设我们有一个包含部门和员工的表,其中每个员工都属于一个部门,并且每个部门都可以有多个子部门。我们想要查询一个特定部门及其所有子部门中的所有员工。 首先,我们需要创建一个包含递归查询的 SQL 语句。该查询应该包括以下内容: 1. 基本查询,用于从根部门开始查找所有子部门。 2. 递归查询,用于从每个子部门开始查找更多子部门。 以下是一个示例查询: ``` WITH dept_tree AS ( SELECT department_id, department_name, parent_department_id FROM departments WHERE department_id = :dept_id UNION ALL SELECT d.department_id, d.department_name, d.parent_department_id FROM departments d JOIN dept_tree dt ON d.parent_department_id = dt.department_id ) SELECT e.employee_id, e.employee_name FROM employees e JOIN dept_tree dt ON e.department_id = dt.department_id; ``` 在此查询中,我们首先选择指定的根部门(由 :dept_id 参数指定)。然后,我们使用 UNION ALL 运算符来执行递归查询,该查询从每个子部门开始查找更多子部门。最后,我们加入员工表,以便仅显示属于所选部门及其所有子部门的员工。 请注意,此查询使用 WITH 语句来创建一个临时表(dept_tree),该表用于存储递归查询的结果。这个表与查询主体一起使用,以便我们可以在查询中引用递归结果。 要运行此查询,请将 :dept_id 替换为所需的根部门 ID,并在 Oracle SQL Developer 或其他 SQL 工具中运行查询。结果将包括所选部门及其所有子部门的所有员工。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值