老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業提供網站建設、域名注冊、服務器等服務

mysql怎么查找遞歸 mysql有遞歸函數嗎

mysql怎么實現遞歸查詢數據

mysql create table treeNodes

創新互聯建站網絡公司擁有10多年的成都網站開發建設經驗,上千多家客戶的共同信賴。提供網站制作、網站建設、網站開發、網站定制、買友情鏈接、建網站、網站搭建、成都響應式網站建設、網頁設計師打造企業風格,提供周到的售前咨詢和貼心的售后服務

- (

- id int primary key,

- nodename varchar(20),

- pid int

- );

Query OK, 0 rows affected (0.09 sec)

mysql select * from treenodes;

+----+----------+------+

| id | nodename | pid |

+----+----------+------+

| 1 | A | 0 |

| 2 | B | 1 |

| 3 | C | 1 |

| 4 | D | 2 |

| 5 | E | 2 |

| 6 | F | 3 |

| 7 | G | 6 |

| 8 | H | 0 |

| 9 | I | 8 |

| 10 | J | 8 |

| 11 | K | 8 |

| 12 | L | 9 |

| 13 | M | 9 |

| 14 | N | 12 |

| 15 | O | 12 |

| 16 | P | 15 |

| 17 | Q | 15 |

+----+----------+------+

17 rows in set (0.00 sec)

mysql遞歸查詢語句

mysql遞歸查詢,mysql中從子類ID查詢所有父類(做無限分類經常用到)

由于mysql 不支持類似 oracle with ...connect的 遞歸查詢語法

之前一直以為類似的查詢要么用存儲過程要么只能用程序寫遞歸查詢.

現在發現原來一條sql語句也是可以搞定的

先來看數據表的結構如下:

id name parent_id

---------------------------

1 Home 0

2 About 1

3 Contact 1

4 Legal 2

5 Privacy 4

6 Products 1

7 Support 1

我要的要求是根據一個分類ID(這個分類ID可能是一個子分類),得到所有的父分類,下面是相應的SQL:

SELECT T2.id, T2.name

FROM (

SELECT

@r AS _id,

(SELECT @r := parent_id FROM table1 WHERE id = _id) AS parent_id,

@l := @l + 1 AS lvl

FROM

(SELECT @r := 5, @l := 0) vars,

table1 h

WHERE @r 0) T1

JOIN table1 T2

ON T1._id = T2.id

ORDER BY T1.lvl DESC

代碼@r := 5標示查詢id為5的所有父類。結果如下

1, ‘Home’

2, ‘About’

4, ‘Legal’

5, ‘Privacy’

自己仿照這看一下!

Mysql8.0遞歸函數

一般比較普遍的就是四種方法:(具體見 SQL Anti-patterns這本書)

因為不支持遞歸查詢,所以Mysql官方當時推薦的是第三種方式:Nested Sets。我是用過的,非常難受。現在支持遞歸查詢,我們可以使用第一種。

其實我還用了一種,一列維持順序,一列維持層級,有空可以把實現寫出來看看。

英文好的朋友請移步到這里: Managing Hierarchical Data in MySQL Using the Adjacency List Model ,不好的同學跟我一起來。

直接語句說明:

好,就這些吧。我是姜友華,下次見。

mysql查詢一個表,實現遞歸查詢

給你個網上寫的比較好的例子:

方法一:利用函數來得到所有子節點號。

創建一個function

getChildLst,

得到一個由所有子節點號組成的字符串.

mysql

delimiter

//

mysql

mysql

CREATE

FUNCTION

`getChildLst`(rootId

INT)

-

RETURNS

varchar(1000)

-

BEGIN

-

DECLARE

sTemp

VARCHAR(1000);

-

DECLARE

sTempChd

VARCHAR(1000);

-

-

SET

sTemp

=

'$';

-

SET

sTempChd

=cast(rootId

as

CHAR);

-

-

WHILE

sTempChd

is

not

null

DO

-

SET

sTemp

=

concat(sTemp,',',sTempChd);

-

SELECT

group_concat(id)

INTO

sTempChd

FROM

treeNodes

where

FIND_IN_SET(pid,sTempChd)0;

-

END

WHILE;

-

RETURN

sTemp;

-

END

-

//

Query

OK,

rows

affected

(0.00

sec)

mysql

mysql

delimiter

;

使用我們直接利用find_in_set函數配合這個getChildlst來查找

mysql

select

getChildLst(1);

+-----------------+

|

getChildLst(1)

|

+-----------------+

|

$,1,2,3,4,5,6,7

|

+-----------------+

1

row

in

set

(0.00

sec)

mysql

select

*

from

treeNodes

-

where

FIND_IN_SET(id,

getChildLst(1));

+----+----------+------+

|

id

|

nodename

|

pid

|

+----+----------+------+

|

1

|

A

|

|

|

2

|

B

|

1

|

|

3

|

C

|

1

|

|

4

|

D

|

2

|

|

5

|

E

|

2

|

|

6

|

F

|

3

|

|

7

|

G

|

6

|

+----+----------+------+

7

rows

in

set

(0.01

sec)

mysql

select

*

from

treeNodes

-

where

FIND_IN_SET(id,

getChildLst(3));

+----+----------+------+

|

id

|

nodename

|

pid

|

+----+----------+------+

|

3

|

C

|

1

|

|

6

|

F

|

3

|

|

7

|

G

|

6

|

+----+----------+------+

3

rows

in

set

(0.01

sec)


網頁名稱:mysql怎么查找遞歸 mysql有遞歸函數嗎
轉載注明:http://www.xueling.net.cn/article/dosephs.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 国产在线一区二区三在线 | 欧美激情五月 | 精品无码三级在线观看视频 | 国产精品国产三级国产AV中文 | 麻豆一区二区三区在线观看 | 国产成人高清亚洲明星一区 | 另类内射国产在线 | 天天做天天爱夜夜爽少妇 | 亚洲国产高清在线观看 | 国产精品二区一区二区aⅴ污介绍 | 69av片| 文中字幕一区二区三区视频播放 | 欧美日韩精品一区二区天天拍小说 | 亚洲最新av网址 | 无码粉嫩虎白一线天在线观看 | 色女人天堂 | 日本少妇又色又爽又高潮看你 | 中文字幕制服亚洲另类 | 中文字幕婷婷日韩欧美亚洲 | 18禁网站免费无遮挡无码中文 | 蜜臀亚洲av永久无码精品老司机 | 999精品无码a片在线1级 | 日本国产一区二区三区 | 久久亚洲色WWW成人图片 | 国产亚洲一区二区手机在线观看 | 五月天我淫我色 | 91超碰caoporn97人人 | www.亚洲国产精品 | 天堂成人在线观看 | 91亚洲精品久久久久图片蜜桃 | 国产精品一区二区四区 | 狠狠色噜噜狠狠狠狠2021天天 | 今天高清视频免费播放一级爱片 | 亚洲国产天堂久久综合网 | 成人aa片免费观看视频 | 欧美一区二区观看视频 | 亚洲欧美日韩综合久久久 | 亚洲欧洲精品一区二区 | 一区二区三区四区五区精品 | 国产成人AV在线影院 | 中文精品久久久久鬼色 |