ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

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

2021-12-24 21:01:03  阅读:150  来源: 互联网

标签:java 用户 两张 员工 添加 user 表中 staff


要求:

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,用户,两张,员工,添加,user,表中,staff
来源: https://blog.csdn.net/Dustmicro/article/details/122134930

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有