mybatis 的一些常用功能

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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏应兆康的专栏

Python Web - Flask笔记6

mysql级别的外键,还不够ORM,必须拿到一个表的外键,然后通过这个外键再去另外一张表中查找,这样太麻烦了。SQLAlchemy提供了一个relationsh...

18110
来自专栏蓝天

Redis基于eval的多字段原子增量计算

一些应用场景需要对多个值进行原子计数,Redis的eval+hincrby可以达到目标,但如果计算的字段比较多时,效率会是个问题,它的时间复杂度为O(N),而...

9520
来自专栏腾讯云数据库团队的专栏

MySQL 5.7 JSON 实现简介

本文主要介绍了MySQL在5.7.7之后引入的原生JSON支持的特性,说明了引入JSON类型的好处,并结合具体的示例介绍了MySQL在JSON类型上对外的接口以...

5.8K10
来自专栏云数据库

MySQL5.7 JSON实现简介

本文主要介绍在MySQL 5.7.7开始引入的非结构化数据类型JSON的特性以及具体的实现方式(包括存储方式)。首先介绍为什么要引入JSON的原生数据类型的支持...

29440
来自专栏听雨堂

Python防止sql注入

看了网上文章,说的都挺好的,给cursor.execute传递格式串和参数,就能防止注入,但是我写了代码,却死活跑不通,怀疑自己用了一个假的python 最后,...

40370
来自专栏黑泽君的专栏

day31_Hibernate复习_03(补刀)

8110
来自专栏xingoo, 一个梦想做发明家的程序员

Java程序员的日常——存储过程知识普及

存储过程是保存可以接受或返回用户提供参数的SQL语句集合。在日常的使用中,经常会遇到复杂的业务逻辑和对数据库的操作,使用存储过程可以进行封装。可以在数据库中定...

19780
来自专栏蓝天

IDL编译器实现入门

本文不对词法和语法、以及flex和bison进行介绍,如有需要,可以阅读《RPC的实现》。本文试图用直接的方式,以最短的篇幅介绍一个最简单的IDL编译器实现。...

25530
来自专栏杨建荣的学习笔记

简单分析shared pool(一) (r3笔记46天)

oracle中的shared pool很重要,但是感觉知之甚少。今天想在原来的认识上能够有一点更深入的了解。 简单做了一个总结。 首先是转储一下shared ...

34670
来自专栏运维一切

模拟linux内存管理代码 转

这个代码模拟实现了linux内存管理的三个算法ff、wf、bf。这三个算法都是连续分配的方式,这种方式的缺点就是内存碎片很难被再次利用。

9510

扫码关注云+社区

领取腾讯云代金券