java将数据同时插入到两张表中
2021/12/24 22:09:15
本文主要是介绍java将数据同时插入到两张表中,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
要求:
xml配置文件中已经配置好sql语句的增、删、改、查,只需要在service层编写java代码实现将数据同时插入到两张表中。
以员工和用户为例,在某种环境下员工也是用户,新增员工信息Staff的时候同时将信息添加到用户表User中。xml中已经配置好了sql语句的增、删、改、查,需要在service层中编写java代码达到需求:
@Service("addStaff") /**传入staff参数,返回String类型信息**/ public String addStaff(Staff staff,SqlSession sqlSession) throws Exception{ logger.info("添加员工信息,参数:{}",staff); try{ /**同时添加user**/ User user = new User(); /**将员工表中在用户表中有的字段传过去,一定要确保添加到用户表中的数据也是员工表中有的字段**/ user .setUserName(staff.getStaffName()); user .setUserAge(staff.getStaffAge()); user.setUserTel(staff.getStaffTel()); /**新增用户关联员工**/ sqlSession.getMapper(UserMapper.class).insertSelective(user); /**定义一个userId获取到新增用户id**/ int userId = user.getUserId(); UserRoleMapping record = new UserRoleMapping(); /**将新增的用户id放到用户角色关联表中进行关联**/ record.setUserId(userId); record.setRoleId(staff.getRoleId()); /**将员工职务的角色id关联给用户id**/ sqlSession.getMapper(UserRoleMapping.class).insertSective(record); staff.setUserId(userId); /**添加员工信息**/ sqlSession.getMapper(StaffMapper.class).insertSelective(staff); }catch(Exception e){ logger.error("添加员工出现异常",e) throw new Exception(CommConstant.ERROR_CODE,"添加员工出现异常"); } return CommConstant.SUCCESS; }
这篇关于java将数据同时插入到两张表中的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-22项目:远程温湿度检测系统
- 2024-12-21《鸿蒙HarmonyOS应用开发从入门到精通(第2版)》简介
- 2024-12-21后台管理系统开发教程:新手入门全指南
- 2024-12-21后台开发教程:新手入门及实战指南
- 2024-12-21后台综合解决方案教程:新手入门指南
- 2024-12-21接口模块封装教程:新手必备指南
- 2024-12-21请求动作封装教程:新手必看指南
- 2024-12-21RBAC的权限教程:从入门到实践
- 2024-12-21登录鉴权实战:新手入门教程
- 2024-12-21动态权限实战入门指南