mybatis注解版实现多表联查

需求:

用户有角色,角色有权限,需要一次取用户信息包含角色信息及其对应权限

实体类:

package cn.zytao.taosir.common.model.user;

import java.io.Serializable;
import java.util.Date;
import java.util.HashSet;
import java.util.Set; import com.baomidou.mybatisplus.annotations.TableField; import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data; @Data
@ApiModel(value="用户实体")
public class User implements Serializable{ /**
*
*/
private static final long serialVersionUID = -2389902440625641568L; @ApiModelProperty(name ="id",value = "ID主键")
private String id; @ApiModelProperty(name ="username",value = "用户名")
private String username; @ApiModelProperty(name ="password",value = "密码")
private String password; @ApiModelProperty(name ="nickname",value = "昵称")
private String nickname; @ApiModelProperty(name ="isInsiders",value = "是否内部人员")
private int isInsiders; @ApiModelProperty(name ="phone",value = "联系电话")
private String phone; @ApiModelProperty(name ="email",value = "邮箱")
private String email; @ApiModelProperty(name ="qq",value = "QQ")
private String qq; @ApiModelProperty(name ="wechat",value = "微信")
private String wechat; @ApiModelProperty(name ="question",value = "找回密码问题")
private String question; @ApiModelProperty(name ="answer",value = "找回密码答案")
private String answer; @ApiModelProperty(name ="createTime",value = "创建时间")
private Date createTime; @ApiModelProperty(name ="updateTime",value = "更新时间")
private Date updateTime; @TableField(exist = false)
private Set<Role> roles=new HashSet<>();
}

用户

package cn.zytao.taosir.common.model.user;

import java.io.Serializable;
import java.util.HashSet;
import java.util.Set; import com.baomidou.mybatisplus.annotations.TableField; import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data; /**
*
* @author taosir
*
*/
@Data
@ApiModel(value="角色实体")
public class Role implements Serializable{ /**
*
*/
private static final long serialVersionUID = 4710406435745633366L; @ApiModelProperty(name ="id",value = "ID主键")
private String id; @ApiModelProperty(name ="roleCode",value = "角色代码")
private String roleCode; @ApiModelProperty(name ="roleName",value = "角色名称")
private String roleName; @TableField(exist = false)
private Set<Permission> permissions=new HashSet<>();
}

角色

package cn.zytao.taosir.common.model.user;

import java.io.Serializable;

import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data; @Data
@ApiModel(value="权限实体")
public class Permission implements Serializable{ /**
*
*/
private static final long serialVersionUID = 1545962188193104351L; @ApiModelProperty(name ="id",value = "ID主键")
private String id; @ApiModelProperty(name ="permissionCode",value = "权限代码")
private String permissionCode; @ApiModelProperty(name ="permissionName",value = "权限名称")
private String permissionName; @ApiModelProperty(name="path",value="映射路径")
private String path;
}

权限

package cn.zytao.taosir.common.model.user;

import java.io.Serializable;

import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data; @Data
@ApiModel(value="用户角色关系表")
public class UserRole implements Serializable{
/**
*
*/
private static final long serialVersionUID = 6163369825048118489L;
@ApiModelProperty(name ="id",value = "ID主键")
private String id;
@ApiModelProperty(name ="username",value = "用户名")
private String username;
@ApiModelProperty(name ="roleCode",value = "角色代码")
private String roleCode;
}

用户角色关系

package cn.zytao.taosir.common.model.user;

import java.io.Serializable;

import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data; @Data
@ApiModel(value="角色权限关系表")
public class RolePermission implements Serializable{ /**
*
*/
private static final long serialVersionUID = -7522662317811377590L;
@ApiModelProperty(name ="id",value = "ID主键")
private String id;
@ApiModelProperty(name ="roleCode",value = "角色代码")
private String roleCode;
@ApiModelProperty(name ="permissionCode",value = "权限代码")
private String permissionCode;
}

角色权限关系

注解是swagger2的,无需关注。另外有个 @TableField(exist = false) 该注解标识这个字段非数据库字段

持久层处理:

@Select("select * from  role where role_code in(select role_code from user_role where username = #{username})")
Set<Role> getUserRoles(String username);
@Select("select * from permission where permission_code in (select permission_code from role_permission where role_code = #{roleCode})")
Set<Permission> getRolePermissions(String roleCode);

第一个sql为获取用户所拥有角色,第二个sql为获取角色所拥有权限

yml的配置上:

mybatis-plus:
type-aliases-package: cn.zytao.taosir.common.model.user
configuration:
map-underscore-to-camel-case: true

映射实体类,开起对下划线转大写的处理

业务处理上:

    public User findByUsername(String username) {
User user = userMapper.findByUsername(username);
Set<Role> roles = userMapper.getUserRoles(username);
for (Role role : roles) {
role.setPermissions(roleMapper.getRolePermissions(role.getRoleCode()));
}
user.setRoles(roles);
return user;
}

这样就可以很方便的解决多表的联查~因为本人比较懒,不想写配置版,也不喜欢在注解上用@Results来标示结果集

仍在不断学习中,如有不妥还望指教~

mybatis-plus注解版实现多表联查(sql)的更多相关文章

  1. SpringBoot Mybatis整合(注解版),SpringBoot集成Mybatis(注解版)

    SpringBoot Mybatis整合(注解版),SpringBoot集成Mybatis(注解版) ================================ ©Copyright 蕃薯耀 2 ...

  2. Spring Boot 实战 —— MyBatis(注解版)使用方法

    原文链接: Spring Boot 实战 -- MyBatis(注解版)使用方法 简介 MyBatis 官网 是这么介绍它自己的: MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过 ...

  3. Spring Boot整合MyBatis(非注解版)

    Spring Boot整合MyBatis(非注解版),开发时采用的时IDEA,JDK1.8 直接上图: 文件夹不存在,创建一个新的路径文件夹 创建完成目录结构如下: 本人第一步习惯先把需要的包结构创建 ...

  4. mybatis使用注解往postgresql数据库表insert数据[主键自增]的写法

    建表SQL: DROP TABLE IF EXISTS person; CREATE TABLE person( person_id serial PRIMARY KEY NOT NULL, pers ...

  5. mybatis plus 一对多,多表联查的使用小记

    阅读本博文需要有基础的mybatis以及mybatis plus知识,如果没有建议您了解相关的内容 本项目使用的是springboot构建的,数据库字段命名不严谨仅做演示测试使用,本文不做相关源码的解 ...

  6. 玩转SSH(五):Struts + Spring + MyBatis(注解版)

    本文将在 玩转SSH(四):Struts + Spring + MyBatis 的基础上进行一些小的改动,将原本是 xml 配置方式的项目,改成注解的配置方式. 要将项目改成注解方式,一般是将在 Sp ...

  7. Spring和MyBatis整合(注解版)

    1.导入所需要的依赖 <!--MyBatis和Spring的整合包 由MyBatis提供--> <dependency> <groupId>org.mybatis& ...

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

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

  9. SpringBoot + MyBatis(注解版),常用的SQL方法

    一.新建项目及配置 1.1 新建一个SpringBoot项目,并在pom.xml下加入以下代码 <dependency> <groupId>org.mybatis.spring ...

随机推荐

  1. 【codeforces 807A】Is it rated?

    [题目链接]:http://codeforces.com/contest/807/problem/A [题意] 给你n个人在一场CF前后的rating值; 问你这场比赛是不是计分的 [题解] 如果有一 ...

  2. 简洁又快速地处理集合——Java8 Stream(下)

    上一篇文章我讲解 Stream 流的基本原理,以及它与集合的区别关系,讲了那么多抽象的,本篇文章我们开始实战,讲解流的各个方法以及各种操作 没有看过上篇文章的可以先点击进去学习一下 简洁又快速地处理集 ...

  3. Forge.autodesk平台的使用

    看了下面的这个网址的教程,发现其中的curl在git集成的shell中不好用,反复尝试后发现,&后面是没有空格的,记录下 https://forge.autodesk.io/

  4. insmod: error inserting &#39;hello.ko&#39;: -1 Invalid module format

    在学习编写linux驱动程序的时候,一般都是从写一个helloworld的模块開始. 可是在编译完毕后,进行模块载入的时候,有时会出现例如以下错误: insmod: error inserting ' ...

  5. Codeforces Round #260 (Div. 1) 455 A. Boredom (DP)

    题目链接:http://codeforces.com/problemset/problem/455/A A. Boredom time limit per test 1 second memory l ...

  6. jQuery插件 -- Cookie插件

    Cookie是站点设计者放置在client的小文本文件.Cookie能为用户提供非常多的使得,比如购物站点存储用户以前浏览过的产品列表.或者门户站点记住用户喜欢选择浏览哪类新闻. 在用户同意的情况下. ...

  7. Android安全攻防战,反编译与混淆技术全然解析(下)

    转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/50451259 在上一篇文章其中,我们学习了Android程序反编译方面的知识,包括 ...

  8. 蓝桥杯-- 历届试题 核桃的数量 (gcd)

      历届试题 核桃的数量   时间限制:1.0s   内存限制:256.0MB        问题描述 小张是软件项目经理,他带领3个开发组.工期紧,今天都在加班呢.为鼓舞士气,小张打算给每个组发一袋 ...

  9. 【BZOJ 2724】 蒲公英

    [题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=2724 [算法] 分块算法在线维护区间众数 分块算法的精髓就在于 : 大段维护,局部朴 ...

  10. Regexp-Utils:身份证号校验

    ylbtech-Regexp-Utils:身份证号校验 1.返回顶部 1.方法 var idCardNoUtil = { /*省,直辖市代码表*/ provinceAndCitys: { 11: &q ...