中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mysql怎么查詢上下級機構

發布時間:2022-04-20 17:11:41 來源:億速云 閱讀:136 作者:zzz 欄目:開發技術

這篇文章主要講解了“mysql怎么查詢上下級機構”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“mysql怎么查詢上下級機構”吧!

思路:

  • 自定義mysql方法

  • 利用mysql中的【FIND_IN_SET】【group_concat】兩個方法

(1)準備測試數據表

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');

(2)查詢指定機構的所有下級機構(包括自身)

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 $$

測試結果:

mysql怎么查詢上下級機構

(3)查詢指定機構的所有上級機構(包括自身)

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怎么查詢上下級機構”的內容了,經過本文的學習后,相信大家對mysql怎么查詢上下級機構這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

沁源县| 平度市| 荣成市| 藁城市| 正镶白旗| 汽车| 临沂市| 山丹县| 平南县| 辛集市| 景德镇市| 淳化县| 九台市| 邹城市| 前郭尔| 绍兴县| 寿光市| 东安县| 资中县| 资源县| 武宣县| 尉氏县| 夏津县| 含山县| 梨树县| 宁城县| 莒南县| 怀来县| 陆良县| 城口县| 泰安市| 津南区| 韶山市| 大石桥市| 中西区| 夹江县| 搜索| 茶陵县| 梓潼县| 洮南市| 邵东县|