Collection翻译过来,意为"集合"的意思,既然是集合,肯定是代表多个。

MyBatis以其自身,小巧易懂,闻名于JavaEE。

传统的JDBC就不说了,Hibernate记得是曾经的持久层框架霸主,记得早在几年前的时候,SSH(Spring+Struts2+Hibernate)是业界中应用最广的。

Hibernate与MyBatis的区别就不多说了,我的相关文章比如ssm框架整合+Ajax异步验证已经说过了,说过不想再重复。

关于JDBC+Hibernate+MyBatis的区别可以参考我的这篇博文MyBatis+Hibernate+JDBC对比分析

mybatis的一对一和一对多以及多对多,一对一倒不常用,一对多和多对多就比较常用了。

<!-- 通用查询映射结果 -->
<resultMap id="BaseResultMap" type="com.entity.FinanceOrder">
<id column="order_no" property="orderNo" />
<result column="user_id" property="userId" />
<result column="order_type" property="orderType" />
<result column="pay_type" property="payType" />
<result column="total_amount" property="totalAmount" />
<result column="order_status" property="orderStatus" />
<result column="subject" property="subject" />
<result column="create_time" property="createTime" />
<result column="amount_type" property="amountType" />
<result column="account_coupon_id" property="accountCouponId" />
<result column="finish_time" property="finishTime" />
<result column="trade_status" property="tradeStatus" />
<result column="invoice" property="invoice" />
<result column="wx_transaction_id" property="wxTransactionId" />
<result column="use_points" property="usePoints" />
<result column="points_amount" property="pointsAmount" />
<result column="balance_amount" property="balanceAmount" />
<result column="wx_amount" property="wxAmount" />
<result column="pwd" property="pwd" />
<result column="remarks" property="remarks" /> <collection property="orderResources" ofType="OrderResources">
<result column="resource_id" property="resourceId" />
</collection> <collection property="orderGuest" ofType="OrderGuest">
<result column="name" property="name" />
</collection>
</resultMap> <!-- 获取当天订单信息 -->
<select id="getTodayOrderInfo" resultMap="BaseResultMap">
SELECT order.order_status,order.create_time, order.finish_time,order.total_amount,order.remarks,rms_order_resources.resource_id,rms_order_guest.name FROM rms_finance_order AS `order`
LEFT JOIN rms_order_resources ON(order.order_no=rms_order_resources.order_no)
LEFT JOIN rms_order_guest ON(order.order_no=rms_order_guest.order_no)
WHERE order.company_code=#{companyCode}
</select>

这个例子可以说是一对多,也可以说是多对多,这并不重要,重要的是你要知道参数的含义。还有就是每当要将sql写入mybatis对应的配置文件时,必须要在mysql相关的客户端或者命令行执行一遍,确认没有问题了,再放入xml配置文件中,这样可以避免很多不必要的错误。

有一点补充说明下:
关于javatype和oftype的区别?
javatype指定的是对象的属性的类型,通常情况下使用<collection>标签默认是集合类型,所以通常就不需要写ArrayList,而oftype指定的是映射到list集合属性中pojo的类型,例如你在集合中放置的类型例如
    List<OrderResources> list
那么oftype对应的类型必须是OrderResources类型,如果mybatis没有对实体进行别名的话,需要写全路径,例如我的OrderResources放置在cn.test包下,我就要将oftype写成cn.test.OrderResources。
不然的话会报找不到类异常。还有要注意的#{companyCode},必须要和参数列表中对应的参数一致,不然会出现两种结果:
 要么出现报错是参数名不对,要么就是不报错显示没有数据。通常情况,sql先执行一遍发现是有数据的,而且条件给的一模一样,这就是需要引起重视了,要么就是你的参数不对,要么就是代码又问题。
我经常遇到的就是参数不对导致无法返回结果,但是单元测试也不会报错。这个时候就要重视了,因为正常情况下通过sql可以查的出数据,但是对应的方法却查不到数据也不报错,最有可能的就是参数名错了,例如#{companyCode},你可能在前台写参数写成company_code,参数不一致,通常不会报错,但也获取不到数据。

MyBatis之Collection的更多相关文章

  1. mybatis的collection查询问题以及使用原生解决方案的结果

    之前在springboot+mybatis环境的坑和sql语句简化技巧的第2点提到,数据库的一对多查询可以一次查询多级数据,并且把拿到的数据按id聚合,使父级表和子级表都有数据. 但是这种查询,必然要 ...

  2. MyBatis嵌套Collection

    站在巨人的肩膀上 https://blog.csdn.net/liaoxiaohua1981/article/details/6862466 聚集元素用来处理“一对多”的关系.需要指定映射的Java实 ...

  3. MyBatis中collection (一对一,一对多)

    MyBatis学习:http://www.mybatis.org/mybatis-3/zh/index.html 大对象InsuranceDetailsVO: com.quicksure.mobile ...

  4. mybatis ForEach Collection集合等规范解析(转)

    转自:http://blog.csdn.net/wj3319/article/details/9025349 在SQL开发过程中,动态构建In集合条件查询是比较常见的用法,在Mybatis中提供了fo ...

  5. Mybatis之collection嵌套查询mapper文件写法

    mapper.xml写法举例 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper ...

  6. MyBatis使用Collection查询多对多或一对多结果集bug

    情况描述:当使用JOIN查询,如果SQL查询出来的记录不是按id列排序的,则生成的List结果会有问题 案例: 1) 数据库模型 简而言之一个Goods包含多个Goods_Img 2) Java Be ...

  7. mybatis中collection和association的作用以及用法

    deptDaoMapper.xml 部门对应员工(1对多的关系) <resultMap type="com.hw.entity.Dept" id="deptinfo ...

  8. Mybatis中collection和association的使用区别

    1. 关联-association2. 集合-collection 比如同时有User.java和Card.java两个类 User.java如下: public class User{ privat ...

  9. mybatis中collection association优化使用及多参数传递

    mybatis都会用,但要优雅的用就不是那么容易了 今天就简单举例,抛砖引玉,供大家探讨 1.主表 CREATE TABLE `test_one` ( `id` int(11) NOT NULL AU ...

随机推荐

  1. CentOS命令行与shell操作(linux系管与运维二)

    原创作品,转载请注明出处:https://www.cnblogs.com/sunshine5683/p/10293729.html 在上篇文章中总结了Linux常用的开机与关机以及重启的命令,今天继续 ...

  2. Java - "JUC" CountDownLatch源码分析

    Java多线程系列--“JUC锁”09之 CountDownLatch原理和示例 CountDownLatch简介 CountDownLatch是一个同步辅助类,在完成一组正在其他线程中执行的操作之前 ...

  3. protocol buffer c#

    第一.打开vs中的Nuget

  4. POJ3268(KB4-D spfa)

    Silver Cow Party Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 23426   Accepted: 1069 ...

  5. HDU1257(dp)

    最少拦截系统 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Subm ...

  6. JS UNIX 时间戳与时间格式转换

    上代码,不多说了,这个没啥说的,记录一下: var date = new Date() // Date 2019-03-05T13:50:39.775Z // 获取1970 至今的毫秒数 var ti ...

  7. ajax jsonp的跨域请求

    1.页面ajax的请求 $.ajax({ async: false, url: 'http://localhost:8080/downloadVideos',//跨域的dns/document!sea ...

  8. Webpack 常用命令总结以及常用打包压缩方法

    前言:Webpack是一款基于node的前端打包工具,它可以将很多静态文件打包起来,自动处理依赖关系后,生成一个.js文件,然后让html来引用,不仅可以做到按需加载,而且可以减少HTTP请求,节约带 ...

  9. 微信小程序< 2 > ~ 微信小程序之头条新闻

    简介 上一篇文章,主要是介绍下微信小程序的开发环境安装和微信组件什么的一些基础的开发内容,所以最近一直在业余找练手的机会.由于之前没有接触过JS,自己学习起来还算是比较的吃力,一点一点的来吧!要持久. ...

  10. 成为Java顶尖程序员,先过了下面问题!

    一.数据结构与算法基础 说一下几种常见的排序算法和分别的复杂度. 用Java写一个冒泡排序算法 描述一下链式存储结构. 如何遍历一棵二叉树? 倒排一个LinkedList. 用Java写一个递归遍历目 ...