文档章节

mybatis 的一些常用功能

yawn-silence
 yawn-silence
发布于 2016/09/22 23:15
字数 1394
阅读 40
收藏 3

1. association 查询结果的一对一关联:

<resultMap id="blogResult" type="Blog">
  <id property=”blog_id” column="id" />
  <result property="title" column="blog_title"/>
  <association property="author" column="blog_author_id" javaType="Author">
    <id property="id" column="author_id"/>
    <result property="username" column="author_username"/>
    <result property="password" column="author_password"/>
    <result property="email" column="author_email"/>
    <result property="bio" column="author_bio"/>
  </association>
</resultMap>

2. collection查询结果的一对多关联:

<resultMap id="blogResult" type="Blog">
  <id property=”id” column="blog_id" />
  <result property="title" column="blog_title"/>
  <collection property="posts" ofType="Post">
    <id property="id" column="post_id"/>
    <result property="subject" column="post_subject"/>
    <result property="body" column="post_body"/>
  </collection>
</resultMap>

3. discriminator鉴别器(一):

    有时一个单独的数据库查询也许返回很多不同(但是希望有些关联)数据类型的结果集。
鉴别器元素就是被设计来处理这个情况的,还有包括类的继承层次结构。鉴别器非常容易理
解,因为它的表现很像 Java 语言中的 switch 语句。
    定义鉴别器指定了 column 和 javaType 属性。列是 MyBatis 查找比较值的地方。 JavaType
是需要被用来保证等价测试的合适类型(尽管字符串在很多情形下都会有用)。比如:

<resultMap id="vehicleResult" type="Vehicle">
  <id property=”id” column="id" />
  <result property="vin" column="vin"/>
  <result property="year" column="year"/>
  <result property="make" column="make"/>
  <result property="model" column="model"/>
  <result property="color" column="color"/>
  <discriminator javaType="int" column="vehicle_type">
    <case value="1" resultMap="carResult"/>
    <case value="2" resultMap="truckResult"/>
    <case value="3" resultMap="vanResult"/>
    <case value="4" resultMap="suvResult"/>
  </discriminator>
</resultMap>

<resultMap id="carResult" type="Car">
  <result property="doorCount" column="door_count" />
</resultMap>

     这个例子中,如果vehicle_type的值是1,则会使用carResult,即只加载doorCount属性,如果需要加载vehicleResult中的属性,则需要让carResult继承vehicleResult,使用如下:

<resultMap id="carResult" type="Car" extends=”vehicleResult”>
  <result property=”doorCount” column="door_count" />
</resultMap>

4. discriminator鉴别器(二):

    还有一种方式可以实现上面的效果:

<resultMap id="vehicleResult" type="Vehicle">
  <id property=”id” column="id" />
  <result property="vin" column="vin"/>
  <result property="year" column="year"/>
  <result property="make" column="make"/>
  <result property="model" column="model"/>
  <result property="color" column="color"/>
  <discriminator javaType="int" column="vehicle_type">
    <case value="1" resultType="carResult">
      <result property=”doorCount” column="door_count" />
    </case>
    <case value="2" resultType="truckResult">
      <result property=”boxSize” column="box_size" />
      <result property=”extendedCab” column="extended_cab" />
    </case>
    <case value="3" resultType="vanResult">
      <result property=”powerSlidingDoor” column="power_sliding_door" />
    </case>
    <case value="4" resultType="suvResult">
      <result property=”allWheelDrive” column="all_wheel_drive" />
    </case>
  </discriminator>
</resultMap>

5. 缓存:

    同hibernate一样,一级缓存(session级)是默认开启的,如果需要开启二级缓存,就需要加以下配置:

<!-- 在核心配置文件中加入配置 -->
<setting name="cacheEnabled" value="true"/>

<!-- 在mapper文件中加入配置 -->
<cache />

    <cache /> 语句的效果如下:

  •     映射语句文件中的所有 select 语句将会被缓存。
  •     映射语句文件中的所有 insert, update 和 delete 语句会刷新缓存。
  •     缓存会使用 Least Recently Used( LRU,最近最少使用的)算法来收回。
  •     根据时间表(比如 no Flush Interval,没有刷新间隔),缓存不会以任何时间顺序来刷新。
  •     缓存会存储列表集合或对象(无论查询方法返回什么)的 1024 个引用。
  •     缓存会被视为是 read/write(可读/可写)的缓存,意味着对象检索不是共享的,而且可以安全地被调用者修改,而不干扰其他调用者或线程所做的潜在修改。

    所有的这些属性都可以通过缓存元素的属性来修改。比如:

<cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>

    这个更高级的配置创建了一个 FIFO 缓存,并每隔 60 秒刷新, 存数结果对象或列表的512 个引用,而且返回的对象被认为是只读的,因此在不同线程中的调用者之间修改它们会导致冲突。
    可用的收回策略有:
 LRU – 最近最少使用的:移除最长时间不被使用的对象。
 FIFO – 先进先出:按对象进入缓存的顺序来移除它们。
 SOFT – 软引用:移除基于垃圾回收器状态和软引用规则的对象。
 WEAK – 弱引用:更积极地移除基于垃圾收集器状态和弱引用规则的对象。
默认的是 LRU。
    flushInterval(刷新间隔)可以被设置为任意的正整数,而且它们代表一个合理的毫秒形式的时间段。默认情况是不设置,也就是没有刷新间隔,缓存仅仅调用语句时刷新。
    size(引用数目)可以被设置为任意正整数,要记住你缓存的对象数目和你运行环境的可用内存资源数目。默认值是 1024。
    readOnly(只读)属性可以被设置为 true 或 false。只读的缓存会给所有调用者返回缓存对象的相同实例。因此这些对象不能被修改。这提供了很重要的性能优势。可读写的缓存会返回缓存对象的拷贝(通过序列化)。这会慢一些,但是安全,因此默认是 false。

6. 动态sql:

  1)条件

      if 和 choose when otherwise

<select id=”findActiveBlogLike” parameterType=”Blog” resultType=”Blog”>
  SELECT * FROM BLOG WHERE state = „ACTIVE‟
  <choose>
    <when test=”title != null”>
      AND title like #{title}
    </when>
    <when test=”author != null and author.name != null”>
      AND title like #{author.name}
    </when>
    <otherwise>
      AND featured = 1
    </otherwise>
  </choose>
</select>

  2)关键字

      where 和 set

<!-- 取代where关键字,当所有if条件不成立时就不会出现where关键字 -->
<select id=”findActiveBlogLike” parameterType=”Blog” resultType=”Blog”>
  SELECT * FROM BLOG
  <where>
    <if test=”state != null”>
      state = #{state}
    </if>
    <if test=”title != null”>
      AND title like #{title}
    </if>
    <if test=”author != null and author.name != null”>
      AND title like #{author.name}
    </if>
  </where>
</select>


<update id="updateAuthorIfNecessary" parameterType="domain.blog.Author">
  update Author
  <set>
    <if test="username != null">username=#{username},</if>
    <if test="password != null">password=#{password},</if>
    <if test="email != null">email=#{email},</if>
    <if test="bio != null">bio=#{bio}</if>
  </set>
  where id=#{id}
</update>

  3)foreach

<select id="selectPostIn" resultType="domain.blog.Post">
  SELECT * FROM POST P WHERE ID in
  <foreach item="item" index="index" collection="list" open="(" separator="," close=")">
    #{item}
  </foreach>
</select>

foreach详细用法: http://www.cnblogs.com/zzgno1/p/4184601.html

© 著作权归作者所有

共有 人打赏支持
yawn-silence
粉丝 30
博文 66
码字总数 32156
作品 0
广州
高级程序员
私信 提问
MyBatis增强工具pndao-帮你自动写SQL

pndao是票牛技术团队在使用的MyBatis增强工具,它可以根据一些方法约定,自动生成SQL。它在实际生产中减少了80%以上的重复SQL编写工作。 起因 作为Java后端开发,写DAO是个日常的不能再日常的...

黄亿华
2016/10/31
7.1K
26
Quella_v1.4 版本发布,Java 开源后台管理框架

本次更新: #主要是对系统性能和安全做优化 使用Redis作为mybatis的二级缓存 使用SpringAOP和自定义注解完成Redis缓存 XSS攻击安全过滤 定时任务可视化控制 富文本可直接嵌入表单 增加系统全...

上善若水iii
2018/12/08
0
0
mybatis-config.xml配置

学习一个框架,必须详细的了解其配置文件,并通过一定的源码分析才能更灵活的运用,根据自己的项目实现一些特殊的、自定义的功能,下面详细看看Mybatis的全局配置文件 因为mybatis经常和其他...

特拉仔
2018/01/18
1
0
老成 FMS 5.0 发布:多处更新,通用的模板告别拷贝 jsp

老成 FMS 5.0 版本除了修改以前版本的各种 bug 外,功能增强是最大特色 增强 mybatis 的通用 service 功能,增删改查,事务都支持对象一次性搞定 前端 ui 代码在线生成 通用的列表与表单模板...

老成有木有
2018/05/30
1K
1
ibatis MyBatis区别与联系

简介: 本文主要讲述了 iBatis 2.x 和 MyBatis 3.0.x 的区别,以及从 iBatis 向 MyBatis 移植时需要注意的地方。通过对本文的学习,读者基本能够了解 MyBatis 有哪些方面的改进,并能够顺利使...

为了美好的明天
2018/04/17
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Confluence 6 升级中的一些常见问题

升级的时候遇到了问题了吗? 如果你想尝试重新进行升级的话,你需要首先重新恢复老的备份。不要尝试再次对 Confluence 进行升级或者在升级失败后重新启动老的 Confluence。 在升级过程中的一...

honeymoose
今天
2
0
C++随笔(四)Nuget打包

首先把自己编译好的包全部准备到一个文件夹 像这样 接下来新建一个文本文档,后缀名叫.nuspec 填写内容 <?xml version="1.0"?><package xmlns="http://schemas.microsoft.com/packaging/201......

Pulsar-V
今天
2
0
再谈使用开源软件搭建数据分析平台

三年前,我写了这篇博客使用开源软件快速搭建数据分析平台, 当时收到了许多的反馈,有50个点赞和300+的收藏。到现在我还能收到一些关于dataplay2的问题。在过去的三年,开源社区和新技术的发...

naughty
今天
5
0
Python3的日期和时间

python 中处理日期时间数据通常使用datetime和time库 因为这两个库中的一些功能有些重复,所以,首先我们来比较一下这两个库的区别,这可以帮助我们在适当的情况下时候合适的库。 在Python文...

编程老陆
今天
2
0
分布式面试整理

并发和并行 并行是两个任务同时进行,而并发呢,则是一会做一个任务一会又切换做另一个任务。 临界区 临界区用来表示一种公共资源或者说是共享数据,可以被多个线程使用,但是每一次,只能有...

群星纪元
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部