网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

mysql怎么看递归,mysql支持递归查询吗

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’

自己仿照这看一下!

mysql如何递归汇总?

单表自身关联查询,关联条件就是父节点pcode和code相等,查询字段包含pcode和sorce,将查询结果作为新表按pcode分组,用group by,查询字段是count记录数,这样就获取pcode的节点值,这是整体思路

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://bjjierui.cn/article/dssohhi.html

其他资讯