欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

(Java)通过案例讲解项目中表与表之间关联的处理步骤

程序员文章站 2024-02-21 08:10:28
...

这里通过一个用户表和角色表关联的案例,向大家展示,项目中对于表与表之间关系的处理步骤

一、案例介绍

(1)user 用户表:
(Java)通过案例讲解项目中表与表之间关联的处理步骤
(2)role 角色表:
(Java)通过案例讲解项目中表与表之间关联的处理步骤
(3)用户与角色关联的关系:
用户与角色之间是多对多关系,我们通过 users_role 表来描述其关联,在实体类中 User 中存在 List,在Role中有 List.

二、用户与角色关联

用户与角色是多对多的关系,我们要建立它们之间的关系,只需要在中间表 user_role 插入数据即可
(1)查询该用户可以添加的角色的选择
(Java)通过案例讲解项目中表与表之间关联的处理步骤

//UserController
 
    @RequestMapping("/findUserByIdAndAllRole.do")
    public ModelAndView findUserByIdAndAllRole(@RequestParam(name = "id", required = true) String userid) throws Exception {
        ModelAndView mv = new ModelAndView();
        //1.根据用户id查询用户
        UserInfo userInfo = userService.findById(userid);
        //2.根据用户id查询可以添加的角色
        List<Role> otherRoles = userService.findOtherRoles(userid);
        mv.addObject("user", userInfo);
        mv.addObject("roleList", otherRoles);
        mv.setViewName("user-role-add");
        return mv;
    }
//UserServiceImpl
@Override
    public List<Role> findOtherRoles(String userId) {
        return userDao.findOtherRoles(userId);
    }
//UserDao
@Select("select * from role where id not in (select roleId from users_role where userId=#{userId})")
    List<Role> findOtherRoles(String userId);

(Java)通过案例讲解项目中表与表之间关联的处理步骤
(2)点击保存,将添加的角色ID 和用户ID 一同插入到 users_role 中
(Java)通过案例讲解项目中表与表之间关联的处理步骤
注意这里的role.id 是多个值,是一个集合

//UserController
    @RequestMapping("/addRoleToUser.do")
    public String addRoleToUser(@RequestParam(name = "userId", required = true) String userId, @RequestParam(name = "ids", required = true) String[] roleIds) {
        userService.addRoleToUser(userId, roleIds);
        return "redirect:findAll.do";
    }
//UserServiceImpl
@Override
    public void addRoleToUser(String userId, String[] roleIds) {
        //将角色信息和用户ID一个一个插入
        for(String roleId:roleIds){
            userDao.addRoleToUser(userId,roleId);
        }
    }
//UserDao
@Insert("insert into users_role(userId,roleId) values(#{userId},#{roleId})")
void addRoleToUser(@Param("userId") String userId, @Param("roleId") String roleId);

(Java)通过案例讲解项目中表与表之间关联的处理步骤
(Java)通过案例讲解项目中表与表之间关联的处理步骤