mybatis collection 多条件查询的实现方法

mybatis collection 多条件查询的实现方法

前言:

业务需要通过mybatis 查询返回嵌套集合,嫌多次查询太麻烦,用自带的高级查询解决问题,下边是代码,已测试通过。

说下自己的理解,就是一个主查询结果集里面嵌套了子查询的结果集,可以是多个子查询,每个子查询的条件从主查询结果集中获取,返回值各自定义。collection 标签的property是主查询里面集合的名字,如果有多个就再写个collection,column是子查询参数,单参数直接写主查询结合返回结果,例如直接写上user_id,要是数据库的字段,多条件就封装下,例如{userId=user_id,theme=theme},然后子查询的parameterType写"java.util.Map",多条件查询好像只有mybatis3.0以后才有,看网上资料说的,没验证过,ofType是集合里的对象,select是对应下面的语句

实现代码:

<resultMap id="BaseResultMap" type="web.model.UserMessage" > <id column="id" property="id" jdbcType="INTEGER" /> <result column="user_id" property="userId" jdbcType="INTEGER" /> <result column="theme" property="theme" jdbcType="VARCHAR" /> <result column="status" property="status" jdbcType="INTEGER" /> <result column="theme_time" property="themeTime" jdbcType="TIMESTAMP" /> <result column="create_time" property="createTime" jdbcType="TIMESTAMP" /> <result column="update_time" property="updateTime" jdbcType="TIMESTAMP" /> <result column="yn" property="yn" jdbcType="INTEGER" /> </resultMap> <resultMap id="BaseVoResultMap" type="web.model.vo.UserMessageVo" extends="BaseResultMap"> <collection property="userMessageDetailList" column="{userId=user_id,theme=theme}" javaType="java.util.ArrayList" ofType="web.model.UserMessageDetail" select="selectUserMessageDetailById"/> </resultMap> <resultMap id="BaseDetailResultMap" type="web.model.UserMessageDetail" > <id column="id" property="id" jdbcType="INTEGER" /> <result column="user_message_id" property="userMessageId" jdbcType="INTEGER" /> <result column="sponsor_id" property="sponsorId" jdbcType="INTEGER" /> <result column="user_id" property="userId" jdbcType="INTEGER" /> <result column="user_type" property="userType" jdbcType="INTEGER" /> <result column="provider_id" property="providerId" jdbcType="INTEGER" /> <result column="message" property="message" jdbcType="VARCHAR" /> <result column="status" property="status" jdbcType="INTEGER" /> <result column="message_time" property="messageTime" jdbcType="TIMESTAMP" /> <result column="create_time" property="createTime" jdbcType="TIMESTAMP" /> <result column="update_time" property="updateTime" jdbcType="TIMESTAMP" /> <result column="yn" property="yn" jdbcType="INTEGER" /> </resultMap> <select id="selectUserMessageById" resultMap="BaseVoResultMap" parameterType="java.lang.Integer"> select * from user_message where user_id = #{userId,jdbcType=INTEGER} </select> <select id="selectUserMessageDetailById" resultMap="BaseDetailResultMap" parameterType="java.util.Map"> select * from user_message_detail where user_id = #{userId,jdbcType=INTEGER} and message = #{theme,jdbcType=VARCHAR} </select>

selectUserMessageById,这个是主查询,VO只多了个 private List<UserMessageDetail> userMessageDetailList,

这个属性,下面是返回值结构截图

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

时间: 2024-09-28 07:27:32

mybatis collection 多条件查询的实现方法的相关文章

多条件数据库查询的优化方法

在数据库编程中,管理人员需要经常从数据库中查询数据.当查询条件为确定时,我们可以明确用的SQL语句来实现,但是当查询条件为多个条件的动态组合时,查询语句会由于分支太多及IF语句的多重嵌套而变得相当复杂.在此,笔者提供了一种优化方法,运用本方法可以有效地减少查询语句的分支和数量以及IF条件语句的嵌套层数,从而提高程序的运行效率. 下面我们以一个简单的例子来说明,假设有一个名为employee的表,现在我们要从其中查询数据,条件有三个,由用户动态选择,如图1所示: 其中条件A.B.C之间是与的关系,

linq to entities-Linq to entities 多条件查询问题不知道有什么方法呢。

问题描述 Linq to entities 多条件查询问题不知道有什么方法呢. 在用实体类建模时候,用Linq根据条件查询数据表,对于多个条件的查询,原来是需要什么条件就写一个方法,在开发途中发现条件确实是太多= =, 便想用几个公用方法来包含这些条件,也就是条件为空的时候不执行这个where罢了 比如: if (FromUserId != """" && ToUserId != """") { var que

net-用个EF框架的泛形类(BaseDal),按条件查询 的方法,排序的lambda表达式不知道写

问题描述 用个EF框架的泛形类(BaseDal),按条件查询 的方法,排序的lambda表达式不知道写 .net的mvc开发中,我用了一个EF框架的泛形类(BaseDal),我在里面写了一个按条件查询 的方法,但是那个排序的lambda表达式我不知道写 public static List<T> GetPageListBy<TKey>(int pageIndex, int pageSize, ref int rowCount, System.Linq.Expressions.Exp

求一份Struts2+Spring+mybatis整合的增删改查及分页和多条件查询的源代码

问题描述 求一份Struts2+Spring+mybatis整合的增删改查及分页和多条件查询的源代码 小白求一份Struts2+Spring+mybatis整合的增删改查及分页和多条件查询的源代码,用jQuery实现jsp页面 解决方案 SpringMVC+Spring+mybatis是否需要呢?笔者之前写了一些相关的文章,也有源代码,你可以参考下:http://blog.csdn.net/evankaka/article/details/49452201http://blog.csdn.net

ii-YII中多条件查询的方法

问题描述 YII中多条件查询的方法 比如:$criteria->addCondition("id=1"); //查询条件,即where id = 1 现在想查询 id为1 和 name为zhangsan 的怎么写查询条件呢,就是怎么查询多个条件呢? 解决方案 YII中自定义查询条件Linq 多条件模糊查询的方法Yii中CDbCriteria查询条件收集 解决方案二: addCondition("id=1 && name='zhangsan '"

实现一个让用户自定义查询条件的查询用什么方法呢?

问题描述 实现一个让用户自定义查询条件的查询用什么方法呢? 解决方案 解决方案二:引用楼主yaoruimei的回复: 实现一个让用户自定义查询条件的查询用什么方法呢? 能说具体点吗?解决方案三:路过的表示没看懂什么意思解决方案四:例如:我们现在在做人事系统.涉及到人员的信息很多有姓名,性别等等.如果查询的时候可能不完全按所有条件查询需要用户自定义的选择人员属性中的几项进行查询.这个条件是用户自定义定的.例如按姓名查询:系统有一个地方出现姓名是等于什么或者包含什么,然后还可以针对这几个条件进行逻辑

javascript:设置URL参数的方法,适合多条件查询

 适用场景:多条件查询情况,如下图所示:  通过设置URL参数,再结合数据源控件设置的RUL参数,就能进行简单的多条件查询了. javascript函数: <mce:script type="text/javascript"><!-- //设置URL参数的方法 function setParmsValue(parms, parmsValue) { var urlstrings = document.URL; var args = GetUrlParms(); var

SQL 多条件查询几种实现方法详细介绍

SQL 多条件查询 以后我们做多条件查询,一种是排列结合,另一种是动态拼接SQL 如:我们要有两个条件,一个日期@addDate,一个是@name 第一种写法是 if (@addDate is not null) and (@name <> '') select * from table where addDate = @addDate and name = @name else if (@addDate is not null) and (@name ='') select * from t

根据多条件查询临时表 想得到不同结果集的方法_MsSql

当我写下如下sql语句时,我得到了输入@c参数时想得到的结果集.select * from @tb t where t.id in (select id from tb where f = @c) 但如果有@a,@b,@c,而它们分别想从@tb中得到不同的结果集,例如 复制代码 代码如下: if @a is not null begin --得到@a想得到的 end if @b is not null begin --得到@b想得到的 end if @c is not null begin --