Ads 4 You

function and procedure MySQL hierarchical recursive query

function and  procedure MySQL hierarchical recursive query

Manage hierarchical data with MySQL stored procedures
Below you will find all code to create the table and the stored procedures to manage hierarchical trees in MySQL.



DELIMITER $$
CREATE DEFINER=`root`@`localhost` FUNCTION `get_emp`(emp_id VARCHAR(255)) RETURNS VARCHAR(255) CHARSET latin1
BEGIN
DECLARE done INT DEFAULT FALSE;
 DECLARE ids INT;
 DECLARE dat VARCHAR(255);
 DECLARE cur CURSOR FOR SELECT id FROM padp WHERE FIND_IN_SET(manager, emp_id);
 DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
 SET dat = '';


    OPEN cur;
 ins_loop: LOOP
            FETCH cur INTO ids;
            IF done THEN
                LEAVE ins_loop;
            END IF;
            SET dat = CONCAT(dat,',',ids);
            END LOOP;            
     CLOSE cur;
       
 RETURN dat;
    END$$




DELIMITER $$

#USE `test`$$

DROP PROCEDURE IF EXISTS `GET_DATA`$$

CREATE DEFINER=`root`@`localhost` PROCEDURE `GET_DATA`(IN emp_id VARCHAR(255))
BEGIN

 DECLARE dat VARCHAR(255);
 SET dat = '';
 ins_loop: LOOP
            SET emp_id = get_emp(emp_id);
            IF emp_id='' THEN          
                LEAVE ins_loop;
            END IF;
            SET dat = CONCAT(dat,emp_id);          
            END LOOP;                                  
    SELECT dat;
END$$

DELIMITER ;


/***
* Table : padp, id,manager
*
* @emp_id = 100
* CALL Procedure
****/
CALL GET_DATA(100);


////
function EDITED ///

BEGIN
DECLARE done INT DEFAULT FALSE;
 DECLARE ids VARCHAR(255);
 DECLARE dat VARCHAR(255);
 DECLARE cur CURSOR FOR SELECT emp_code FROM employee_master WHERE FIND_IN_SET(reporting_manager_id, emp_id);
 DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
 SET dat = '';
 
    OPEN cur;
 ins_loop: LOOP
            FETCH cur INTO ids;
            IF done THEN
                LEAVE ins_loop;
            END IF;
            SET dat = CONCAT(dat,',',ids);
            END LOOP;            
     CLOSE cur;
       
 RETURN dat;
END


//*******
******/

BEGIN

 DECLARE dat VARCHAR(255);
 SET dat = '';
 ins_loop: LOOP
            SET emp_id = getHisReportingEmp(emp_id);
            IF emp_id='' THEN          
                LEAVE ins_loop;
            END IF;
            SET dat = CONCAT(dat,emp_id);          
            END LOOP;                                  
    SELECT dat;
END


/*---------------------------------*/


Comments