如何实现MyBatis Plus中的多表联合查询示例代码?

2026-05-16 02:251阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计809个文字,预计阅读时间需要4分钟。

如何实现MyBatis Plus中的多表联合查询示例代码?

原文:java// 实体类package com.sk.skskill.entity;import com.baomidou.mybatisplus.annotation.TableField;import com.baomidou.mybatisplus.annotation.TableName;import import com.baomidou.mybatisplus.annotation.TableId;import java.io.Serializable;

@TableName(user)public class User implements Serializable { @TableId private Long id; @TableField(name) private String name; @TableField(age) private Integer age; // 省略其他字段和方法}

改写后:java// 实体类package com.sk.skskill.entity;

import com.baomidou.mybatisplus.annotation.TableField;import com.baomidou.mybatisplus.annotation.TableName;

@TableName(user)public class User { private Long id; private String name; private Integer age; // 省略其他字段和方法}

本文主要介绍了mybatis Plus 多表联合查询,分享给大家,具体如下:

//实体类package com.sk.skkill.entity; import com.baomidou.mybatisplus.annotation.TableField; import com.baomidou.mybatisplus.annotation.TableName; import lombok.Data; import java.io.Serializable; import java.util.Date; import java.util.List; @TableName("orders") @Data public class Order implements Serializable { public static final long serialVersionUID =1L; private String id; private String orderName; private Date createTime; private Date updateTime; private String userID; @TableField(exist = false) private List<Users> listUsers; public Order(){ } public Order(String id, String orderName) { this.id = id; this.orderName = orderName; } }

//dao层 package com.sk.skkill.mapper; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.sk.skkill.entity.Order; import com.sun.javafx.collections.MappingChange; import org.apache.ibatis.annotations.Select; import java.util.List; import java.util.Map; public interface OrderMapper extends BaseMapper<Order> { List<Order> selectOrder(); int addOrder(Order order);

//多表联合查询 按条件orderID @Select("select t1.*,t2.user_name,t2.nick_name from orders t1 LEFT JOIN users t2 ON t1.user_id =t2.id WHERE t1.user_id= #{id}") List<Map<String,Object>> orderUserList(Page<Map<String,Object>> page,String id); }

//service层 package com.sk.skkill.service; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.IService; import com.sk.skkill.entity.Order; import java.util.List; import java.util.Map; public interface OrderService extends IService<Order> { List<Order> selectOrder(); int addOrder(Order order); // List<Map<String,Object>> orderUserList(Page<Map<String,Object>> page, String id); Page<Map<String,Object>> selectListPage(int current,int number,String id); }

//serviceImpl层 package com.sk.skkill.service.impl; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.sk.skkill.entity.Order; import com.sk.skkill.mapper.OrderMapper; import com.sk.skkill.service.OrderService; import org.springframework.stereotype.Service; import java.util.List; import java.util.Map; @Service public class OrderServiceImpl extends ServiceImpl<OrderMapper, Order> implements OrderService { @Override public List<Order> selectOrder() { return baseMapper.selectList(null); } @Override public int addOrder(Order order) { return baseMapper.insert(order); } @Override public Page<Map<String, Object>> selectListPage(int current, int number,String id) { //新建分页 Page<Map<String,Object>> page =new Page<Map<String,Object>>(current,number); //返回结果 return page.setRecords(this.baseMapper.orderUserList(page,id)); } }

//controller层 package com.sk.skkill.controller; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.sk.skkill.entity.Order; import com.sk.skkill.service.impl.OrderServiceImpl; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import java.util.List; import java.util.Map; @RestController @RequestMapping("order") public class OrderController { @Autowired private OrderServiceImpl service; @RequestMapping("selectOrder") public List<Order> selectOrder() { return service.selectOrder(); } @RequestMapping("addOrder") public int addOrder(Order order){ order=new Order("FGGG","蒙牛MILK"); return service.addOrder(order); } @RequestMapping("selectListPage") public List<Map<String,Object>> selectListPage(String id) { Page<Map<String, Object>> page = service.selectListPage(1, 2,id); return page.getRecords(); } }

到此这篇关于mybatis Plus 多表联合查询的实现示例的文章就介绍到这了,更多相关mybatis Plus 多表联合查询内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!

如何实现MyBatis Plus中的多表联合查询示例代码?
标签:实现示例

本文共计809个文字,预计阅读时间需要4分钟。

如何实现MyBatis Plus中的多表联合查询示例代码?

原文:java// 实体类package com.sk.skskill.entity;import com.baomidou.mybatisplus.annotation.TableField;import com.baomidou.mybatisplus.annotation.TableName;import import com.baomidou.mybatisplus.annotation.TableId;import java.io.Serializable;

@TableName(user)public class User implements Serializable { @TableId private Long id; @TableField(name) private String name; @TableField(age) private Integer age; // 省略其他字段和方法}

改写后:java// 实体类package com.sk.skskill.entity;

import com.baomidou.mybatisplus.annotation.TableField;import com.baomidou.mybatisplus.annotation.TableName;

@TableName(user)public class User { private Long id; private String name; private Integer age; // 省略其他字段和方法}

本文主要介绍了mybatis Plus 多表联合查询,分享给大家,具体如下:

//实体类package com.sk.skkill.entity; import com.baomidou.mybatisplus.annotation.TableField; import com.baomidou.mybatisplus.annotation.TableName; import lombok.Data; import java.io.Serializable; import java.util.Date; import java.util.List; @TableName("orders") @Data public class Order implements Serializable { public static final long serialVersionUID =1L; private String id; private String orderName; private Date createTime; private Date updateTime; private String userID; @TableField(exist = false) private List<Users> listUsers; public Order(){ } public Order(String id, String orderName) { this.id = id; this.orderName = orderName; } }

//dao层 package com.sk.skkill.mapper; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.sk.skkill.entity.Order; import com.sun.javafx.collections.MappingChange; import org.apache.ibatis.annotations.Select; import java.util.List; import java.util.Map; public interface OrderMapper extends BaseMapper<Order> { List<Order> selectOrder(); int addOrder(Order order);

//多表联合查询 按条件orderID @Select("select t1.*,t2.user_name,t2.nick_name from orders t1 LEFT JOIN users t2 ON t1.user_id =t2.id WHERE t1.user_id= #{id}") List<Map<String,Object>> orderUserList(Page<Map<String,Object>> page,String id); }

//service层 package com.sk.skkill.service; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.IService; import com.sk.skkill.entity.Order; import java.util.List; import java.util.Map; public interface OrderService extends IService<Order> { List<Order> selectOrder(); int addOrder(Order order); // List<Map<String,Object>> orderUserList(Page<Map<String,Object>> page, String id); Page<Map<String,Object>> selectListPage(int current,int number,String id); }

//serviceImpl层 package com.sk.skkill.service.impl; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.sk.skkill.entity.Order; import com.sk.skkill.mapper.OrderMapper; import com.sk.skkill.service.OrderService; import org.springframework.stereotype.Service; import java.util.List; import java.util.Map; @Service public class OrderServiceImpl extends ServiceImpl<OrderMapper, Order> implements OrderService { @Override public List<Order> selectOrder() { return baseMapper.selectList(null); } @Override public int addOrder(Order order) { return baseMapper.insert(order); } @Override public Page<Map<String, Object>> selectListPage(int current, int number,String id) { //新建分页 Page<Map<String,Object>> page =new Page<Map<String,Object>>(current,number); //返回结果 return page.setRecords(this.baseMapper.orderUserList(page,id)); } }

//controller层 package com.sk.skkill.controller; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.sk.skkill.entity.Order; import com.sk.skkill.service.impl.OrderServiceImpl; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import java.util.List; import java.util.Map; @RestController @RequestMapping("order") public class OrderController { @Autowired private OrderServiceImpl service; @RequestMapping("selectOrder") public List<Order> selectOrder() { return service.selectOrder(); } @RequestMapping("addOrder") public int addOrder(Order order){ order=new Order("FGGG","蒙牛MILK"); return service.addOrder(order); } @RequestMapping("selectListPage") public List<Map<String,Object>> selectListPage(String id) { Page<Map<String, Object>> page = service.selectListPage(1, 2,id); return page.getRecords(); } }

到此这篇关于mybatis Plus 多表联合查询的实现示例的文章就介绍到这了,更多相关mybatis Plus 多表联合查询内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!

如何实现MyBatis Plus中的多表联合查询示例代码?
标签:实现示例