亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

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

福清市| 宁德市| 哈密市| 河南省| 肇庆市| 嘉禾县| 抚远县| 基隆市| 张家界市| 惠来县| 庄河市| 马尔康县| 金坛市| 保山市| 巴林右旗| 合山市| 游戏| 洪湖市| 富顺县| 台南县| 额敏县| 明水县| 舞钢市| 巴南区| 正安县| 呈贡县| 安康市| 凭祥市| 普陀区| 长治县| 西昌市| 洛宁县| 鲜城| 尼玛县| 麻阳| 冷水江市| 滕州市| 康平县| 旺苍县| 胶州市| 潞西市|