您好,登錄后才能下訂單哦!
這篇文章主要講解了“mysql怎么查詢上下級機構”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“mysql怎么查詢上下級機構”吧!
自定義mysql方法
利用mysql中的【FIND_IN_SET】【group_concat】兩個方法
CREATE TABLE `org_test` ( `org_no` varchar(32) NOT NULL COMMENT '機構編號', `org_name` varchar(200) NOT NULL COMMENT '機構名稱', `p_org_no` varchar(32) DEFAULT NULL COMMENT '上級機構編號', PRIMARY KEY (`org_no`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
測試數據
INSERT INTO `org_test` VALUES ('1001', '福建省', null); INSERT INTO `org_test` VALUES ('100101', '廈門市', '1001'); INSERT INTO `org_test` VALUES ('10010101', '思明區', '100101'); INSERT INTO `org_test` VALUES ('10010102', '湖里區', '100101'); INSERT INTO `org_test` VALUES ('10010103', '同安區', '100101'); INSERT INTO `org_test` VALUES ('100102', '福州市', '1001');
delimiter $$ CREATE FUNCTION getOrgChild (orgNo varchar(32)) RETURNS varchar(1000) CHARSET utf8 BEGIN -- 定義臨時變量 DECLARE tmpOrg varchar(1000) DEFAULT ''; -- 循環查詢,orgNo不為空,則循環 WHILE orgNo IS NOT NULL DO -- 拼接所有查詢結果 IF tmpOrg = '' THEN SET tmpOrg = CONCAT(tmpOrg, orgNo); ELSE SET tmpOrg = CONCAT(tmpOrg, ',', orgNo); END IF; -- 查詢數據 SELECT group_concat(org_no) INTO orgNo FROM org_test WHERE FIND_IN_SET(p_org_no, orgNo) > 0; END WHILE; -- 返回結果 RETURN tmpOrg; END $$
測試結果:
delimiter $$ CREATE FUNCTION getOrgParent (orgNo varchar(32)) RETURNS varchar(1000) CHARSET utf8 BEGIN -- 定義臨時變量 DECLARE tmpOrg varchar(1000) DEFAULT ''; -- 循環查詢,orgNo不為空,則循環 WHILE orgNo IS NOT NULL DO -- 拼接所有查詢結果 IF tmpOrg = '' THEN SET tmpOrg = CONCAT(tmpOrg, orgNo); ELSE SET tmpOrg = CONCAT(tmpOrg, ',', orgNo); END IF; -- 查詢數據 SELECT group_concat(p_org_no) INTO orgNo FROM org_test WHERE FIND_IN_SET(org_no, orgNo) > 0; END WHILE; -- 返回結果 RETURN tmpOrg; END $$
測試結果:
感謝各位的閱讀,以上就是“mysql怎么查詢上下級機構”的內容了,經過本文的學習后,相信大家對mysql怎么查詢上下級機構這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。