mybatis的<foreach>标签的高级使用

该代码示例展示了如何在Java中通过Map和List实现同时满足两个查询条件的循环查询。在serviceImpl.java中,创建了一个Map列表来存储查询参数,然后通过mapper接口和XML映射文件进行数据库查询。查询逻辑在mapper.xml中,利用了MyBatis的动态SQL来处理多个条件。当查询结果不为空时,返回查询结果列表。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本代码的功能:实现2个查询条件同时满足的循环查询。
将每次要传递的2个参数使用map存储起来,然后再把map存储在List集合中,每次遍历一个map,然后在map中获取要传递的数据。
其实,按照这种思想,可以实现同时满足"N"个查询条件的循环语句。
serviceImpl.java

@Override
	public List<NutritionalComposition> findElementWeightByPratiesIdListAndStatusListandPreparationWeightList(List<Integer> pratiesIdList, List<Integer> statusList) {

		List<Map<String,Integer>> mapList = new ArrayList<Map<String,Integer>>();
		for(int i = 0; i < pratiesIdList.size(); i++){
			Map<String,Integer> map = new HashMap<>();
			map.put("partiesId", pratiesIdList.get(i));
			map.put("status", statusList.get(i));
			mapList.add(map);
		}
		List<NutritionalComposition> list = stoNutritionElementMapper.selectElementWeightByPratiesIdListAndStatusList(mapList);
		if(list != null && list.size() > 0){
			
			return list;
		}else{
			return null;
		}

	}

mapper.java


	List<NutritionalComposition> selectElementWeightByPratiesIdListAndStatusList(@Param("mapList") List<Map<String,Integer>> mapList);

mapper.xml

<select id="selectElementWeightByPratiesIdListAndStatusList" resultType="com.my.en.pojo.custom.NutritionalComposition" parameterType="list" >
		select
			a.ELEMENT_NAME elementName,
			a.UNIT unit,
			a.PARTIES_ID partiesId,
			a.`STATUS` status,
			sum(a.ELEMENT_WEIGHT * (b.NUTRITION_WEIGHT / 100)) elementWeight
		from
			(
				select

					sne.ELEMENT_NAME,
					sne.NUTRITION_ID,
					sne.ELEMENT_ID,
					sne.ELEMENT_WEIGHT,
					sne.UNIT,
					rpd.PARTIES_ID,
					rpd.`STATUS` status
				from
					sto_nutrition_element sne
				left join
					rec_parties_details rpd
				on
					rpd.NUTRITION_ID = sne.NUTRITION_ID
				<where>
					sne.DELETE_MARK = 0
					<if test="mapList != null">
						<foreach collection="mapList" item="map" open=" and (" close=")"
								 separator="or">
							(rpd.PARTIES_ID = #{map.partiesId}  and rpd.`STATUS` = #{map.status})
						</foreach>
					</if>

				</where>
				ORDER BY `STATUS`
			)a
		left join
			(
				select
					NUTRITION_ID,
					NUTRITION_WEIGHT,
					`STATUS`
				from
					rec_parties_details
				<where>
					<if test="mapList != null">
						<foreach collection="mapList" item="map" open=" and (" close=")"
								 separator="or">
							(PARTIES_ID = #{map.partiesId}  and `STATUS` = #{map.status})
						</foreach>
					</if>

				</where>
			)b
		on
			a.NUTRITION_ID = b.NUTRITION_ID and a.`STATUS` = b.`STATUS`
		GROUP BY
			a.ELEMENT_ID,
			a.PARTIES_ID,
			a.`STATUS`
		ORDER BY
			a.`STATUS`,
			a.ELEMENT_ID
	</select>
出现这个错误的原因是在导入seaborn包时,无法从typing模块中导入名为'Protocol'的对象。 解决这个问题的方法有以下几种: 1. 检查你的Python版本是否符合seaborn包的要求,如果不符合,尝试更新Python版本。 2. 检查你的环境中是否安装了typing_extensions包,如果没有安装,可以使用以下命令安装:pip install typing_extensions。 3. 如果你使用的是Python 3.8版本以下的版本,你可以尝试使用typing_extensions包来代替typing模块来解决该问题。 4. 检查你的代码是否正确导入了seaborn包,并且没有其他导入错误。 5. 如果以上方法都无法解决问题,可以尝试在你的代码中使用其他的可替代包或者更新seaborn包的版本来解决该问题。 总结: 出现ImportError: cannot import name 'Protocol' from 'typing'错误的原因可能是由于Python版本不兼容、缺少typing_extensions包或者导入错误等原因造成的。可以根据具体情况尝试上述方法来解决该问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [ImportError: cannot import name ‘Literal‘ from ‘typing‘ (D:\Anaconda\envs\tensorflow\lib\typing....](https://blog.youkuaiyun.com/yuhaix/article/details/124528628)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值