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 之级联查询 一对多配置的更多相关文章

  1. mybatis ---- 级联查询 一对多 (集合映射)

    关联有嵌套查询和嵌套结果两种方式,本文是按照嵌套结果这种方式来说明的 上一章介绍了多对一的关系,用到了<association></association>,这是一个复杂类型的 ...

  2. mybatis ----数据级联查询(多对一)

    工程的目录结构: 有两个表,一个文章表article ,一个用户表user. create table article (id int(11) not null auto_increment, use ...

  3. LayUI table表格控件 如何显示 对象中的属性(针对Mybatis的级联查询--一对一情况)

    1.entity如下: 2.Mybatis的Mapper.xml文件如下 <resultMap id="BaseResultMapPlus" type="dicIt ...

  4. mybatis关于级联查询结果集嵌套映射对象非列表的处理问题

    工作中遇到这么一个问题,嵌套查询,返回json的时候,作为属性,deviceFields是一个device中的一个对象属性,在json返回的时候想要得到的应该是deviceFields:{ 具体属性} ...

  5. Mybatis夺标关联查询一对多实例

    <?xml version="1.0" encoding="UTF-8" ?>  <!DOCTYPE mapper PUBLIC " ...

  6. Mybatis 级联查询 (一对多 )

    后台系统中 涉及到添加试卷 问题 答案的一个模块的.我需要通过试卷 查询出所有的试题,以及试题的答案.这个主要要使用到Mybatis的级联查询. 通过试卷 查询出与该试卷相关的试题(一对多),查询出试 ...

  7. Mybatis中使用级联查询,一对多的查询

    一.需求描述 自己在开发一个小程序的过程中,需要做的一个查询是稍微比较复杂的查询,根据用户信息去查询用户所对应的宠物信息. 一个用户可能对应多个宠物,所以在用户和宠物信息的对应关系就是一对多的关系. ...

  8. MyBatis之级联——一对多关系

    上次我们讲到了MyBatis的一对一关系的表示,简单回顾一下一对一关系就是一个学生只有一个学生证.那么什么是一对多关系呢?一个学生有多个课程这就是一对多的关系.我们结合上一章中的学生和学生证,在此基础 ...

  9. mybatis的一对一,一对多查询,延迟加载,缓存介绍

    一对一查询 需求 查询订单信息关联查询用户信息 sql语句 /*通过orders关联查询用户使用user_id一个外键,只能关联查询出一条用户记录就可以使用内连接*/ SELECT orders.*, ...

随机推荐

  1. Linux修改网卡名称、主机名

    Linux修改网卡名称.主机名 环境:VirtualBox 5.0.14 + RHEL 6.5 需求:个人实验搭建一套Standby RAC时,为了节约时间,直接复制之前安装RAC的主机模板. 但复制 ...

  2. java反射机制(1)

      百度百科: java 反射机制:JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意方法和属性:这种动态获取信息以及动态调用对象方 ...

  3. 微信客户端+微信公众平台+新浪云SAE+Arduino+WS100(控制LED)

    第一步:准备 1.智能手机微信客户端或微信电脑版 2.注册微信公众平台 https://mp.weixin.qq.com 3.注册新浪账号 http://www.sinacloud.com 4.拥有一 ...

  4. 纯JS实现像素逐渐显示

    就是对于新手的我,以前从来没有做过对像素进行操作的实例.于是把资料书找了出来,实现了这个功能,比较简单,大神勿喷.下面是效果图,因为重在思路,效果就简陋一些. 其实就是简单的用JS实现将左上角的矩形随 ...

  5. kafka在windows下的安装和配置

    博主最近在学习有关kafka的配置安装以及在spring的集成使用.但网上关于kafka的配置参考资料基本都是于linux下的配置,于是博主在整理了相关windows下kafka的配置记录在博客里.由 ...

  6. 使用DbFunctions来解决EF按照日期分组数据

    如下一张表 要进行MyDate的date部分进行分组,我们会发现如下写法会报异常 那么如何才能使linq正确转化为sql语句呢,这就要使用到了DbFunctions这个工具类 转到定义可以看到此类在e ...

  7. SVN 、Git、Github的使用

    1.1 SVN 总结以及使用建议 每一次保存历史记录实际上就是一次提交 什么时候去保存历史记录? 完成了一个具体的功能模块 代码运行没有bug 当天工作结束提交一次 没有 bug 的前提下去提交一次 ...

  8. iOS绘图框架CoreGraphics分析

    由于CoreGraphics框架有太多的API,对于初次接触或者对该框架不是十分了解的人,在绘图时,对API的选择会感到有些迷茫,甚至会觉得iOS的图形绘制有些繁琐.因此,本文主要介绍一下iOS的绘图 ...

  9. HTTP协议发展介绍

    HTTP协议工作于C/S架构上,是万维网服务器传输超文本到本地客户端的一种应用层协议,全称是:Hyper Text Transfer Protocol(超文本传输协议),HTTP是基于TCP/IP通信 ...

  10. java之生成可重复执行的sql脚本

    在实际项目开发过程中,sql脚本需要多次执行.而一般的DML和DDL语句一般只能执行一次,再次执行执行时就会报错(操作对应已存在/不存在),所以必须将sql脚本生成可重复执行的.本文共分为4部分:1. ...