Mybatis 之级联查询 一对多配置
Mybatis级联 查询相对于hibenate是有点麻烦,但是相应好处也是有的,Mybatis轻量、根据自己要的字段配置方便
一对多配置用 <collection property="bean里面的对象集合" column="一对多的外键" select="一对多 中的‘多’ sql语句id"></collection>
多对一配置 <association property="user" javaType="User"> 配置需要的字段</association >
一对多配置
bean实体类
/**
* 用户信息表 bean
* @author flm
* @date 2017年7月27日
*/
public class UserBean implements Serializable{ private static final long serialVersionUID = 4581502828662200769L; private Integer id; //用户ID
private String loginName; //登录名称
private Integer sex; //性别
private String phone; //手机号码
private String address; //住址
private Integer u_identity;//身份 1 厂家 2 经销商 3用户
private Integer u_last_id; //上一级用户id
private String loginPwd; // 登录密码 public List<UserBean> userBeans =new ArrayList<UserBean>(); // userBeans List集合 应用于 一对多查询
// (本类比较特殊 一对多也是自己userBean) }
mapxml文件
<mapper namespace="com.ifengSearch.user.dao.UserDao"> <!-- 结构Map配置 -->
<resultMap id="UserMap" type="com.ifengSearch.user.entity.UserBean" >
<id column="id" property="id" javaType="Integer" jdbcType="INTEGER" />
<result column="loginName" property="loginName" javaType="String" jdbcType="VARCHAR" />
<result column="sex" property="sex" javaType="Integer" jdbcType="INTEGER" />
<result column="phone" property="phone" javaType="String" jdbcType="VARCHAR" />
<result column="address" property="address" javaType="String" jdbcType="VARCHAR" />
<result column="u_identity" property="u_identity" javaType="Integer" jdbcType="INTEGER" />
<result column="u_last_id" property="u_last_id" javaType="Integer" jdbcType="INTEGER" />
<result column="loginPwd" property="loginPwd" javaType="String" jdbcType="VARCHAR" />
</resultMap> <!-- === userBean 一 对多查询关联 (本类比较特殊 一对多也是自己userBean) === -->
<resultMap id="getlist" type="com.ifengSearch.user.entity.UserBean" >
<!-- 实体类属性对应数据库的主键字段,不然主键会查不到 主键 id -->
<id property="id" column="id" javaType="Integer" jdbcType="INTEGER" /> <!-- 用collection标签 ,也是实体类属性要对应数据库字段 -->
<!-- userBeans 对应的是 userBean实体类配置的集合 column="id" 是对应主键一对多的关联的外键 -->
<!-- select="com.ifengSearch.user.dao.UserDao.getUser" getUser一对多查询的sql语句 id ‘多’查询userBeans查询集合 -->
<collection property="userBeans" column="id" select="com.ifengSearch.user.dao.UserDao.getUser">
</collection>
</resultMap> <!-- 根据 一对多 中的 ‘多’查询 userBeans查询集合 -->
<select id="getUser" resultMap="UserMap" parameterType="Integer">
select * from user_info where u_last_id = #{id};
</select>
<!-- getlist 一对多 中的‘一’ 查询 -->
<select id="selectAll" resultMap="getlist">
select * from user_info where id=#{id}
</select>
dao层调用
package com.ifengSearch.user.dao; import java.util.List; import org.apache.ibatis.annotations.Param;
import org.springframework.stereotype.Repository; import com.ifengSearch.user.entity.UserBean; /**
* 用户 dao层
* @author flm
* @date 2017年7月27日
*/ @Repository
public interface UserDao {
/**
* 一对多查询 user
* @return
*/
public List<UserBean> selectAll();
}
然后就可以获取到 一对多的集合了
多对一 相对应来说比较简单
直接配置就可以了
<resultMap id="resultUserOhter" type="Uother">
<id column="id" property="id" />
<result column="other" property="other" />
<association property="user" javaType="User">
<id column="id" property="id" />
<result column="name" property="name" />
<result column="info" property="info" />
</association>
</resultMap>
<select id="getUserOhters" parameterType="int" resultMap="resultUserOhter">
select
user.id,user.name,user.info,uother.id,uother.ohter from uother,user
where user.id=uother.user_id
</select>
也可以参考 http://www.cnblogs.com/hq233/p/6752335.html
Mybatis 之级联查询 一对多配置的更多相关文章
- mybatis ---- 级联查询 一对多 (集合映射)
关联有嵌套查询和嵌套结果两种方式,本文是按照嵌套结果这种方式来说明的 上一章介绍了多对一的关系,用到了<association></association>,这是一个复杂类型的 ...
- mybatis ----数据级联查询(多对一)
工程的目录结构: 有两个表,一个文章表article ,一个用户表user. create table article (id int(11) not null auto_increment, use ...
- LayUI table表格控件 如何显示 对象中的属性(针对Mybatis的级联查询--一对一情况)
1.entity如下: 2.Mybatis的Mapper.xml文件如下 <resultMap id="BaseResultMapPlus" type="dicIt ...
- mybatis关于级联查询结果集嵌套映射对象非列表的处理问题
工作中遇到这么一个问题,嵌套查询,返回json的时候,作为属性,deviceFields是一个device中的一个对象属性,在json返回的时候想要得到的应该是deviceFields:{ 具体属性} ...
- Mybatis夺标关联查询一对多实例
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC " ...
- Mybatis 级联查询 (一对多 )
后台系统中 涉及到添加试卷 问题 答案的一个模块的.我需要通过试卷 查询出所有的试题,以及试题的答案.这个主要要使用到Mybatis的级联查询. 通过试卷 查询出与该试卷相关的试题(一对多),查询出试 ...
- Mybatis中使用级联查询,一对多的查询
一.需求描述 自己在开发一个小程序的过程中,需要做的一个查询是稍微比较复杂的查询,根据用户信息去查询用户所对应的宠物信息. 一个用户可能对应多个宠物,所以在用户和宠物信息的对应关系就是一对多的关系. ...
- MyBatis之级联——一对多关系
上次我们讲到了MyBatis的一对一关系的表示,简单回顾一下一对一关系就是一个学生只有一个学生证.那么什么是一对多关系呢?一个学生有多个课程这就是一对多的关系.我们结合上一章中的学生和学生证,在此基础 ...
- mybatis的一对一,一对多查询,延迟加载,缓存介绍
一对一查询 需求 查询订单信息关联查询用户信息 sql语句 /*通过orders关联查询用户使用user_id一个外键,只能关联查询出一条用户记录就可以使用内连接*/ SELECT orders.*, ...
随机推荐
- java_==和equal方法
java测试两个变量是否相等有两种方式: 一种是利用"=="运算符 值和对象的判断 一种是利用equals()方法 只是值的判断 1.如果两个变量是基本类型变量,且都是数值类型(不 ...
- Python使用openpyxl读写excel文件
Python使用openpyxl读写excel文件 这是一个第三方库,可以处理xlsx格式的Excel文件.pip install openpyxl安装.如果使用Aanconda,应该自带了. 读取E ...
- nessus重置密码
许久不用的nessus密码居然忘记了,查了下: cmd下进入到nessus的安装目录 提升为管理员,登录系统 如果想用之前的账号,可以直接在系统内重置密码.
- Cocoapods 应用第二部分-私有库相关
我们在这里,使用的是 第一部分使用pod lib create YohunlUtilsPod 创建的framework工程来说明.其创建过程在此就不重复了,当然你也可以下载我已经创建好的demo ht ...
- hdu--5351--MZL's Border
表示看这篇博客后找到了思路: http://blog.csdn.net/queuelovestack/article/details/47291195 补充一下数据,方便观察规律 m LBorder ...
- 605. Can Place Flowers种花问题【leetcode】
Suppose you have a long flowerbed in which some of the plots are planted and some are not. However, ...
- Struts2框架入门
1.1 Struts2概述: 是一个遵循WEB层规范的MVC设实现,该框架基本上借鉴了WebWork框架的体系结构,只吸收了少部分Struts1的优点.是目前JAVA EE项目中WEB层事实上的工业标 ...
- position属性absolute和relative理解
relative:相对于自身静态位置进行定位,不脱离流. absolute:绝对定位,脱离流,如果父元素定义了position属性,无论是absolute.relative还是fixed,都是相对于父 ...
- Struts2之初识
Struts2教程 第一章 初识Struts2 主页:http://struts.apache.org/ 优势:用户请求,模块处理,页面展现.适用于企业级开发,便于维护. 配置:web.xml中添加的 ...
- iOS 工程自动化 - 思路整理
4 月份参加 2017@Swift 大会的时候有幸听到了 @zesming 大佬关于美团组件化的 Topic,有一张图印象特别深刻. 来自 @zesming 大佬 后来跟 @zesming 大佬沟通怎 ...