Today's harvest !!!
今天将Mybatis的视频看到了第60集,其之前讲解了自表的主外键查询.
例如一个新闻表中,有一级栏目,二级栏目,三级栏目,其中二级栏目的pid为一级栏目的id,如此种种.
而今天做的小项目中使用了 easyui 这个前端框架来做后端数据的解析.
看了下SpringBoot入门以及IDEA创建SpringBoot项目.
SpringBoot又把SSM框架简化了.
MyBatis的自表分层查询很简单.

如上表, 在id 1 上是name: 娱乐新闻, 其pid为0. 表示这是第一级栏目.
之后看看pid为1的 港台明星和内地影视, 这是二级栏目. 同样 pid 为 2 的NBA和CBA是二级栏目,
三级栏目的话是它的上级还有上级,例如火箭,湖人,它们pid为3,而 id 为 3 的是NBA, NBA的pid为 2. 而2已经是最上层栏目.
(将这种分层栏目利用继承去理解更好理解,而一般网站构建中适度分层,三层就可以了.)

基本测试用的分层结构
beans中的新闻实体:
package com.ykmimi.beans;
/*
* 新闻栏目:当前的新闻栏目被看作是一方,即父栏目
*/ import java.util.Set; public class NewsLabel {
private Integer id;
private String name;//栏目名称 //子栏目
private Set<NewsLabel> children;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Set<NewsLabel> getChildren() {
return children;
}
public void setChildren(Set<NewsLabel> children) {
this.children = children;
}
@Override
public String toString() {
return "NewsLabel>> id:"+id+",name:"+name+",children:"+children;
}
}
之后分别是dao的接口和mapper.xml
package com.ykmimi.dao;
import java.util.List;
import com.ykmimi.beans.NewsLabel;
public interface INewsLabelDao {
List<NewsLabel> selectChildrenByParent(int pid);
}
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper SYSTEM "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.ykmimi.dao.INewsLabelDao">
<!--
<select id="" resultMap="NewsLabelMapper">
select id,name from newslabel where pid = #{ news_id }
</select>
-->
<resultMap type="NewsLabel" id="NewsLabelMapper">
<id column="id" property="id"/>
<result column="name" property="name"/>
<collection property="children"
ofType="NewsLabel"
select="selectChildrenByParent"
column="id"/>
</resultMap> <select id="selectChildrenByParent" resultMap="NewsLabelMapper">
select id,name from newslabel where pid = #{ news_id }
</select> </mapper>
最重要的就是mapper中的设置,其resultMap中的collection的column="id"其实是调用了自身的查询到的id.并一直递归查询直到查询到null
当传入参数2. 其查询pid为2的两个数据库元组,查询到后,继续执行该select语句,此时获取到的id又成为了参数进行了查询.
最终获得:
NewsLabel>> id:3,name:NBA,children:[NewsLabel>> id:6,name:湖人,children:[], NewsLabel>> id:5,name:火箭,children:[]]
NewsLabel>> id:4,name:CBA,children:[NewsLabel>> id:7,name:北京金隅,children:[], NewsLabel>> id:8,name:浙江广厦,children:[], NewsLabel>> id:9,name:青岛双星,children:[]]
-----------------------------------------下面是返回一个对象,该对象封装了多个表数据的自查询形式
同样的项目构建,实体类做了变更:
package com.ykmimi.beans;
/*
* 新闻栏目:当前的新闻栏目被看作是一方,即父栏目
*/ public class NewsLabel {
private Integer id;
private String name;//栏目名称 //父栏目
private NewsLabel parent; public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public NewsLabel getParent() {
return parent;
}
public void setParent(NewsLabel parent) {
this.parent = parent;
} @Override
public String toString() { return "newslabel->:"+id+","+name+","+">>"+"parent:"+parent;
} }
dao接口的方法:
//查询指定栏目及其所有子孙栏目
NewsLabel selectNewsLabelById(int id);
并且mapper.xml的方法更改了:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper SYSTEM "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.ykmimi.dao.INewsLabelDao"> <!-- ↓查询所有的内容包括父栏目 TotalNewsLabelMapper--> <resultMap type="NewsLabel" id="TotalNewsLabelMapper">
<id column="id" property="id"/>
<result column="name" property="name"/>
<association property="parent"
javaType="NewsLabel"
select="selectNewsLabelById"
column="pid"/> </resultMap> <select id="selectNewsLabelById" resultMap="TotalNewsLabelMapper">
select id,name,pid from newslabel where id = #{ get_id }
</select> </mapper>
@Test
public void test02() {
NewsLabel newslabel = dao.selectNewsLabelById(7);
System.out.println(newslabel);
}
结果为:自身及父栏目实例
newslabel->:7,北京金隅,>>parent:newslabel->:4,CBA,>>parent:newslabel->:2,体育新闻,>>parent:null
待更 自查询 多对一
Today's harvest !!!的更多相关文章
- hdu多校第4场 B Harvest of Apples(莫队)
Problem B. Harvest of Apples Time Limit: / MS (Java/Others) Memory Limit: / K (Java/Others) Total Su ...
- HDU 6333 Harvest of Apples (分块、数论)
题目连接:Harvest of Apples 题意:给出一个n和m,求C(0,n)+C(1,n)+.....+C(m,n).(样例组数为1e5) 题解:首先先把阶乘和逆元预处理出来,这样就可O(1)将 ...
- 2018 Multi-University Training Contest 4 Problem B. Harvest of Apples 【莫队+排列组合+逆元预处理技巧】
任意门:http://acm.hdu.edu.cn/showproblem.php?pid=6333 Problem B. Harvest of Apples Time Limit: 4000/200 ...
- HDU 6333.Problem B. Harvest of Apples-组合数C(n,0)到C(n,m)求和-组合数学(逆元)+莫队 ((2018 Multi-University Training Contest 4 1002))
2018 Multi-University Training Contest 4 6333.Problem B. Harvest of Apples 题意很好懂,就是组合数求和. 官方题解: 我来叨叨 ...
- Harvest of Apples
问题 B: Harvest of Apples 时间限制: 1 Sec 内存限制: 128 MB提交: 18 解决: 11[提交] [状态] [讨论版] [命题人:admin] 题目描述 Ther ...
- hdu6333 Harvest of Apples 离线+分块+组合数学(求组合数模板)
Problem B. Harvest of Apples Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K ...
- hdu6333 Problem B. Harvest of Apples(组合数+莫队)
hdu6333 Problem B. Harvest of Apples 题目传送门 题意: 求(0,n)~(m,n)组合数之和 题解: C(n,m)=C(n-1,m-1)+C(n-1,m) 设 ...
- 2018年多校第四场第二题 B. Harvest of Apples hdu6333
题意:给定10^5以内的n,m求∑组合数(n,i),共10^5组数据. 题解: 定义 S(n, m) = \sum_{i = 0} ^ {m} {n \choose i}S(n,m)=∑i=0m ...
- HDU6333 Harvest of Apples (杭电多校4B)
这莫队太强啦 先推公式S(n,m)表示从C(n, 0) 到 C(n, m)的总和 1.S(n, m) = S(n, m-1) + C(n, m) 这个直接可以转移得到 2.S(n, m) = ...
- Problem B. Harvest of Apples HDU - 6333(莫队)
Problem Description There are n apples on a tree, numbered from 1 to n.Count the number of ways to p ...
随机推荐
- JavaWeb温习之HttpServletResquest对象
HttpServletRequest对象代表客户端的请求,当客户端通过HTTP协议访问服务器时,HTTP请求头中的所有信息都封装在这个对象中,通过这个对象提供的方法,可以获得客户端请求的所有信息. 1 ...
- 关于PreparedStatement.addBatch()方法 (转)
Statement和PreparedStatement的区别就不多废话了,直接说PreparedStatement最重要的addbatch()结构的使用. 1.建立链接,(打电话拨号 ) Connec ...
- luogu P1379 八数码难题(A*算法入门详细讲解)
代码实现细节 #include<cstdio> #include<cstring> #include<iostream> using namespace std; ...
- CRUX下实现进程隐藏(3)
通过一个内核模块拦截文件系统的回调函数来实现进程隐藏. VFS(Virtual File System)是Linux在实际文件系统(如ext3,ext4,vfat等)上抽象出的一个文件系统模型,简单来 ...
- 【BZOJ4423】[AMPPZ2013]Bytehattan 对偶图+并查集
[BZOJ4423][AMPPZ2013]Bytehattan Description 比特哈顿镇有n*n个格点,形成了一个网格图.一开始整张图是完整的.有k次操作,每次会删掉图中的一条边(u,v), ...
- Oracle AWR 之 通过dbms_workload_repository.awr_report_text(html)函数在客户端生成AWR报告
1.概述 一般情况下,awr报告都是通过在oracle服务器的sqlplus窗口调用$ORACLE_HOME/rdbms/admin/awrrpt.sql脚本生成报告.方法如下: [oracle@lo ...
- (ubuntu ufw)My firewall is blocking network connections from the docker container to outside
Maybe this is due to the current version, but the current answer doesn't work on my system (Docker 0 ...
- 前端~HTML~CSS~JavaScript~JQuery~Vue
HTML CSS JavaScript DOM文档操作 jQuery实例 Vue
- BBS - 预备知识
一.中介模型 四个项目: 苑昊 博客(BBS) (7-8) CRM 1.权限组件 (3) 2.start组件 -- admin (5) 1.使用 2.源码 django 源码 (面向对象) 以源码为导 ...
- 安装Ruby、Sass在WebStrom添加Watcher实现编辑scss文件时自动生成.map和压缩后的.css文件
前言 这段时间一直在看Bootstrap,V3官方直接提供了Less版本的源码,就先将Less学完了,很简单的语法,学习写Demo都是在Webstorm里写的,配置了Watcher自动编译(详见< ...