mybatis怎么利用resultMap复杂类型list映射
短信预约 -IT技能 免费直播动态提醒
这篇文章主要介绍“mybatis怎么利用resultMap复杂类型list映射”,在日常操作中,相信很多人在mybatis怎么利用resultMap复杂类型list映射问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mybatis怎么利用resultMap复杂类型list映射”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
mybatis resultMap复杂类型list映射
映射泛型为对象
xml
<resultMap id="internetDataDTO" type="com.mdm.skr.mdm_common.dto.StrategyInternetDataDTO"> <id property="id" column="id" jdbcType="INTEGER"/> <result property="internetData" column="internet_data" jdbcType="INTEGER"/> <collection property="userList" ofType="com.mdm.skr.mdm_common.entity.SysUser"> <id property="id" column="id" jdbcType="INTEGER"/> <result property="number" column="number" jdbcType="VARCHAR"/> <result property="pushToken" column="push_token" jdbcType="VARCHAR"/> <result property="wsChannelId" column="ws_channel_id" jdbcType="VARCHAR"/> </collection></resultMap> <select id="selectInternetDataDTOByInternetDataIdList" resultMap="internetDataDTO"> SELECT sidu.id, sidu.internet_data, su.id, su.number, su.push_token, su.ws_channel_id FROM strategy_internet_data_user sidu JOIN skr_user su on su.id = sidu.user_id WHERE sidu.id IN <foreach collection="internetDataIdList" open="(" close=")" separator="," item="internetDataId"> #{internetDataId} </foreach></select>
DTO
@Datapublic class StrategyInternetDataDTO { private Integer id ; private Integer internetData ; private List<SysUser> userList ; }
ENTITY
@Datapublic class SysUser { private Integer id; private String number; private String pushToken; private String wsChannelId ; }
MAPPER
List<StrategyInternetDataDTO> selectInternetDataDTOByInternetDataIdList(@Param("internetDataIdList") List<Integer> internetDataIdList);
映射泛型为包装类型
xml
<resultMap id="internetDataDTO" type="com.mdm.skr.mdm_common.dto.StrategyInternetDataDTO"> <id property="id" column="id" jdbcType="INTEGER"/> <result property="internetData" column="internet_data" jdbcType="INTEGER"/> <collection property="userIdList" ofType="java.lang.Integer" javaType="java.util.List"> <result column="userId"/> </collection></resultMap> <select id="selectInternetDataDTOByInternetDataIdList" resultMap="internetDataDTO"> SELECT sidu.id, sidu.internet_data, sidu.user_id userId FROM strategy_internet_data_user sidu WHERE sidu.id IN <foreach collection="internetDataIdList" open="(" close=")" separator="," item="internetDataId"> #{internetDataId} </foreach></select>
DTO
@Datapublic class StrategyInternetDataDTO { private Integer id ; private Integer internetData ; private List<Integer> userIdList ; }
MAPPER
List<StrategyInternetDataDTO> selectInternetDataDTOByInternetDataIdList(@Param("internetDataIdList") List<Integer> internetDataIdList);
mybatis的几种传值方式
1.单个参数传参
User selectUserInfo(Integer userId);<select id = "selectUserInfo" parameterType = "java.lang.Inte" resultMap="BaseResultMap" > select <include refid="Base_Column_List" /> from user where userId = #{userId , jdbcType=INTEGER}</select>
2. 按照顺序传参
User selectUserInfo(Integer userId, String userName, String userPass);<select id = "selectUserInfo" resultMap="BaseResultMap" > select <include refid="Base_Column_List" /> from user where userId = #{arg0} and userName = #{arg1} and userPass = #{arg2}</select>
3. 使用@Param注解传参
User selectUserInfo(@Param("userName")String userName, @Param("userPass")String userPass);<select id = "selectUserInfo" resultMap="BaseResultMap" > select <include refid="Base_Column_List" /> from user where userName = #{userName} and userPass = #{userPass}</select>
4. 使用Map传参 注意传参方式:parameterType="java.util.Map"
Map<String,Object> map = new HashMap();map.put("userName","张三");map.put("userPass","123");User user = userMapper.selectUserInfo(map);User selectUserInfo(Map<String,Object> map);<select id="selectUserInfo" parameterType="java.util.Map" resultMap="BaseResultMap" > select <include refid="Base_Column_List" /> from user where userName = #{userName} and userPass = #{userPass}</select>
5. 实体对象传参
User user = new User();user.setUserName("张三");user.setUserPass("123");User user = UserMapper.selectUserInfo(user);User selectUserInfo(User record);<select id="selectUserInfo" parameterType="com.LiuXu.bean.User" resultMap="BaseResultMap" > select <include refid="Base_Column_List" /> from user where userName = #{userName} and userPass = #{userPass}</select>
6. List传参
List<User> list = new ArrayList<>();list.add(user1);list.add(user2);List<User> userList = userMapper.selectUserInfo(list); List<User> selectUserInfo(List<User> record);<select id="selectUserInfo" resultMap="BaseResultMap" > select <include refid="Base_Column_List" /> from user where userId in <foreach item="item" index="index" collection="list" open="(" separator="," close=")"> #{item} </foreach></select>
到此,关于“mybatis怎么利用resultMap复杂类型list映射”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341