数据库设计:此处将章课节所有信息存放到一张表中,可递归查询。最上一级章的parentid是教材的id。故给一个教材id便可以查找到其下所有的章课节信息。...二、解决 已设置的我们这里不讨论,只需要到库中查询对应的章课节即可。...那么对于默认第一章第一课第一节,我们这里使用一个递归函数将查询的结果存放到一个list中 /*** 根据给定的id,查询其下的第一课、第一节(不只适用于章课节三级,如果下面还有级别的目录,也可查 * *...= null) { list.add(c); getSubChapter(c.getId(), list);//递归查询 } } }catch(Exception e) { logger.error...(e.getMessage(),e); } } 递归查询的特点:函数方法自己掉用自己,通过某个条件判断跳出最后一个被调用的递归方法。
insert t_test VALUES(9,7,"解放西路"); insert t_test VALUES(10,8,"朝阳北路"); SELECT * FROM t_test; 测试数据展示 查询...id=1,查询中国下边有哪些地方 SELECT ID.LEVEL, DATA.* FROM ( SELECT @ids AS _ids, ( SELECT @ids := GROUP_CONCAT..._ids ) ORDER BY LEVEL id=3,查询山西下边有哪些地方 SELECT ID.LEVEL, DATA.* FROM ( SELECT @ids AS _ids..._ids ) ORDER BY LEVEL id=4,查询北京下边有哪些地方 最后再从 id=2 华北地区往下查询
from MEUM_TEST t --where t.org_level=4 start with parent_id=0 connect by prior t.cid=t.parent_id; 查找单个节点的根...对于节点间的父子关系,prior运算符在一侧表示父节点,在另一侧表示子节点,从而确定查找树结构是的顺序是自顶向下还是自底向上。在连接关系中,除了可以使用列名外,还允许使用列表达式。...start with子句为可选项,用来标识哪个节点作为查找树型结构的根节点。若该子句被省略,则表示所有满足查询条件的行作为根节点。
privatevoid treeView1_AfterCheck(object sender, TreeViewEventArgs e) { if (e.Act...
递归查询父节点 和子节点 包含mysql 递归查询父节点 和子节点 mysql递归查询,查父集合,查子集合 查子集合 –drop FUNCTION `getChildList` CREATE FUNCTION...在My … MySQL递归查询树状表的子节点、父节点具体实现 mysql版本(5.5.6等等)尚未支持循环递归查询,和sqlserver.oracle相比,mysql难于在树状表中层层遍历的子节点.本程序重点参考了下面的资料...,写了两个sql存储过程,子节点查询算 … 递归的实际业务场景之MySQL 递归查询 喜欢就点个赞呗!...` varchar(32) DEFAUL … MySQL递归查询树状表的子节点、父节点 表结构和表数据就不公示了,查询的表user_role,主键是id,每条记录有parentid字段; 如下mysql...查询函数即可实现根据一个节点查询所有的子节点,根据一个子节点查询所有的父节点.对于数据 … mysql 递归查询 主要是对于层级关系的查询 最近遇到了一个问题,在mysql中如何完成节点下的所有节点或节点上的所有父节点的查询
父子查询: 根据父 id 查询下面所有子节点数据;子父查询: 根据子 id 查询上面所有父节点数据;...————mysql递归查询 目录结构: 创建表并添加测试数据 创建表 添加数据 根据父id递归查询所有子节点 创建函数 根据函数查询 根据子id递归查询所有父节点 写sql语句 根据组织机构名称模糊查询所有父节点...根据子id递归查询所有父节点 根据子id查询父节点就不那么麻烦了,不需要写递归函数,当然,你也可以写递归函数来查询。..._id = T2.id ORDER BY id; 注意:大家看到那个10000了吗,就是我们的子节点id。 注意:只支持单个查询,意思是不可以根据两个或者两个以上的子节点同时查询出所有父节点。...西面提供一个函数支持多个查询 根据组织机构名称模糊查询所有父节点 该功能常用于组织机构模糊搜索 创建函数 CREATE FUNCTION getParentOrgByOrgName(orgName
3、mysql查询语句可以查询出父级目录信息: 注意:自己的数据表表名称,切记手动修改,字段名称(特别注意id,parent_id字段名称,不然肯定查询不出来的)。..._id = T2.id 13 ORDER BY T1.lvl DESC 查询实例如下所示: ? ...4、然后使用ajax来传递id的值,最后展示出来查询出来的名称即可: 1 //查询目录 2 function findByDirectory(id){ 3 var url = 'cateLogAction
对于树结构的查询,在oracle数据库中有现成的函数直接调用,但是在mysql中这部分没有现成的函数可以直接调用,对于树形结构的递归遍历在实际业务中也是非常常见的。...本小节做一个记录 向下递归查询 SELECT ID.LEVEL, DATA.* FROM ( SELECT @ids AS _ids, ( SELECT @ids := GROUP_CONCAT...( id ) FROM 表名 WHERE FIND_IN_SET( 父级 id字段, @ids ) ) AS cids, @l := @l + 1 AS LEVEL FROM 表名, (..._ids ) ORDER BY LEVEL, id 向上递归 SELECT GROUP_CONCAT( s.name SEPARATOR "," ) FROM ( SELECT T2.
mysql版本:8.0.32 对于 MySQL 8.0 及以上版本,递归查询可以通过 WITH RECURSIVE 语法实现。...FROM employees e INNER JOIN subordinates s ON e.manager_id = s.id ) SELECT * FROM subordinates; 对于 MySQL...5.x 版本,可使用存储过程递归调用实现。
最近在做项目迁移,Oracle版本的迁到Mysql版本,遇到有些oracle的函数,mysql并没有,所以就只好想自定义函数或者找到替换函数的方法进行改造。...Oracle递归查询 oracle实现递归查询的话,就可以使用start with … connect by connect by递归查询基本语法是: select 1 from 表格 start with...... connect by prior id = pId start with:表示以什么为根节点,不加限制可以写1=1,要以id为123的节点为根节点,就写为start with id =123...或者直接start with 1=1不加限制 prior:prior关键字可以放在等号的前面,也可以放在等号的后面,表示的意义是不一样的,比如 prior id = pid,就表示pid就是这条记录的根节点了...递归查询 下面主要介绍Mysql方面的实现,Mysql并没有提供类似函数,所以只能通过自定义函数实现,网上很多这种资料,不过已经不知道那篇是原创了,这篇博客写的不错,https://www.2cto.com
之前一直用的是Oracle,对于树形查询可以使用start with ... connect by select * from menu start with id='130000' connect...by id = prior parent_id; 没错,这是Oracle所支持的 现在公司用的是mysql,对于这种查询方式只能通过sql语句实现了 语言都是相通的,何况sql呢 mysql随没有自带的语法支持...,不过可以通过创建函数来实现递归查询。 ...(pid,ctemp)>0; END WHILE; RETURN ptemp; END$$ DELIMITER ; OK,查询可以通过将函数当做一个查询条件
最近在做项目迁移,Oracle版本的迁到MySQL版本,遇到有些Oracle的函数,MySQL并没有,所以就只好想自定义函数或者找到替换函数的方法进行改造。...Oracle递归查询 oracle实现递归查询的话,就可以使用start with ... connect by connect by递归查询基本语法是: select 1 from 表格 start...with ... connect by prior id = pId start with:表示以什么为根节点,不加限制可以写1=1,要以id为123的节点为根节点,就写为start with id =...或者直接start with 1=1不加限制 prior:prior关键字可以放在等号的前面,也可以放在等号的后面,表示的意义是不一样的,比如 prior id = pid,就表示pid就是这条记录的根节点了...递归查询 下面主要介绍Mysql方面的实现,Mysql并没有提供类似函数,所以只能通过自定义函数实现,网上很多这种资料,不过已经不知道那篇是原创了,这篇博客写的不错,https://www.2cto.com
之前一直用的是Oracle,对于树形查询可以使用start with ... connect by select * from menu start with id='130000' connect...by id = prior parent_id; 没错,这是Oracle所支持的 现在公司用的是mysql,对于这种查询方式只能通过sql语句实现了 语言都是相通的,何况sql呢 mysql随没有自带的语法支持...,不过可以通过创建函数来实现递归查询。 ...(pid,ctemp)>0; END WHILE; RETURN ptemp; END$$ DELIMITER ; OK,查询可以通过将函数当做一个查询条件...SELECT * FROM nodelist WHERE FIND_IN_SET(id, getChild(3)) 上面难度相对比较大,再补充一个简单的自连接查询 SELECT t1.id,t1.nodecontent
MySQL复杂查询使用实例 By:授客 表结构设计 SELECT id, `name`, parent_id FROM `tb_testcase_suite` ?...说明: parent_id值关联表自身id列的值,如果其值为-1,则表示该记录不存在父级记录,否则表示该记录存在父级记录(假设parent_id值为5,则父级记录id为5),暂且把该记录自身称之为子记录...,父级及父父级的记录称之为祖先记录,子级及子子级记录称之为后辈记录 查询需求 1) 根据指定记录的id,查询该记录关联的所有祖先记录,并按层级返回祖先记录name 2) 根据指定parent_id,查询其关联的的所有后辈记录...id 查询实现 通过函数调用实现 1)根据指定记录的id,查询该记录关联的所有祖先记录,并按层级返回祖先记录name # 向下递归 DROP FUNCTION IF EXISTS queryChildrenSuiteIds...2)根据指定parent_id,查询其关联的的所有后辈记录id # 向上递归 DROP FUNCTION IF EXISTS querySuitePath; DELIMITER ;; CREATE FUNCTION
-----------------来自小马哥的故事 ---- 所周知,目前的mysql版本中并不支持直接的递归查询,但是通过递归到迭代转化的思路,还是可以在一句SQL内实现树的递归查询的。...这个得益于Mysql允许在SQL语句内使用@变量。以下是示例代码。...创建表格 CREATE TABLE `treenodes` ( `id` int , -- 节点ID `nodename` varchar (60), -- 节点名称 `pid` int -...- 节点父ID ); 插入测试数据 INSERT INTO `treenodes` (`id`, `nodename`, `pid`) VALUES ('1','A','0'),('2','B','1...的递归查询的实现全过程,希望对大家的学习有所帮助。
1.前言 大家在用mysql递归查询的时候,肯定或多或少的会碰到一些问题,像小编就遇到了天大的坑(如下图),于是自己踩了坑,我得想办法把它铺一铺吖,避免大家也同时遇到这样的问题。...相信很多人都用不惯mysql,小编也是,oracle的递归查询很简单。...就一句sql就可以搞定,还有不清楚或者突然忘记需要温习的小伙伴们,大家可以看小编发的以前的关于oracle递归查询的方法,戳这里:【oracle递归查询方法介绍】 ---- 2.踩坑介绍 mysql递归查询...②递归父节点 那么接下来的递归所有的父节点,也是同样的道理, 咱们先创建辅助函数getParList(), CREATE FUNCTION `getParList`(rootId INT) RETURNS...4.总结 上面这些,就是小编在用mysql递归查询遇到的坑,如果你还没有遇到,恭喜你,看完这篇文章可以避免踩坑了,但是记得点个赞吖。哈哈哈哈哈。
--查询ID = '009'的所有父节点 SET @ID = '009' ;WITH T AS ( SELECT ID , PID , NAME FROM TB WHERE ID = @ID...') insert into tb values('009' , '007' , '龙华镇') insert into tb values('010' , '007' , '松岗镇') go --查询各节点的父路径函数...',' + @re_str from tb a , tb b where a.id = @id and a.pid = b.id end return @re_str end go --查询各节点的父路径函数...(从子到父) create function f_pid2(@id varchar(3)) returns varchar(100) as begin declare @re_str as varchar...return @re_str end go select * , dbo.f_pid1(id) [路径(从父到子)] , dbo.f_pid2(id) [路径(从子到父)
08.19自我总结 js|jq获取兄弟节点,父节点,子节点 一.js var parent = test.parentNode; // 父节点 var chils = test.childNodes;...// 全部子节点 var first = test.firstChild; // 第一个子节点 var last = test.lastChile; // 最后一个子节点 var previous =...; // 父节点元素 var first = test.firstElementChild; // 第一个子节点元素 var last = test.lastElementChile; // 最后一个子节点...注意操作父来控制子必须给子元素赋予一个变量 二.jq $("#test1").parent(); // 父节点 $("#test1").parents(); // 全部父节点 $("#test1")....").prevAll(); // 之前所有兄弟节点 $("#test1").next(); // 下一个兄弟节点 $("#test1").nextAll(); // 之后所有兄弟节点 $("#test1
递归获取所有子节点测试用例: /** * 获取子级ids,含自己 * @param id 父节点 * @param TaxBureauList 组织单位列表 *...Object>> TaxBureauList) { for (Map bureau : TaxBureauList) { //过滤父节点为空的数据...bureau.get("id").toString(), childIds, TaxBureauList); } } return; } 递归获取所有父节点测试用例...Override public List queryParentIds(String id, List taxCompanyList) { //递归获取父级...this.getParentTaxCompanyIds(taxCompanyList, id, parentIds); return parentIds; } /** * 递归获取父级
领取专属 10元无门槛券
手把手带您无忧上云