管理表格 行业资料 企业战略 企业文化 物流采购 职业经理人 成功激励 管理工具 管理制度 服装行业 商业计划书 可行性报告 影楼经营 幼儿园管理 超市管理
  • 2012mysql递归查询_(doc 9页) 下载

  • 17374次
  • 名称:2012mysql递归查询_(doc 9页)
  • 类型:生活百科
  • 大小:7.00 KB
  • 更新时间:05-02 20:38:17
  • 下载次数:7379
  • 语言:简体中文
  • 推荐度:
  • 上传会员ID:22916623
《2012mysql递归查询_(doc 9页)》下载简介

在Oracle 中我们知道有一个 Hierarchical Queries 通过CONNECT BY 我们可以方便的查了所有当前节点下的所有子节点。但很遗憾,在MySQL的目前版本中还没有对应的功能。
 
在MySQL中如果是有限的层次,比如我们事先如果可以确定这个树的最大深度是4, 那么所有节点为根的树的深度均不会超过4,则我们可以直接通过left join 来实现。
 
但很多时候我们无法控制树的深度。这时就需要在MySQL中用存储过程来实现或在你的程序中来实现这个递归。本文讨论一下几种实现的方法。
 
样例数据:

mysql> create table treeNodes
    -> (
    ->  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)
树形图如下

 1:A
  +-- 2:B
  |    +-- 4:D
  |    +-- 5:E
  +-- 3:C
       +-- 6:F
            +-- 7:G
 8:H
  +-- 9:I
  |    +-- 12:L
  |    |    +--14:N
  |    |    +--15:O
  |    |        +--16:P
  |    |        +--17:Q
  |    +-- 13:M
  +-- 10:J
  +-- 11:K  
 
方法一:利用函数来得到所有子节点号。
创建一个function getChildLst, 得到一个由所有子节点号组成的字符串. 

mysql> delimiter //
mysql>
mysql> CREATE FUNCTION `getChildLst`(rootId INT)
    -> RETURNS varchar(1000)
    -> BEGIN
    ->   DECLARE sTemp VARCHAR(1000);
    ->   DECLARE sTempChd VARCHAR(1000);
    ->
 




……………………

本站免费提供《2012mysql递归查询_(doc 9页)》下载,我们己经对《2012mysql递归查询_(doc 9页)》进行全面的整理检查,以保证您安全的下载《2012mysql递归查询_(doc 9页)》,本站还有更多房地产资料提供下载,为下次能方便快速的找到本站,记得收藏我们的网址(http://www.liushuye.com)哦!

下载地址
下载分类导航
热门下载排行