SQL部分
<!-- 新增订单安装记录-->
<insert id="saveInstallDetail" parameterType="ArrayList">
INSERT INTO tb_order_install_detail (
order_install_id,
goods_name,
is_cancel
)
VALUES
<foreach item="item" index="index" collection="list" separator=",">
(
#{item.orderInstallId},
#{item.goodsName},
#{item.isCancel}
)
</foreach>
</insert>
接口实现类
@Override
@Transactional
public TbOrderInstallInfoVo create(TbOrderInstallInfoVo vo) throws Exception {
// 1.根据erp发货ID 获取 发货记录ID和方案ID
TbOrderInstallInfoVo deliveVo = sqlSessionTemplate.selectOne("TbOrderInstallInfoMapper.findByDelivelId", vo);
if(null == deliveVo){
throw new InvalidRequestException("未找到发货记录");
}
vo.setOrderDelivelId(deliveVo.getOrderDelivelId());
vo.setSchemeId(deliveVo.getSchemeId());
// 2. 将新的TbOrderInstallInfoVo对象插入到订单安装记录表中
sqlSessionTemplate.insert("TbOrderInstallInfoMapper.saveInstallInfo", vo);
// 3. 拆分字符串goodsStrs,将信息插入安装明细表中 格式:橱柜~0,马桶~0,瓷砖~1
List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
String[] goods = vo.getGoodsStrs().split(",");
if (null != goods) {
for (String s : goods) {
Map<String, Object> map = new HashMap<String, Object>();
String[] goodsDetail = s.split("~");
if (2 == goodsDetail.length) {
map.put("orderInstallId", vo.getOrderInstallId());
map.put("goodsName", goodsDetail[0]);
// "0"代表未取消 "1"代表已取消
if ("0".equals(goodsDetail[1]) ) {
map.put("isCancel", "Y");
}else {
map.put("isCancel", "N");
}
}
list.add(map);
}
}
sqlSessionTemplate.insert("TbOrderInstallInfoMapper.saveInstallDetail", list);
return vo;
}