一、动态SQL

  1、sql片段

    解决sql语句的冗余代码问题。   

<sql id="SELECT_T_USER">
    select id,name,password,birthday
</sql>

<select id="queryUserById" resultType="User">
    <include refid="SELECT_T_USER"/>
    from t_user
    where id=#{id}
</select>

  2、where子句的处理

    DAO接口代码:

public interface UserDao{

    public User queryUser(@Param("id") Integer id,@Param("name")String name,@Param("password")String password);

}

    mapper文件:

<select id="queryUser" resultType="user">
    <include refid="SELECT_T_USER"/>
    from t_user
    <trim prefix="where" prefixOverrides="and|or">
        <if test="id!=null">
            id=#{id}
        </if>
        <if test="name!=null">
            and name=#{name}
        </if>
        <if test="password!=null">
            and password=#{password}
        </if>
    </trim>
</select>

    解释:prifixOverrides="and|or"----->自动忽略最前面的and或者or。

       prefix="where"------>表示where子句。

       ps、id应该写成包装器类型。因为有可能值为null。

  3、set子句的处理

    Dao接口代码: 

public interface UserDao{

    public void modifyUser(@Param("id")Integer id,@Param("name")String name,@Param("password")String password);

}

    mapper文件:

<update id="modifyUser" parameterType="User">
    update t_user
    <trim prefix="set" suffixOverrides=",">
        <if test="name!=null">
            name=#{name},
        </if>
        <if test="password!=null">
            password=#{password}
        </if>
    </trim>
    where id=#{id}
</update>

    解释:

      predix="set"---->表示set子句。

      suffixOverrides=","------>表示自动忽略最后面的","。

  4、批量查询、删除

    sql语句:

,,)

    DAO接口:

public interface UserDao{

    public List<User> queryUserByIds(List<Integer> ids);

} 

    mapper文件:

<select id="queryUserByIds" resultType="User">
    select * from t_user where id in
    <foreach collection="list" open="(" item="item" separator="," close=")">
        #{item}
    </foreach>
</select>

    解释:

      item="item"------->是当前所遍历的元素。

    delete from t_user where id in (1,2,3)

二、缓存机制

  1、激活mybatis的全局缓存

    a、在mybatis-config.xml中添加语句:

<settings>
    <setting name="cacheEnabled" value="true"/>
</settings>

    b、给对应的mapper文件加入<cache></cache>。

    c、实体要做可序列化的声明

public class User implements Serializable{
    priavte Interger id;
    private String name;
    private String password;
}

    implements Serializable,实现该接口便是声明该类可以被序列化。

  2、注意

    a、只有在sqlSession关闭的时候,mybatis才会把查询的数据放置在缓存中。

    b、脏数据问题:sqlSession在事务提交的时候,会自动清空缓存。

    c、查询操作:操作后,应该关闭sqlSession确保查询的数据可以被缓存。

        增删改操作:操作后,应该进行事务提交,以避免脏数据问题。

 

      

浅谈Mybatis(三)的更多相关文章

  1. 浅谈C++三种传参方式

    浅谈C++三种传参方式 C++给函数传参中,主要有三种方式:分别是值传递.指针传递和引用传递. 下面通过讲解和实例来说明三种方式的区别. 值传递 我们都知道,在函数定义括号中的参数是形参,是给函数内专 ...

  2. 浅谈Mybatis(一)

    一.MyBatis引言 1.基本概念 MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google co ...

  3. 浅谈mybatis如何半自动化解耦

    在JAVA发展过程中,涌现出一系列的ORM框架,JPA,Hibernate,Mybatis和Spring jdbc,本系列,将来研究Mybatis. 通过研究mybatis源码,可将mybatis的大 ...

  4. 浅谈mybatis如何半自动化解耦和ORM实现

    在JAVA发展过程中,涌现出一系列的ORM框架,JPA,Hibernate,Mybatis和Spring jdbc,本系列,将来研究Mybatis. 通过研究mybatis源码,可将mybatis的大 ...

  5. 浅谈Mybatis持久化框架在Spring、SSM、SpringBoot整合的演进及简化过程

    前言 最近开始了SpringBoot相关知识的学习,作为为目前比较流行.用的比较广的Spring框架,是每一个Java学习者及从业者都会接触到一个知识点.作为Spring框架项目,肯定少不了与数据库持 ...

  6. 浅谈mybatis中的#和$的区别

    1. #将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号.如:order by #user_id#,如果传入的值是111,那么解析成sql时的值为order by "111&qu ...

  7. 浅谈Servlet(三)

    一.三种作用域 作用域:web开发中用于存储和获得数据. 1.request 一次请求有效,在forward跳转时可用request作用域传递数据. 2.session client不变,sessio ...

  8. 浅谈TCP三次握手和四次挥手

    学习三次握手和四次挥手前,先了解下几个基础的概念. Seq:数据段序号,我们都知道TCP是提供有序传输的,有序传输的基础就是数据段序号,接收方在收到发送方乱序包的情况下可以根据Seq进行重新排序,确保 ...

  9. 浅谈 Mybatis中的 ${ } 和 #{ }的区别

    好了,真正做开发也差不多一年了.一直都是看别人的博客,自己懒得写,而且也不会写博客,今天就开始慢慢的练习一下写博客吧.前段时间刚好在公司遇到这样的问题. 一.举例说明 select * from us ...

随机推荐

  1. wx.ToolBar

    wx.ToolBar A toolbar is a bar of buttons and/or other controls usually placed below the menu bar in ...

  2. [置顶] java web 动态服务器

    写了一个java web 动态服务器,主要通过内部类来实现,动态类使用了外部类,采用了 classforname 实例化,动态类的构造方法不能带参数, 效果都出来了,分享给有需要的 朋友.判断做的不够 ...

  3. MAC COCOA call command 调用终端控制台程序

    MAC COCOA call command 调用终端控制台程序 STEP 1 先写一个C++ DOS程序 STEP2 使用NSTask来运行,然后用NSPipe和 NSData来接受运行的结果字符串 ...

  4. HBASE学习笔记--shell

    Hbase shell 启动 下载安装hbase client包,填写相关配置后进入,配置相关说明可以参见配置篇 指令:./bin/hbase shell 状态及配置信息查询 查询服务器状态 stat ...

  5. SQL Server数据库--》top关键字,order by排序,distinct去除重复记录,sql聚合函数,模糊查询,通配符,空值处理。。。。

    top关键字:写在select后面 字段的前面 比如你要显示查询的前5条记录,如下所示: select top 5 * from Student 一般情况下,top是和order by连用的 orde ...

  6. 关于Resharper的使用经验

    发现Resharper这东西真的有点累赘,重构也是,一开始用会有很多莫名其妙的提示.现在的项目用了Resharper,js是很方便,有定位功能,但连TypeScript的js都有了.

  7. ES6笔记② 箭头函数

    特性介绍 箭头函数是ES6新增的特性之一,它为JS这门语言提供了一种全新的书写函数的语法. //ES5 function fun(x,y){ return x+y; } console.log(fun ...

  8. static函数和普通函数的区别

    static函数与普通函数的区别: 用static修饰的函数,本限定在本源码文件中,不能被本源码文件以外的代码文件调用.而普通的函数,默认是extern的,也就是说,可以被其它代码文件调用该函数. 在 ...

  9. 图论测试题(一)第一题:longest

    第一题:longest 乌托邦有n个城市,某些城市之间有公路连接.任意两个城市都可以通过公路直接或者间接到达,并且任意两个城市之间有且仅有一条路径(What does this imply? A tr ...

  10. Linux网络管理——TCP/IP四层模型

    1. 网络基础 .note-content {font-family: "Helvetica Neue",Arial,"Hiragino Sans GB",&q ...