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

您的位置:首頁技術文章
文章詳情頁

MyBatis 三表外關聯查詢的實現(用戶、角色、權限)

瀏覽:227日期:2023-10-23 12:20:45

一、數據庫結構

MyBatis 三表外關聯查詢的實現(用戶、角色、權限)

二、查詢所有數據記錄(SQL語句)

MyBatis 三表外關聯查詢的實現(用戶、角色、權限)

SQL語句:

SELECT u.*, r.*, a.* FROM( ( ( user u INNER JOIN user_role ur ON ur.user_id = u.user_id ) INNER JOIN role r ON r.role_id = ur.role_id ) INNER JOIN role_authority ra ON ra.role_id = r.role_id)INNER JOIN authority a ON ra.authority_id = a.authority_id

三、詳細代碼(第一中方式)

1、實體類entity

package cn.lemon.demo.entity;import lombok.Data;import java.io.Serializable;@Datapublic class AuthorityEntity implements Serializable { private Integer authorityId; private String authorityName; private String authorityDescription;}

package cn.lemon.demo.entity;import lombok.Data;import java.io.Serializable;@Datapublic class RoleEntity implements Serializable { private Integer roleId; private String roleName; private String roleDescription;}

package cn.lemon.demo.entity;import lombok.Data;import java.io.Serializable;import java.util.Date;import java.util.List;@Datapublic class UserEntity implements Serializable { private Integer userId; private String userName; private String userSex; private Date userBirthday; private String userAddress; private List<RoleEntity> roleEntityList; private List<AuthorityEntity> authorityEntityList;}

2、數據訪問層dao、Mapper

package cn.lemon.demo.dao;import cn.lemon.demo.entity.UserEntity;import org.springframework.stereotype.Repository;import java.util.List;@Repositorypublic interface IUserDao { /** * 查詢所有關聯的數據 * * @return */ List<UserEntity> selectAllUserRoleAuthority();}

<?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='cn.lemon.demo.dao.IUserDao'> <select resultMap='userMap'> SELECT u.*, r.*, a.* FROM ( (( user u INNER JOIN user_role ur ON ur.user_id = u.user_id )INNER JOIN role r ON r.role_id = ur.role_id ) INNER JOIN role_authority ra ON ra.role_id = r.role_id ) INNER JOIN authority a ON ra.authority_id = a.authority_id </select> <resultMap type='cn.lemon.demo.entity.UserEntity'> <id property='userId' column='user_id'/> <result property='userName' column='user_name'/> <result property='userSex' column='user_sex'/> <result property='userBirthday' column='user_birthday'/> <result property='userAddress' column='user_address'/> <collection property='roleEntityList' ofType='cn.lemon.demo.entity.RoleEntity' resultMap='roleMap'/> <collection property='authorityEntityList' ofType='cn.lemon.demo.entity.AuthorityEntity' resultMap='authorityMap'/> </resultMap> <resultMap type='cn.lemon.demo.entity.RoleEntity'> <id property='roleId' column='role_id'/> <result property='roleName' column='role_name'/> <result property='roleDescription' column='role_description'/> </resultMap> <resultMap type='cn.lemon.demo.entity.AuthorityEntity'> <id property='authorityId' column='authority_id'/> <result property='authorityName' column='authority_name'/> <result property='authorityDescription' column='authority_description'/> </resultMap></mapper>

3、業務層service

package cn.lemon.demo.service;import cn.lemon.demo.entity.UserEntity;import org.springframework.stereotype.Service;import java.util.List;@Servicepublic interface IUserService { List<UserEntity> selectAllUserRoleAuthority();}

package cn.lemon.demo.service.impl;import cn.lemon.demo.dao.IUserDao;import cn.lemon.demo.entity.UserEntity;import cn.lemon.demo.service.IUserService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Service;import java.util.List;@Servicepublic class UserServiceImpl implements IUserService { @Autowired private IUserDao userDao; @Override public List<UserEntity> selectAllUserRoleAuthority() { return userDao.selectAllUserRoleAuthority(); }}

4、測試類

package cn.lemon.demo.service.impl;import cn.lemon.demo.entity.UserEntity;import cn.lemon.demo.service.IUserService;import org.junit.Test;import org.junit.runner.RunWith;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.boot.test.context.SpringBootTest;import org.springframework.test.context.junit4.SpringRunner;import java.util.List;@SpringBootTest@RunWith(SpringRunner.class)public class UserServiceImplTest { @Autowired private IUserService userService; @Test public void selectAllUserRoleAuthority() { List<UserEntity> userEntities = userService.selectAllUserRoleAuthority(); for (UserEntity userEntity : userEntities) { System.out.println( '用戶姓名:' + userEntity.getUserName() + '用戶地址:' + userEntity.getUserAddress() + '權限列表:' + userEntity.getAuthorityEntityList() + '角色列表:' + userEntity.getRoleEntityList()); System.out.println('--------------------------------------'); } }}

四、詳細代碼(第二中方式)

1、實體類entity (實體類可以省略不寫)

package cn.lemon.demo.entity;import lombok.Data;import java.io.Serializable;import java.util.Date;@Datapublic class UserEntity implements Serializable { private Long userId; private String userName; private String userSex; private Date userBirthday; private String userAddress;}

package cn.lemon.demo.entity;import lombok.Data;import java.io.Serializable;@Datapublic class RoleEntity implements Serializable { private Long roleId; private String roleName; private String roleDescription;}

package cn.lemon.demo.entity;import lombok.Data;import java.io.Serializable;@Datapublic class AuthorityEntity implements Serializable { private Long authorityId; private String authorityName; private String authorityDescription;}

2、數據訪問層dao、Mapper

package cn.lemon.demo.dao;import java.util.List;import java.util.Map;public interface IUserDao { List<Map> selectAllUserRoleAuthority();}

<?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='cn.lemon.demo.dao.IUserDao'> <!--查詢 用戶信息,角色信息,權限信息--> <select resultType='java.util.Map'> SELECT u.user_id userId, u.user_name userName, u.user_sex userSex, u.user_birthday userBirthday, u.user_address userAddress, r.role_name roleName, r.role_description roleDescription, a.authority_name authorityName, a.authority_description authorityDescription FROM (( ( USER u INNER JOIN user_role ur ON u.user_id = ur.user_id ) INNER JOIN role r ON r.role_id = ur.role_id)INNER JOIN role_authority ra ON ra.role_id = r.role_id ) INNER JOIN authority a ON a.authority_id = ra.authority_id </select></mapper>

3、業務層service (接口及實現類)

package cn.lemon.demo.service;import java.util.List;import java.util.Map;public interface IUserService { List<Map> selectAllUserRoleAuthority();}

package cn.lemon.demo.service.impl;import cn.lemon.demo.dao.IUserDao;import cn.lemon.demo.service.IUserService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Service;import java.util.List;import java.util.Map;@Servicepublic class UserServiceImpl implements IUserService { @Autowired private IUserDao userDao; @Override public List<Map> selectAllUserRoleAuthority() { return userDao.selectAllUserRoleAuthority(); }}

4、控制層controller

package cn.lemon.demo.controller;import cn.lemon.demo.service.IUserService;import com.alibaba.fastjson.JSONObject;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.RequestMethod;import org.springframework.web.bind.annotation.ResponseBody;import java.util.List;import java.util.Map;@Controller@RequestMapping(value = '/')public class SystemController { @Autowired private IUserService userService; /** * 跳轉頁面 * * @return */ @RequestMapping(value = 'index') public String index() { return 'index'; } /** * 查詢所有關聯的數據 用戶信息,角色信息,權限信息 * @return */ @RequestMapping(value = 'selectAll',method = RequestMethod.POST) @ResponseBody public String selectAll(){ List<Map> mapList = userService.selectAllUserRoleAuthority(); JSONObject json = new JSONObject(); json.put('mapList',mapList); System.out.println(json.toJSONString()); return json.toJSONString(); }}

5、前端頁面 index.html

<!DOCTYPE html><html lang='en' xmlns:th='http://www.thymeleaf.org'><head> <meta charset='UTF-8'> <title>首頁</title> <script type='text/javascript' th:src='http://www.b3g6.com/bcjs/@{/static/js/jquery-1.11.3.min.js}'></script></head><body><div id='head'> <table border='2px' cellspacing='2px'> <thead> <tr> <th>用戶編號</th> <th>用戶姓名</th> <th>用戶性別</th> <th>用戶生日</th> <th>用戶地址</th> <th>角色名稱</th> <th>角色描述</th> <th>權限名稱</th> <th>權限描述</th> </tr> </thead> <tbody id='tbody'> </tbody> </table></div><script type='text/javascript'> $(function () { $.ajax({ type: 'post', url: ’/selectAll’, contentType: 'application/json;charset=utf-8', dataType: ’json’, //async: false,/*表示請求為同步方式*/ success: function (data) {//在<tbody>中追加數據for (var i = 0; i < data.mapList.length; i++) { $('#tbody').append('<tr><td>' + data.mapList[i].userId + '</td>' + '<td>' + data.mapList[i].userName + '</td>' + '<td>' + data.mapList[i].userSex + '</td>' + '<td>' + data.mapList[i].userBirthday + '</td>' + '<td>' + data.mapList[i].userAddress + '</td>' + '<td>' + data.mapList[i].roleName + '</td>' + '<td>' + data.mapList[i].roleDescription + '</td>' + '<td>' + data.mapList[i].authorityName + '</td>' + '<td>' + data.mapList[i].authorityDescription + '</td>' + '</tr>');} }, error: function () {window.alert('查詢失敗'); } }); });</script></body></html>

運行 localhost:8080 顯示:

MyBatis 三表外關聯查詢的實現(用戶、角色、權限)

到此這篇關于MyBatis 三表外關聯查詢的實現(用戶、角色、權限)的文章就介紹到這了,更多相關MyBatis 外關聯查詢內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲精品黄色| 国产情侣一区在线| 亚洲国内欧美| 乱人伦精品视频在线观看| 少妇精品在线| 美腿丝袜亚洲三区| 欧美日韩精品一区二区视频| 99日韩精品| 久久精品凹凸全集| 国产成人精品999在线观看| 999久久久国产精品| 日韩在线一区二区| 久久精品一区| 狠狠色综合网| 国产精品香蕉| 久久五月天小说| 日韩精品久久久久久久软件91| 久久久久亚洲精品中文字幕| 激情综合自拍| 国产精品极品在线观看| 婷婷激情综合| 国产欧美丝祙| 图片区亚洲欧美小说区| 国产精品一区三区在线观看| 日韩啪啪电影网| 亚洲影视一区二区三区| 成人在线观看免费视频| 免费在线观看一区二区三区| 精品淫伦v久久水蜜桃| 亚洲色诱最新| 国产一区福利| 亚洲日本三级| 99久久久久国产精品| 国产精品一区二区中文字幕| 亚洲高清久久| 国产精品一国产精品| 91国语精品自产拍| 国产精品nxnn| 亚洲欧美日韩专区| 精品国产乱码久久久久久樱花 | 国产精品sss在线观看av| 欧美 日韩 国产精品免费观看| 91p九色成人| 亚洲免费激情| 日韩电影免费网址| 国产精品一国产精品| aa国产精品| 亚洲精品88| 欧美黑人做爰爽爽爽| 久久国产高清| 亚洲a在线视频| 成人午夜在线| 国产情侣久久| 首页亚洲欧美制服丝腿| 日韩中文在线播放| 麻豆精品蜜桃视频网站| 日韩中文字幕在线一区| 精品一区在线| 国产色播av在线| 久久不卡国产精品一区二区| 中文字幕一区二区三区四区久久| 久久精品国产68国产精品亚洲| 欧美黄页在线免费观看| 午夜久久av| 亚洲综合国产| 亚洲午夜黄色| 久久天堂av| 色婷婷色综合| 久久av免费| 欧美视频久久| 亚洲欧洲日韩| 丝袜国产日韩另类美女| 欧美特黄一级| 亚洲国产综合在线看不卡| 国产精品福利在线观看播放| 国产精品66| 国产精品蜜月aⅴ在线| 日韩精品免费视频一区二区三区| 国产农村妇女精品一二区| 国产主播一区| 久久国产主播| 久久久久中文| 久久婷婷一区| 日韩免费高清| 日韩精品1区| 欧美日韩免费观看视频| 国产精品99久久精品| 国模大尺度视频一区二区| 精品一区视频| 91麻豆国产自产在线观看亚洲| 美女av一区| 久久免费视频66| 久久精品国产99国产| 久久久久九九精品影院| 国产精品视频首页| 国产精品极品| 精品一级视频| 精品一区二区三区中文字幕 | 婷婷中文字幕一区| 欧美1区2区3区| 免费av一区| 国产高清一区| 久热re这里精品视频在线6| 日韩精品一区第一页| 亚州欧美在线| 国产精品网址| 欧美国产一级| 国产91精品对白在线播放| 黄色亚洲大片免费在线观看| 一区在线观看| 美女黄网久久| 日韩二区三区在线观看| 国产精品www.| 91免费精品| 香蕉人人精品| 日韩专区在线视频| 婷婷综合成人| 麻豆视频观看网址久久| 国产精品伦理久久久久久| 久久黄色影院| 丝袜美腿高跟呻吟高潮一区| 日韩不卡一区二区三区| 麻豆视频观看网址久久| 亚洲最新无码中文字幕久久| 日韩在线欧美| 国产视频欧美| 91精品国产自产观看在线| 国产极品嫩模在线观看91精品| 国产精品原创| 99re国产精品| 国产欧美日韩免费观看| 日韩大片免费观看| 视频一区二区不卡| 国产精品手机在线播放| 日韩欧美二区| 亚洲一级大片| 精品国产中文字幕第一页| 国产精品av久久久久久麻豆网| 综合激情五月婷婷| 国产精品一区高清| 日韩欧美一区二区三区免费观看| 在线一区欧美| 久久成人高清| 激情婷婷亚洲| 日韩精品91亚洲二区在线观看| 欧美激情aⅴ一区二区三区| 久久婷婷亚洲| 日韩黄色在线观看| 午夜av不卡| 日韩三级一区| av高清一区| 日本少妇一区二区| 日韩视频网站在线观看| 亚洲涩涩av| 福利片在线一区二区| 国产亚洲在线观看| 国产精品va视频| 午夜日本精品| 久久久久伊人| 免费在线视频一区| 另类专区亚洲| 亚洲精品黄色| 精品丝袜在线| 国产欧美三级| 婷婷综合激情| 麻豆成人91精品二区三区| 麻豆精品91| se01亚洲视频| 国产欧美精品久久| 免费av一区二区三区四区| 国产欧美三级| 在线亚洲国产精品网站| 成人国产精品久久| 亚洲最大av| 99久久久久国产精品| 国产精品亚洲四区在线观看| 亚洲综合三区| 日韩免费av| 国产精品日韩精品在线播放| 欧美在线综合| 日韩欧美少妇| 欧美极品中文字幕| 亚洲一二三区视频| 99久久亚洲精品蜜臀| 国产精品久一| 日韩一区二区久久| 亚洲精品在线影院| 久久不见久久见免费视频7 | 国产成人77亚洲精品www| 日韩精品成人| 99国产一区| 久久裸体视频| 精品视频自拍| 国产亚洲欧美日韩在线观看一区二区| 好吊日精品视频| yellow在线观看网址| 国产精品男女| 日本成人中文字幕在线视频| 国产专区一区| 亚洲啊v在线|