java将数据同时插入到两张表中

6 篇文章 0 订阅
5 篇文章 0 订阅
要求:

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;
}
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值