日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

Spring boot2基于Mybatis實現(xiàn)多表關(guān)聯(lián)查詢

瀏覽:87日期:2023-09-09 11:47:39

模擬業(yè)務(wù)關(guān)系:

一個用戶user有對應(yīng)的一個公司company,每個用戶有多個賬戶account。

spring boot 2的環(huán)境搭建見上文:spring boot 2整合mybatis

一、mysql創(chuàng)表和模擬數(shù)據(jù)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);

二、創(chuàng)建實體

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 這里省略...}

三、開發(fā)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 { /* * 根據(jù)用戶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 { /* * 根據(jù)公司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:查詢結(jié)果賦值給此實體屬性 * column:對應(yīng)數(shù)據(jù)庫的表字段,做為下面@One(select方法的查詢參數(shù) * one:一對一的查詢 * @One(select = 方法全路徑) :調(diào)用的方法 */ @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:查詢結(jié)果賦值給此實體屬性 * column:對應(yīng)數(shù)據(jù)庫的表字段,可做為下面@One(select方法)的查詢參數(shù) * many:一對多的查詢 * @Many(select = 方法全路徑) :調(diào)用的方法 */ @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配置如下:

<?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.example.demo.mapper.UserMapper' > <resultMap type='com.example.demo.entity.User'> <id column='id' jdbcType='INTEGER' property='id' /> <result property='name' column='name' jdbcType='VARCHAR' /> <!--封裝映射company表數(shù)據(jù),user表與company表1對1關(guān)系,配置1對1的映射 association:用于配置1對1的映射 屬性property:company對象在user對象中的屬性名 屬性javaType:company屬性的java對象 類型 屬性column:user表中的外鍵引用company表 --> <association property='company' javaType='com.example.demo.entity.Company' column='company_id'> <id property='id' column='companyid'></id> <result property='companyName' column='companyname'></result> </association> <!--配置1對多關(guān)系映射 property:在user里面的List<Account>的屬性名 ofType:當(dāng)前account表的java類型 column:外鍵 --> <collection property='accounts' ofType='com.example.demo.entity.Account' column='user_id'> <id property='id' column='accountid'></id> <result property='accountName' column='accountname'></result> </collection> </resultMap> <select resultMap='UserMap' > SELECT u.id,u.name,c.id companyid, c.name companyname, a.id accountid,a.name accountname FROM user u LEFT JOIN company c on u.company_id=c.id LEFT JOIN account a on u.id=a.user_id </select></mapper>

四、控制層

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 /*請求結(jié)果:{'id':1,'name':'aa','company':{'id':1,'companyName':'xx公司'},'accounts':null}*/ @RequestMapping('/getUserWithCompany/{id}') public User getUserWithCompany(@PathVariable('id') Long id) { User user = userMapper.getUserWithCompany(id); return user; } //請求例子:http://localhost:9001/getUserWithAccount/1 /*請求結(jié)果:{'id':1,'name':'aa','company':null,'accounts':[{'id':1,'accountName':'中行'},{'id':2,'accountName':'工行'}]}*/ @RequestMapping('/getUserWithAccount/{id}') public User getUserWithAccount(@PathVariable('id') Long id) { User user = userMapper.getUserWithAccount(id); return user; } //請求例子:http://localhost:9001/getUserWithAccount/1 /*請求結(jié)果:[{'id':1,'name':'aa','company':{'id':1,'companyName':'xx公司'},'accounts':[{'id':1,'accountName':'中行'}, {'id':2,'accountName':'工行'}]},{'id':2,'name':'bb','company':{'id':2,'companyName':'yy公司'},'accounts':[{'id':3,'accountName':'中行'}]}]*/ @RequestMapping('/getUsers') public List<User> getUsers() { List<User> users=userMapper.getAll(); return users; } }

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Spring
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩.com| 久久国产三级精品| 久久99青青| 蜜臀av性久久久久蜜臀aⅴ流畅 | 国产国产精品| 色老板在线视频一区二区| 久久精品二区亚洲w码 | 欧美亚洲综合视频| 国产日韩欧美三区| 欧美激情麻豆| 精品国产亚洲一区二区三区在线| 国产亚洲字幕| 亚洲精品自拍| 日韩精品欧美大片| 911精品国产| 美女国产一区二区三区| 久久精品午夜| 日韩高清成人| 亚州av乱码久久精品蜜桃| 激情91久久| 亚洲精品乱码| 欧美精品97| 日韩精品永久网址| 欧美日韩日本国产亚洲在线| 石原莉奈在线亚洲二区| 深夜福利一区| 日韩动漫一区| 国产一区一一区高清不卡| 亚洲精品国产嫩草在线观看 | 欧美日韩国产传媒| 免费日韩视频| 久久狠狠久久| 国产aⅴ精品一区二区三区久久| 久久夜夜操妹子| 免播放器亚洲| 久久久久伊人| 蜜桃国内精品久久久久软件9| 亚洲免费婷婷| 久久精品72免费观看| 黄色aa久久| 乱人伦精品视频在线观看| 国产欧美一区二区色老头| 美女福利一区二区三区| 亚洲深爱激情| 国产精品探花在线观看| 三级精品视频| 午夜性色一区二区三区免费视频| 国产精品a级| 国产99久久久国产精品成人免费| 亚洲精品女人| 亚洲永久av| 中文字幕一区二区三区在线视频| 国产精品亚洲四区在线观看 | 18国产精品| www成人在线视频| 婷婷五月色综合香五月| 精品三级av| 日韩中文字幕不卡| 精品一区视频| 午夜在线精品偷拍| 精品国产欧美日韩一区二区三区| 99在线观看免费视频精品观看| 日韩av成人高清| 久久久777| 欧美日韩一区二区三区不卡视频| 日韩免费在线| 清纯唯美亚洲综合一区| 亚洲免费福利| 欧美视频久久| 99视频精品免费观看| 捆绑调教美女网站视频一区| 夜夜精品视频| 超碰99在线| 日韩av网站在线观看| 亚洲不卡av不卡一区二区| 日韩高清欧美激情| 一级欧洲+日本+国产| 国产乱码精品一区二区三区四区 | 模特精品在线| 欧美激情综合| 日韩中文字幕一区二区三区| 日韩高清欧美| 国产精品一级| 在线精品观看| 久久精品一区二区不卡| 国产美女久久| 亚洲综合五月| 91精品蜜臀一区二区三区在线| 国产精品成人国产| 视频一区视频二区中文字幕| 亚洲性色av| 国产精品多人| 日本不卡的三区四区五区| 婷婷久久一区| 日韩电影免费网站| 国产精品成人自拍| 日韩中出av| 中文精品在线| 欧美在线影院| 久久中文精品| 国产日韩视频| 日韩在线成人| 午夜在线一区| 亚洲精品在线观看91| 亚洲最新无码中文字幕久久| 久久gogo国模啪啪裸体| 日本一区二区中文字幕| 日韩午夜在线| 国产国产精品| 99国产精品一区二区| 精品久久国产一区| 国产精品一区高清| 啪啪亚洲精品| 日本欧美一区| 日韩av二区在线播放| 亚洲精品高潮| 日韩中文欧美在线| 欧美久久精品一级c片| 日本精品在线中文字幕| 国产在线观看www| 国产中文字幕一区二区三区| 精品网站999| 久久精品网址| 精品免费av一区二区三区| 精品九九在线| 久久精品网址| 鲁鲁在线中文| 亚洲a一区二区三区| 99久久久久久中文字幕一区| 91精品久久久久久久久久不卡| 久久久久久久久久久9不雅视频| 久久精品影视| 1024精品一区二区三区| 免费久久久久久久久| 欧美日韩国产高清电影| 国产亚洲高清视频| 一区二区电影在线观看| 婷婷综合电影| 欧美日韩一视频区二区| 久久不见久久见免费视频7| 国产精品一区高清| 高清一区二区三区av| 88xx成人免费观看视频库| 999国产精品999久久久久久| 一区在线免费| 日韩精品亚洲aⅴ在线影院| 国产九一精品| 久久久久久色| 久久三级毛片| 欧美韩日一区| 亚洲手机在线| 日韩中文字幕91| 国产日产精品一区二区三区四区的观看方式| 青青草91视频| a天堂资源在线| 久久在线免费| 一区二区电影在线观看| 国产精品夜夜夜| 中文在线а√天堂| 女主播福利一区| 日韩精品电影一区亚洲| 美女性感视频久久| 久久精品导航| 亚洲区欧美区| 久久99精品久久久久久园产越南| 日韩综合在线| 香蕉精品999视频一区二区| 国产欧美日韩综合一区在线播放| 国产福利91精品一区二区| 欧美日韩视频一区二区三区| 亚洲人成毛片在线播放女女| 久久亚洲人体| 在线观看免费一区二区| 欧美在线首页| 日韩一区二区三区免费| 亚洲一区二区三区中文字幕在线观看| 国产美女久久| 亚洲天堂久久| 国产精品一线天粉嫩av| 欧美日韩在线观看视频小说| 婷婷成人av| 美女网站视频一区| 日韩手机在线| 久久久人人人| 久久精品av麻豆的观看方式| 日韩高清不卡| 日本精品另类| 亚洲精品一级二级| 日本欧美一区二区在线观看| 亚洲va在线| 国产精品亚洲欧美| 国产日韩综合| 国产一区二区精品久| 亚洲乱码一区| 亚洲不卡系列| 国产精品久久久久9999高清| 国产精品美女| а√天堂中文在线资源8| 香蕉久久一区| 激情欧美国产欧美|