前言:

  Mybatis一对多的处理关系:

一个人有好多本书,每本书的主人只有一个人。当我们查询某个人拥有的所有书籍时,就涉及到了一对多的映射关系。

一、添加数据表:

 CREATE TABLE `book` (
`id` int(6) NOT NULL,
`name` varchar(50) DEFAULT NULL,
`uid` int(6) DEFAULT NULL,
`price` double DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `bu_id` (`uid`),
CONSTRAINT `bu_id` FOREIGN KEY (`uid`) REFERENCES `user` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

二、代码实现:

1.添加Book实体:

 package com.beilin.entity;
/*
* 书的实体
* @author 北林
*
*/ public class Book { private int id;
private int uid;
private String name;
private double price; public int getId() {
return id;
} public void setId(int id) {
this.id = id;
} public int getUid() {
return uid;
} public void setUid(int uid) {
this.uid = uid;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public double getPrice() {
return price;
} public void setPrice(double price) {
this.price = price;
}
}

Book.java

2.在User实体中添加book集合:

 public class User {
/**
* name:学生实体
*/ //主键id
private int id;
//姓名
private String name;
//年龄
private int age;
//添加book集合
private List<Book> books; // Get和 Set方法
public int getId() {
return id;
} public void setId(int id) {
this.id = id;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
} public List<Book> getBooks() {
return books;
} public void setBooks(List<Book> books) {
this.books = books;
}
}

User.java

3.在UserMapper接口中定义查询方法:

 package com.beilin.mapper;

 import com.beilin.entity.User;

 import java.util.List;

 public interface UserMapper {

      //插入
public void insert(User user); //根据id删除
public void delete(Integer id); //根据user的id修改
public void update(User user); //根据id查询
public User getById(Integer id); //查询全部
public List<User> list(); /**
* 根据id查询所有的书
* @param id
*/
public User selectBookById(Integer id); }

UserMapper

4.在mapper映射关系中,添加一对多的select和resaultMap:

注意:当多个表的字段名一样的时候,查询需要用别名

 <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.beilin.mapper.UserMapper"> <!-- 插入一个user -->
<insert id="insert" parameterType="user" useGeneratedKeys="true" keyProperty="id">
insert into user(name,age) values(#{name},#{age})
</insert> <!-- 根据id删除user -->
<delete id="delete" parameterType="int">
delete from user where id=#{id}
</delete> <!-- 根据id修改user信息 -->
<update id="update" parameterType="user">
update user set name=#{name},age=#{age} where id=#{id}
</update> <!-- 根据id查询 -->
<select id="getById" parameterType="int" resultType="user">
select * from user where id=#{id}
</select> <!-- 查询所有 -->
<select id="list" parameterType="int" resultType="user">
select * from user
</select> <resultMap id="bookMap" type="user">
<id property="id" column="id"/>
<result property="name" column="name"/>
<result property="age" column="age"/>
<collection property="books" ofType="book">
<id property="id" column="bid"/>
<result property="name" column="bookName"/>
<result property="price" column="price"/>
</collection>
</resultMap> <!--根据id查询所有的书 -->
<select id="selectBookById" parameterType="int" resultMap="bookMap">
select a.*,b.id bid,b.name as "bookName" ,b.price from user a,book b where a.id=b.uid and a.id=#{id};
</select> </mapper>

UserMapper.xml

5.在UserController中实现查询:

 package com.beilin.controller;

 import com.beilin.entity.Book;
import com.beilin.entity.User;
import com.beilin.mapper.UserMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*; import java.util.List; @RestController
public class UserController { @Autowired
private UserMapper userMapper; //插入user
@RequestMapping("/user")
public void insert( User user) {
userMapper.insert(user);
} //根据id删除
@RequestMapping("/user1/{id}")
public void delete(@PathVariable("id") Integer id) {
userMapper.delete(id);
}
//修改
@RequestMapping("/user2/{id}")
public void update(User user,@PathVariable("id") Integer id) {
userMapper.update(user);
} //根据id查询user
@RequestMapping("/user3/{id}")
public User getById(@PathVariable("id") Integer id) {
User user = userMapper.getById(id);
return user;
} //查询全部
@RequestMapping("/users")
public List<User> list(){
List<User> users = userMapper.list();
return users;
} /**
* 根据id查询所有的书
*/
@GetMapping("/user/book/{id}")
public User getBooks(@PathVariable("id") Integer id){
User user = userMapper.selectBookById(id);
return user;
}
}

UserController.java

三、测试结果:

1.数据库查询结果:

2.postman访问结果:

3.SpringBoot整合Mybatis(一对多)的更多相关文章

  1. SpringBoot整合Mybatis之项目结构、数据源

    已经有好些日子没有总结了,不是变懒了,而是我一直在奋力学习springboot的路上,现在也算是完成了第一阶段的学习,今天给各位总结总结. 之前在网上找过不少关于springboot的教程,都是一些比 ...

  2. SpringBoot整合Mybatis【非注解版】

    接上文:SpringBoot整合Mybatis[注解版] 一.项目创建 新建一个工程 ​ 选择Spring Initializr,配置JDK版本 ​ 输入项目名 ​ 选择构建web项目所需的state ...

  3. SpringBoot整合Mybatis注解版---update出现org.apache.ibatis.binding.BindingException: Parameter 'XXX' not found. Available parameters are [arg1, arg0, param1, param2]

    SpringBoot整合Mybatis注解版---update时出现的问题 问题描述: 1.sql建表语句 DROP TABLE IF EXISTS `department`; CREATE TABL ...

  4. springboot学习随笔(四):Springboot整合mybatis(含generator自动生成代码)

    这章我们将通过springboot整合mybatis来操作数据库 以下内容分为两部分,一部分主要介绍generator自动生成代码,生成model.dao层接口.dao接口对应的sql配置文件 第一部 ...

  5. springboot整合mybatis出现的一些问题

    springboot整合mybatis非常非常的简单,简直简单到发指.但是也有一些坑,这里我会详细的指出会遇到什么问题,并且这些配置的作用 整合mybatis,无疑需要mapper文件,实体类,dao ...

  6. springBoot整合mybatis、jsp 或 HTML

    springBoot整合mybatis.jsp Spring Boot的主要优点: 1:  为所有Spring开发者更快的入门: 2:  开箱即用,提供各种默认配置来简化项目配置: 3:  内嵌式容器 ...

  7. SpringBoot系列七:SpringBoot 整合 MyBatis(配置 druid 数据源、配置 MyBatis、事务控制、druid 监控)

    1.概念:SpringBoot 整合 MyBatis 2.背景 SpringBoot 得到最终效果是一个简化到极致的 WEB 开发,但是只要牵扯到 WEB 开发,就绝对不可能缺少数据层操作,所有的开发 ...

  8. SpringBoot整合Mybatis完整详细版二:注册、登录、拦截器配置

    接着上个章节来,上章节搭建好框架,并且测试也在页面取到数据.接下来实现web端,实现前后端交互,在前台进行注册登录以及后端拦截器配置.实现简单的未登录拦截跳转到登录页面 上一节传送门:SpringBo ...

  9. SpringBoot整合Mybatis完整详细版

    记得刚接触SpringBoot时,大吃一惊,世界上居然还有这么省事的框架,立马感叹:SpringBoot是世界上最好的框架.哈哈! 当初跟着教程练习搭建了一个框架,传送门:spring boot + ...

随机推荐

  1. spark 笔记 4:Apache Hadoop YARN: Yet Another Resource Negotiator

    spark支持YARN做资源调度器,所以YARN的原理还是应该知道的:http://www.socc2013.org/home/program/a5-vavilapalli.pdf    但总体来说, ...

  2. Mybaits 运行原理流程图

  3. 全面解读php-网络协议

    一.OSI七层模型 1.物理层 作用:建立,维护,断开物理连接 2.数据链路层 作用:建立逻辑连接,进行硬件地址寻址,差错校验等功能. 3.网络层 作用:进行逻辑地址寻址,实现不同网络之间的路径选择. ...

  4. python 引流

    Python给抖音自动点赞和评论,实现自动化运营! 都说抖音有毒,一刷就停不下来了.看来抖音这款产品紧紧抓住了人们内心深处的某些需求.当然今天不是来探讨抖音这款产品的啊.今天我们来学习如何用 Pyth ...

  5. 基于form表单的极验滑动验证小案例

    01.目录展示 02.url.py urlpatterns = [ path('admin/', admin.site.urls), path('login/',views.login), path( ...

  6. VirtualBox-5.2.8-121009-Win,虚拟机指令ifconfig不显示ip解决方法

  7. Activity 的 36 大难点,你会几个

    前言 学 Android 有一段时间了,一直都只顾着学新的东西,最近发现很多平常用的少的东西竟让都忘了,趁着这两天,打算把有关 Activity 的内容以问题的形式梳理出来,也供大家查缺补漏. 本文中 ...

  8. python基础-输出

    输出helloworld语句       print('helloworld') 换行操作    print('helloworld',‘hellodarling’)

  9. KinectFusion 介绍

    原文链接 KinectFusion简介 KinectFusion是微软在2011年发表的一篇论文里提到的点云重建的方法,论文题目是:KinectFusion: Real-Time Dense Surf ...

  10. vue --- vscode 配置 .vue文件生成结构

    1.选择“文件 -> 首选项 -> 用户代码片段”,此时,会弹出一个搜索框,输入vue      选择vue后,编辑器会自动打开一个名字为vue.json的文件 2.复制以下内容到这个文件 ...