时间:2021-05-20
模拟业务关系:
一个用户user有对应的一个公司company,每个用户有多个账户account。
spring boot 2的环境搭建见上文:spring boot 2整合mybatis
一、mysql创表和模拟数据sql
CREATE TABLE IF NOT EXISTS `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(50) NOT NULL, `company_id` int(11) NOT NULL, PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;CREATE TABLE IF NOT EXISTS `company` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(200) NOT NULL, PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;CREATE TABLE IF NOT EXISTS `account` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(200) NOT NULL, `user_id` int(11) NOT NULL, PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;INSERT INTO `user`VALUES (1, 'aa', 1), (2, 'bb', 2);INSERT INTO `company`VALUES (1, 'xx公司'), (2, 'yy公司');INSERT INTO `account`VALUES (1, '中行', 1), (2, '工行', 1), (3, '中行', 2);二、创建实体
public class User { private Integer id; private String name; private Company company; private List<Account> accounts; //getter/setter 这里省略...}public class Company { private Integer id; private String companyName; //getter/setter 这里省略...}public class Account { private Integer id; private String accountName; //getter/setter 这里省略...}三、开发Mapper
方法一:使用注解
1、AccountMapper.java
package com.example.demo.mapper;import java.util.List;import org.apache.ibatis.annotations.Result;import org.apache.ibatis.annotations.Results;import org.apache.ibatis.annotations.Select;import com.example.demo.entity.Account;public interface AccountMapper { /* * 根据用户id查询账户信息 */ @Select("SELECT * FROM `account` WHERE user_id = #{userId}") @Results({ @Result(property = "accountName", column = "name") }) List<Account> getAccountByUserId(Long userId);}2、CompanyMapper.java
package com.example.demo.mapper;import org.apache.ibatis.annotations.Result;import org.apache.ibatis.annotations.Results;import org.apache.ibatis.annotations.Select;import com.example.demo.entity.Company;public interface CompanyMapper { /* * 根据公司id查询公司信息 */ @Select("SELECT * FROM company WHERE id = #{id}") @Results({ @Result(property = "companyName", column = "name") }) Company getCompanyById(Long id);}3、UserMapper.java
package com.example.demo.mapper;import org.apache.ibatis.annotations.Result;import org.apache.ibatis.annotations.Results;import org.apache.ibatis.annotations.Select;import org.apache.ibatis.annotations.One;import org.apache.ibatis.annotations.Many;import com.example.demo.entity.User;public interface UserMapper { /* * 一对一查询 * property:查询结果赋值给此实体属性 * column:对应数据库的表字段,做为下面@One(select方法的查询参数 * one:一对一的查询 * @One(select = 方法全路径) :调用的方法 */ @Select("SELECT * FROM user WHERE id = #{id}") @Results({ @Result(property = "company", column = "company_id", one = @One(select = "com.example.demo.mapper.CompanyMapper.getCompanyById")) }) User getUserWithCompany(Long id); /* * 一对多查询 * property:查询结果赋值给此实体属性 * column:对应数据库的表字段,可做为下面@One(select方法)的查询参数 * many:一对多的查询 * @Many(select = 方法全路径) :调用的方法 */ @Select("SELECT * FROM user WHERE id = #{id}") @Results({ @Result(property = "id", column = "id"),//加此行,否则id值为空 @Result(property = "accounts", column = "id", many = @Many(select = "com.example.demo.mapper.AccountMapper.getAccountByUserId")) }) User getUserWithAccount(Long id); /* * 同时用一对一、一对多查询 */ @Select("SELECT * FROM user") @Results({ @Result(property = "id", column = "id"), @Result(property = "company", column = "company_id", one = @One(select = "com.example.demo.mapper.CompanyMapper.getCompanyById")), @Result(property = "accounts", column = "id", many = @Many(select = "com.example.demo.mapper.AccountMapper.getAccountByUserId")) }) List<User> getAll(); }方法二:使用XML
参考上文spring boot 2整合mybatis配置application.properties和mybatis-config.xml等后,
以上面的getAll()方法为例,UserMapper.xml配置如下:
四、控制层
package com.example.demo.web;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.web.bind.annotation.PathVariable;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController;import com.example.demo.entity.User;import com.example.demo.mapper.UserMapper;@RestControllerpublic class UserController { @Autowired private UserMapper userMapper; //请求例子:http://localhost:9001/getUserWithCompany/1 @RequestMapping("/getUserWithCompany/{id}") public User getUserWithCompany(@PathVariable("id") Long id) { User user = userMapper.getUserWithCompany(id); return user; } //请求例子:http://localhost:9001/getUserWithAccount/1 @RequestMapping("/getUserWithAccount/{id}") public User getUserWithAccount(@PathVariable("id") Long id) { User user = userMapper.getUserWithAccount(id); return user; } //请求例子:http://localhost:9001/getUserWithAccount/1 @RequestMapping("/getUsers") public List<User> getUsers() { List<User> users=userMapper.getAll(); return users; } }以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言hasOne、hasMany是Yii2特有的用于多表关联查询的函数,平时在使用多表关联查询的时候建议使用它们。为什么?因为这种方式关联查询出来的结果会保留Y
本文实例讲述了MongoDB多表关联查询操作。分享给大家供大家参考,具体如下:Mongoose的多表关联查询首先,我们回忆一下,MySQL多表关联查询的语句:s
本文实例讲述了ThinkPHP中关联查询的用法。分享给大家供大家参考。具体分析如下:在THINKPHP中关联查询(多表查询)可以使用table()方法或和joi
导入mybatis依赖org.mybatis.spring.bootmybatis-spring-boot-starter2.0.1yml实现mybatis依赖
1.加入mybatis-spring-boot-stater的Maven依赖org.mybatis.spring.bootmybatis-spring-boot