亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mysql通過@變量實(shí)現(xiàn)遞歸詳細(xì)實(shí)例

 更新時(shí)間:2023年06月07日 10:34:57   作者:supuerlovepc  
眾所周知目前的mysql版本中并不支持直接的遞歸查詢,下面這篇文章主要給大家介紹了關(guān)于mysql通過@變量實(shí)現(xiàn)遞歸的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

1. 測試表結(jié)構(gòu)

create table demo
(
    id varchar(100) not null
        primary key,
    parentId    varchar(100) not null
);
-- 測試數(shù)據(jù)
INSERT INTO demo (ID, parentID) VALUES ('1', '0');
INSERT INTO demo (ID, parentID) VALUES ('10', '9');
INSERT INTO demo (ID, parentID) VALUES ('11', '9');
INSERT INTO demo (ID, parentID) VALUES ('2', '1');
INSERT INTO demo (ID, parentID) VALUES ('3', '2');
INSERT INTO demo (ID, parentID) VALUES ('4', '3');
INSERT INTO demo (ID, parentID) VALUES ('5', '4');
INSERT INTO demo (ID, parentID) VALUES ('6', '5');
INSERT INTO demo (ID, parentID) VALUES ('7', '6');
INSERT INTO demo (ID, parentID) VALUES ('8', '1');
INSERT INTO demo (ID, parentID) VALUES ('9', '1');

2. 向下遞歸(包括自己)

-- 向下遞歸 par即為遞歸查詢出來的所有id
SELECT
    @par                                                                          AS par,
    (SELECT @par := GROUP_CONCAT(id) FROM demo WHERE FIND_IN_SET(parentid, @par)) AS son
FROM demo_userm, (SELECT @par := '1') T
WHERE @par IS NOT NULL;
查詢結(jié)果:
| par       | son     |
| 1         | 2,8,9   |
| 2,8,9     | 10,11,3 |
| 10 ,11,3  | 4       |
| 4         | 5       |
| 5         | 6       |
| 6         | 7       |
| 7         | NULL    |

3.向下遞歸(不包括自己)

-- 向下遞歸 par即為遞歸查詢出來的所有id
SELECT
    @par                                                                          AS par,
    (SELECT @par := GROUP_CONCAT(id) FROM demo WHERE FIND_IN_SET(parentid, @par)) AS son
FROM demo_userm, (SELECT @par := '1') T
WHERE @par IS NOT NULL and @par != '1';
查詢結(jié)果:
| par       | son     |
| 2,8,9     | 10,11,3 |
| 10 ,11,3  | 4       |
| 4         | 5       |
| 5         | 6       |
| 6         | 7       |
| 7         | NULL    |

4. 向下遞歸可能存在問題,修正優(yōu)化:

-- 如果存在 par = 51016 并且 son = 51016 , 那么會出現(xiàn)問題,多出許多數(shù)據(jù)
SELECT
    @par                                                                          AS par,
    (SELECT @par := GROUP_CONCAT(distinct ORG_REFNO) FROM gis_udp_bank WHERE FIND_IN_SET(PNBRN_ORG_REFNO, @par)) AS son
FROM gis_udp_bank, (SELECT @par := '51016') T
WHERE @par IS NOT NULL;
-- 優(yōu)化后:后面家條件: !FIND_IN_SET(ORG_REFNO, @par)
SELECT
    @par                                                                          AS par,
    (SELECT @par := GROUP_CONCAT(distinct ORG_REFNO) FROM gis_udp_bank WHERE FIND_IN_SET(PNBRN_ORG_REFNO, @par)
        and !FIND_IN_SET(ORG_REFNO, @par)
        ) AS son
FROM gis_udp_bank, (SELECT @par := '51016') T
WHERE @par IS NOT NULL;

5. 向上遞歸

SELECT
    @par                                                                     AS par,
    (SELECT @par := GROUP_CONCAT(NAME) FROM demo_userm WHERE LOGONID = @par) AS son
FROM demo_userm, (SELECT @par := '10') T
WHERE @par IS NOT NULL;
par即為遞歸查詢結(jié)果
查詢結(jié)果:
| par | son |
| 10  | 9   |
| 9   | 1   |
| 1   | 0   |
| 0   | NULL|

所用函數(shù)介紹:

1、GROUP_CONCAT([distinct] colName)

一般用于取ID集合。
select  * from demo_userm t where NAME = 1;
| LOGONID | NAME |
| 2       | 1    |
| 8       | 1    |
| 9       | 1    |
select  GROUP_CONCAT(LOGONID) from demo_userm t where NAME = 1;
| GROUP\_CONCAT\(LOGONID\) |
| 2,8,9 |
-- 不去重取name集合
select  GROUP_CONCAT(NAME) from demo_userm t where NAME in (1,2,3,4,5,6,7);
| GROUP\_CONCAT\(NAME\) |
| 1,2,3,4,5,6,1,1 |
-- 去重再取name集合
select  GROUP_CONCAT(distinct NAME) from demo_userm t where NAME in (1,2,3,4,5,6,7);
| GROUP\_CONCAT\(distinct NAME\) |
| 1,2,3,4,5,6 |

2、FIND_IN_SET(colName, strs)

select * from demo_userm where  FIND_IN_SET(LOGONID, ('1,2,3,4'));
| LOGONID | NAME |
| 1       | 0    |
| 2       | 1    |
| 3       | 2    |
| 4       | 3    |
select * from demo_userm where  
FIND_IN_SET(LOGONID, (select  GROUP_CONCAT(LOGONID) from demo_userm t where NAME = 1));
| LOGONID | NAME |
| 2       | 1    |
| 8       | 1    |
| 9       | 1    |

3、#@是用戶變量,@@是系統(tǒng)變量。

用戶變量賦值有兩種方式: 一種是直接用"=“號,另一種是用”:=“號。

其區(qū)別在于:

使用set命令對用戶變量進(jìn)行賦值時(shí),兩種方式都可以使用; # 用select語句時(shí),只能用”:=“方式,因?yàn)閟elect語句中,”="號被看作是比較操作符。

總結(jié)

到此這篇關(guān)于mysql通過@變量實(shí)現(xiàn)遞歸的文章就介紹到這了,更多相關(guān)mysql @變量實(shí)現(xiàn)遞歸內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論