栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Mybatis 连带操作(注解方式)(两张表关联,一张表插入一条新数据,另外一张表也跟着插入一条新数据)

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Mybatis 连带操作(注解方式)(两张表关联,一张表插入一条新数据,另外一张表也跟着插入一条新数据)

以角色权限模块中增加功能为例子:

  1. 概念:

连带操作:首先先在Role表中插入一条数据,接着拿到rid,往Role-Acl表中插入一条数据

  1. 数据库设计:
    Role表:

    Role-Acl表:

  2. 代码实现:

RoleMap:

@Insert("insert into sys_role(rolename,creator,createtime,remark) VALUES(#{rolename},1,NOW(),#{remark})")
@Options(useGeneratedKeys = true, keyProperty = "rid",keyColumn="rid")
int  addRole(SysRole sysRole);

RoleAclMap:

 
@Insert("INSERT into sys_role_acl(rid,aid) VALUES(#{rid},#{aid})")
int  addRoleAcl(SysRoleAcl sysRoleAcl);

RoleService:

public Map addRole(SysRole sysRole, String[] aids) {
    int addRole = m_RoleMap.addRole(sysRole);
    Integer rid = sysRole.getRid();
    // SysRoleAcl
    SysRoleAcl sysRoleAcl = new SysRoleAcl();
    sysRoleAcl.setAid(Arrays.toString(aids));
    sysRoleAcl.setRid(rid);
    m_RoleAclMap.addRoleAcl(sysRoleAcl);
    // 调用IRoleAclMap方法
    Map tResultMap = new HashMap();
    tResultMap.put("status", "fail");
    if (addRole <= 0) {
 tResultMap.put("Msg", "添加失败");
 return tResultMap;
    }
    tResultMap.put("status", "success");
    return tResultMap;
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/238665.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号