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;
}
因篇幅问题不能全部显示,请点此查看更多更全内容
Copyright © 2019- esig.cn 版权所有 湘ICP备2023023988号-3
违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com
本站由北京市万商天勤律师事务所王兴未律师提供法律服务