• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

结合mybatis-plus实现简单不需要写sql的多表查询

java 搞代码 4年前 (2022-01-05) 50次浏览 已收录 0个评论

这篇文章主要给大家介绍了关于结合mybatis-plus实现简单不需要写sql的多表查询的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用mybatis-plus具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧

项目地址: GITHUB (本地下载)

java mybatis 多表查询

简介

实现简单的实体类操作多表,  首先你的项目是使用了mybatis-plus 才可以使用

设计说明

  • 如何关联表?

找第一张表注解为 TableId (mybatis-plus 注解)的属性名, 到每二张表找同样的属性名, 如果没找到,反过来找,如果还没找到,挨个属性找。以此类推,实现关联的前提条件是 主从表的关联例名必须一样

 // user 表 @TableId private Integer userId // address 表 @TableId private Integer addressId private Integer userId

使用说明

com.freedomen.multipselect 包放到你的项目中,使 com.freedomen.multipselect.mapper里的xml 要被扫描到,或手动配置, com.freedomen.multipselect.service也要被发现

 //引入service @Autowired private MultipleService multipleService; //表关联, 关联用户表和地址表,查找 用户表的所有字段和地址表的所有字段 MultipleSelect multipleSelect = MultipleSelect.newInstance("${1}", new User(), new Address()); multipleSelect .where("${0}") .like("userName", "张三"); multipleService.mulSelect(multipleSelect); 

查找字段

 //MultipleSelect.newInstance 的第一个参数是所要查找的字段 //${0} 或 ${user} 表是第一张表的所有字段 ${0}.userName或${user}.userName表示userName字段, 默认第一张表的字段全部都返回的。 ${}中间的参数可以是后面实体的下标,也可以是表名 如user、user_address //下面是要订单表的所有信息 和用户的姓名与号码 和地址 MultipleSelect.newInstance("${1}.userName,${1}.userPhone,${2}", new Orders(), new User(), new Address());

查找条件

  • eq: =
  • notEq: !=
  • like: LIKE (前置已经加了 ‘%’)
  • between: between
  • and: 改变连接方式为 AND练级(默认)
  • or: 改变 连接方式为 OR
  • division:括号
  • in: IN
  • notIn: NOT IN
  • notLike: NOT LIKE
  • …等等
 //实例好 查找实体后可以操作实体 //注意: 如何实体内属性有值 将会以 eq方式and连接做为where 条件 MultipleSelect multipleSelect = MultipleSelect.newInstance("${1}.userName,${1}.userPhone,${2}", new Orders(), new User(), new Address()); multipleSelect .where("${0}") //哪张表 .eq("ordersId", 1) //并且 订单id = 1 .like("ordersName", "cmcc") //并且 订单名称 like ''%cmcc' .or() //改变后续操作关系为 OR, 默认为AND .notEq("orderSno", "123"); //或者 orderSno 不等于 '123' multipleSelect .where("${1}") //哪张表接着用户表 默认and连接 可以 .or()改为 OR .in("userId", [1, 2, 3]); // 并且userId in [1, 2, 3] multipleSelect .where("${2}") .or() .like("adressDetails", "江苏"); //或者 地址 like '江苏' multipleService.mulSelect(multipleSelect); //查询

排序

 //MultipleSelect.setOrderBy(...columns) MultipleSelect.setOrderBy("${1}.ordersName desc", "${2}.userId asc", ...)

分页

 //Multiple<a style="color:transparent">来源gao($daima.com搞@代@#码(网</a>Select.setPage(pageNo, pageSize); MultipleSelect.setPage(1, 15); //第一页 每页 15条

multipleService.mulSelect返回结果

 //MultipleResult /* 原型 private List<Map> data; //结果数据 private Integer pageNo;  //如果设置了分页 会有 private Integer pageSize;  //如果设置了分页 会有 private Integer total;  //如果设置了分页 会有 */

逻辑删除

 //默认是读取 mybatis-plus 的 TableLogic 注解 0 未删除, //如果不是用 0 表示未删除, 可以修改 MultipleSelect 的 setCustomWhere 方法中的下面这段中的 0 if (logic != null) sb.append(" AND ") .append(te.getNickName()) .append(".") .append(logic) .append(" = ") .append("0");

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对gaodaima搞代码网的支持。

以上就是结合mybatis-plus实现简单不需要写sql的多表查询的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:结合mybatis-plus实现简单不需要写sql的多表查询

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址