mybatis一对一,一对多,多对多的关联查询

简介: mybatis一对一,一对多,多对多的关联查询

mybatis中一对一,一对多,多对多的处理:

http://www.cnblogs.com/yaobolove/p/5444046.html


http://www.360doc.com/content/14/0205/21/834950_350059484.shtml


http://www.cnblogs.com/junge/p/5145881.html



一对一: 使用association

<association property="teacher" javaType="Teacher">


一对多和多对多:collection

<collection property="orders" ofType="com.yc.m.Orders">


注意:相同字段要设置别名

如果两表联查,主表和明细表的主键都是id的话,明细表的多条只能查询出来第一条。

级联查询的时候,主表和从表有一样的字段名的时候,在mysql上命令查询是没问题的。

但在mybatis中主从表需要为相同字段名设置别名。设置了别名就OK了。



一对多关联查询示例:一个角色对应多个权限

<resultMap id="rolePowerMap" type="com.lakala.creditloan.manager.model.Role">
     <id column="roleId" property="roleId" jdbcType="INTEGER" />
  <result column="ROLE_NAME" property="roleName" jdbcType="VARCHAR" />
  <result column="rdescri" property="describe" jdbcType="VARCHAR" />
  <collection property="powerlist"  ofType="com.lakala.creditloan.manager.model.Power">
      <id column="powerid" property="id" jdbcType="INTEGER" />
      <result column="POWER_NAME" property="powerName" jdbcType="VARCHAR" />
      <result column="ACTION_URL" property="actionUrl" jdbcType="VARCHAR" />
      <result column="PID" property="pid" jdbcType="INTEGER" />
      <result column="LV" property="lv" jdbcType="INTEGER" />
      <result column="ACTION_TYPE" property="actionType" jdbcType="INTEGER" />
      <result column="pdescri" property="descri" jdbcType="VARCHAR" />
        </collection>
  </resultMap>
<select id="selectByRoleId" parameterType="java.lang.Integer" resultMap="rolePowerMap">
    select r.ID roleId,r.ROLE_NAME,r.DESCRI rdescri,
        p.ID powerid,p.POWER_NAME,p.ACTION_URL,p.ACTION_URL,p.PID,p.LV,p.ACTION_TYPE,p.DESCRI pdescri
    from rcs_role  r 
        left  join rcs_role_power rp on r.id=rp.ROLE_ID 
        left  join rcs_power p on p.ID=rp.POWER_ID  
    where r.ID=#{roleId,jdbcType=INTEGER}
  </select>
目录
相关文章
|
18天前
|
SQL Java 数据库
解决Java Spring Boot应用中MyBatis-Plus查询问题的策略。
保持技能更新是侦探的重要素质。定期回顾最佳实践和新技术。比如,定期查看MyBatis-Plus的更新和社区的最佳做法,这样才能不断提升查询效率和性能。
62 1
|
5月前
|
XML Java 数据库连接
Mybatis一对一,一对多关联查询
## MyBatis一对一、一对多关联查询详解 MyBatis是一款优秀的持久层框架,提供了灵活的SQL映射功能,支持复杂的数据库操作。本文将详细介绍MyBatis中一对一和一对多关联查询的实现。 ### 一对一关联查询 一对一关联关系指的是一个表中的一条记录与另一个表中的一条记录相关联。例如,一个用户有一个地址信息。 #### 数据库表设计 假设有两个表:`user`和 `address`。 ``` CREATE TABLE user ( id INT PRIMARY KEY, name VARCHAR(50) ); CREATE TABLE address
134 18
|
5月前
|
SQL Java 数据库连接
【潜意识Java】MyBatis中的动态SQL灵活、高效的数据库查询以及深度总结
本文详细介绍了MyBatis中的动态SQL功能,涵盖其背景、应用场景及实现方式。
559 6
|
6月前
|
XML Java 数据库连接
Mybatis实现RBAC权限模型查询
通过对RBAC权限模型的理解和MyBatis的灵活使用,我们可以高效地实现复杂的权限管理功能,为应用程序的安全性和可维护性提供有力支持。
159 5
|
3月前
|
XML Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于注解的整合
本文介绍了Spring Boot集成MyBatis的两种方式:基于XML和注解的形式。重点讲解了注解方式,包括@Select、@Insert、@Update、@Delete等常用注解的使用方法,以及多参数时@Param注解的应用。同时,针对字段映射不一致的问题,提供了@Results和@ResultMap的解决方案。文章还提到实际项目中常结合XML与注解的优点,灵活使用两者以提高开发效率,并附带课程源码供下载学习。
80 0
|
5月前
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
215 2
|
8月前
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
318 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
8月前
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
206 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
|
8月前
|
前端开发 Java Apache
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
本文详细讲解了如何整合Apache Shiro与Spring Boot项目,包括数据库准备、项目配置、实体类、Mapper、Service、Controller的创建和配置,以及Shiro的配置和使用。
1825 1
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
|
9月前
|
缓存 前端开发 Java
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
Soring Boot的起步依赖、启动流程、自动装配、常用的注解、Spring MVC的执行流程、对MVC的理解、RestFull风格、为什么service层要写接口、MyBatis的缓存机制、$和#有什么区别、resultType和resultMap区别、cookie和session的区别是什么?session的工作原理
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)