目录(?)[-]

  1. 二SQL语句映射文件2增删改查参数缓存
    1. select
    2. insert
    3. updatedelete
    4. sql
    5. parameters
      1. 基本类型参数
      2. Java实体类型参数
      3. Map参数
      4. 多参数的实现
      5. 字符串代入法
    6. cache缓存
 

二、SQL语句映射文件(2)增删改查、参数、缓存

MyBatis学习 之 一、MyBatis简介与配置MyBatis+Spring+MySql

MyBatis学习 之 二、SQL语句映射文件(1)resultMap

MyBatis学习 之 二、SQL语句映射文件(2)增删改查、参数、缓存

MyBatis学习 之 三、动态SQL语句

MyBatis学习 之 四、MyBatis配置文件

2.2 select

一个select 元素非常简单。例如:

  1. <!-- 查询学生,根据id -->
  2. <select id="getStudent" parameterType="String" resultMap="studentResultMap">
  3. SELECT ST.STUDENT_ID,
  4. ST.STUDENT_NAME,
  5. ST.STUDENT_SEX,
  6. ST.STUDENT_BIRTHDAY,
  7. ST.CLASS_ID
  8. FROM STUDENT_TBL ST
  9. WHERE ST.STUDENT_ID = #{studentID}
  10. </select>

这条语句就叫做‘getStudent,有一个String参数,并返回一个StudentEntity类型的对象。 注意参数的标识是:#{studentID}。

select 语句属性配置细节:

属性 描述 取值 默认
id 在这个模式下唯一的标识符,可被其它语句引用    
parameterType 传给此语句的参数的完整类名或别名    
resultType 语句返回值类型的整类名或别名。注意,如果是集合,那么这里填写的是集合的项的整类名或别名,而不是集合本身的类名。(resultType 与resultMap 不能并用)    
resultMap 引用的外部resultMap 名。结果集映射是MyBatis 中最强大的特性。许多复杂的映射都可以轻松解决。(resultType 与resultMap 不能并用)    
flushCache 如果设为true,则会在每次语句调用的时候就会清空缓存。select 语句默认设为false true|false false
useCache 如果设为true,则语句的结果集将被缓存。select 语句默认设为false true|false false timeout 设置驱动器在抛出异常前等待回应的最长时间,默认为不设值,由驱动器自己决定 true|false false
timeout  设置驱动器在抛出异常前等待回应的最长时间,默认为不设值,由驱动器自己决定 正整数 未设置
fetchSize 设置一个值后,驱动器会在结果集数目达到此数值后,激发返回,默认为不设值,由驱动器自己决定 正整数 驱动器决定
statementType statement,preparedstatement,callablestatement。 预准备语句、可调用语句 STATEMENT PREPARED CALLABLE PREPARED
resultSetType forward_only,scroll_sensitive,scroll_insensitive 只转发,滚动敏感,不区分大小写的滚动 FORWARD_ONLY SCROLL_SENSITIVE SCROLL_INSENSITIVE 驱动器决定

2.3 insert

一个简单的insert语句:

  1. <!-- 插入学生 -->
  2. <insert id="insertStudent" parameterType="StudentEntity">
  3. INSERT INTO STUDENT_TBL (STUDENT_ID,
  4. STUDENT_NAME,
  5. STUDENT_SEX,
  6. STUDENT_BIRTHDAY,
  7. CLASS_ID)
  8. VALUES   (#{studentID},
  9. #{studentName},
  10. #{studentSex},
  11. #{studentBirthday},
  12. #{classEntity.classID})
  13. </insert>

insert可以使用数据库支持的自动生成主键策略,设置useGeneratedKeys=”true”,然后把keyProperty 设成对应的列,就搞定了。比如说上面的StudentEntity 使用auto-generated 为id 列生成主键.  还可以使用selectKey元素。下面例子,使用mysql数据库nextval('student')为自定义函数,用来生成一个key。

  1. <!-- 插入学生 自动主键-->
  2. <insert id="insertStudentAutoKey" parameterType="StudentEntity">
  3. <selectKey keyProperty="studentID" resultType="String" order="BEFORE">
  4. select nextval('student')
  5. </selectKey>
  6. INSERT INTO STUDENT_TBL (STUDENT_ID,
  7. STUDENT_NAME,
  8. STUDENT_SEX,
  9. STUDENT_BIRTHDAY,
  10. CLASS_ID)
  11. VALUES   (#{studentID},
  12. #{studentName},
  13. #{studentSex},
  14. #{studentBirthday},
  15. #{classEntity.classID})
  16. </insert>

insert语句属性配置细节:

属性 描述 取值 默认
id 在这个模式下唯一的标识符,可被其它语句引用    
parameterType 传给此语句的参数的完整类名或别名    
flushCache 如果设为true,则会在每次语句调用的时候就会清空缓存。select 语句默认设为false true|false false
useCache 如果设为true,则语句的结果集将被缓存。select 语句默认设为false true|false false timeout 设置驱动器在抛出异常前等待回应的最长时间,默认为不设值,由驱动器自己决定 true|false false
timeout  设置驱动器在抛出异常前等待回应的最长时间,默认为不设值,由驱动器自己决定 正整数 未设置
fetchSize 设置一个值后,驱动器会在结果集数目达到此数值后,激发返回,默认为不设值,由驱动器自己决定 正整数 驱动器决定
statementType statement,preparedstatement,callablestatement。 预准备语句、可调用语句 STATEMENT PREPARED CALLABLE PREPARED
useGeneratedKeys

告诉MyBatis 使用JDBC 的getGeneratedKeys 方法来获取数据库自己生成的主键(MySQL、SQLSERVER 等

关系型数据库会有自动生成的字段)。默认:false

true|false false
keyProperty

标识一个将要被MyBatis 设置进getGeneratedKeys 的key 所返回的值,或者为insert 语句使用一个selectKey

子元素。

   

selectKey语句属性配置细节:

属性 描述 取值
keyProperty selectKey 语句生成结果需要设置的属性。  
resultType 生成结果类型,MyBatis 允许使用基本的数据类型,包括String 、int类型。  
order 可以设成BEFORE 或者AFTER,如果设为BEFORE,那它会先选择主键,然后设置keyProperty,再执行insert语句;如果设为AFTER,它就先运行insert 语句再运行selectKey 语句,通常是insert 语句中内部调用数据库(像Oracle)内嵌的序列机制。  BEFORE AFTER
statementType 像上面的那样, MyBatis 支持STATEMENT,PREPARED和CALLABLE 的语句形式, 对应Statement ,PreparedStatement 和CallableStatement 响应 STATEMENT PREPARED CALLABLE

2.4 update、delete

一个简单的update:

  1. <!-- 更新学生信息 -->
  2. <update id="updateStudent" parameterType="StudentEntity">
  3. UPDATE STUDENT_TBL
  4. SET STUDENT_TBL.STUDENT_NAME = #{studentName},
  5. STUDENT_TBL.STUDENT_SEX = #{studentSex},
  6. STUDENT_TBL.STUDENT_BIRTHDAY = #{studentBirthday},
  7. STUDENT_TBL.CLASS_ID = #{classEntity.classID}
  8. WHERE STUDENT_TBL.STUDENT_ID = #{studentID};
  9. </update>

一个简单的delete:

  1. <!-- 删除学生 -->
  2. <delete id="deleteStudent" parameterType="StudentEntity">
  3. DELETE FROM STUDENT_TBL WHERE STUDENT_ID = #{studentID}
  4. </delete>

update、delete语句属性配置细节:

属性 描述 取值 默认
id 在这个模式下唯一的标识符,可被其它语句引用    
parameterType 传给此语句的参数的完整类名或别名    
flushCache 如果设为true,则会在每次语句调用的时候就会清空缓存。select 语句默认设为false true|false false
useCache 如果设为true,则语句的结果集将被缓存。select 语句默认设为false true|false false timeout 设置驱动器在抛出异常前等待回应的最长时间,默认为不设值,由驱动器自己决定 true|false false
timeout  设置驱动器在抛出异常前等待回应的最长时间,默认为不设值,由驱动器自己决定 正整数 未设置
fetchSize 设置一个值后,驱动器会在结果集数目达到此数值后,激发返回,默认为不设值,由驱动器自己决定 正整数 驱动器决定
statementType statement,preparedstatement,callablestatement。 预准备语句、可调用语句 STATEMENT PREPARED CALLABLE PREPARED

2.5 sql

Sql元素用来定义一个可以复用的SQL 语句段,供其它语句调用。比如:

  1. <!-- 复用sql语句  查询student表所有字段 -->
  2. <sql id="selectStudentAll">
  3. SELECT ST.STUDENT_ID,
  4. ST.STUDENT_NAME,
  5. ST.STUDENT_SEX,
  6. ST.STUDENT_BIRTHDAY,
  7. ST.CLASS_ID
  8. FROM STUDENT_TBL ST
  9. </sql>

这样,在select的语句中就可以直接引用使用了,将上面select语句改成:

  1. <!-- 查询学生,根据id -->
  2. <select id="getStudent" parameterType="String" resultMap="studentResultMap">
  3. <include refid="selectStudentAll"/>
  4. WHERE ST.STUDENT_ID = #{studentID}
  5. </select>

2.6parameters

上面很多地方已经用到了参数,比如查询、修改、删除的条件,插入,修改的数据等,MyBatis可以使用的基本数据类型和Java的复杂数据类型。         基本数据类型,String,int,date等。         但是使用基本数据类型,只能提供一个参数,所以需要使用Java实体类,或Map类型做参数类型。通过#{}可以直接得到其属性。

2.6.1基本类型参数

根据入学时间,检索学生列表:

  1. <!-- 查询学生list,根据入学时间  -->
  2. <select id="getStudentListByDate"  parameterType="Date" resultMap="studentResultMap">
  3. SELECT *
  4. FROM STUDENT_TBL ST LEFT JOIN CLASS_TBL CT ON ST.CLASS_ID = CT.CLASS_ID
  5. WHERE CT.CLASS_YEAR = #{classYear};
  6. </select>
  1. List<StudentEntity> studentList = studentMapper.getStudentListByClassYear(StringUtil.parse("2007-9-1"));
  2. for (StudentEntity entityTemp : studentList) {
  3. System.out.println(entityTemp.toString());
  4. }

2.6.2Java实体类型参数

根据姓名和性别,检索学生列表。使用实体类做参数:

  1. <!-- 查询学生list,like姓名、=性别,参数entity类型 -->
  2. <select id="getStudentListWhereEntity" parameterType="StudentEntity" resultMap="studentResultMap">
  3. SELECT * from STUDENT_TBL ST
  4. WHERE ST.STUDENT_NAME LIKE CONCAT(CONCAT('%', #{studentName}),'%')
  5. AND ST.STUDENT_SEX = #{studentSex}
  6. </select>
  1. StudentEntity entity = new StudentEntity();
  2. entity.setStudentName("李");
  3. entity.setStudentSex("男");
  4. List<StudentEntity> studentList = studentMapper.getStudentListWhereEntity(entity);
  5. for (StudentEntity entityTemp : studentList) {
  6. System.out.println(entityTemp.toString());
  7. }

2.6.3Map参数

根据姓名和性别,检索学生列表。使用Map做参数:

  1. <!-- 查询学生list,=性别,参数map类型 -->
  2. <select id="getStudentListWhereMap" parameterType="Map" resultMap="studentResultMap">
  3. SELECT * from STUDENT_TBL ST
  4. WHERE ST.STUDENT_SEX = #{sex}
  5. AND ST.STUDENT_SEX = #{sex}
  6. </select>
  1. Map<String, String> map = new HashMap<String, String>();
  2. map.put("sex", "女");
  3. map.put("name", "李");
  4. List<StudentEntity> studentList = studentMapper.getStudentListWhereMap(map);
  5. for (StudentEntity entityTemp : studentList) {
  6. System.out.println(entityTemp.toString());
  7. }

2.6.4多参数的实现

如果想传入多个参数,则需要在接口的参数上添加@Param注解。给出一个实例:  接口写法:

  1. public List<StudentEntity> getStudentListWhereParam(@Param(value = "name") String name, @Param(value = "sex") String sex, @Param(value = "birthday") Date birthdar, @Param(value = "classEntity") ClassEntity classEntity);

SQL写法:

  1. <!-- 查询学生list,like姓名、=性别、=生日、=班级,多参数方式 -->
  2. <select id="getStudentListWhereParam" resultMap="studentResultMap">
  3. SELECT * from STUDENT_TBL ST
  4. <where>
  5. <if test="name!=null and name!='' ">
  6. ST.STUDENT_NAME LIKE CONCAT(CONCAT('%', #{name}),'%')
  7. </if>
  8. <if test="sex!= null and sex!= '' ">
  9. AND ST.STUDENT_SEX = #{sex}
  10. </if>
  11. <if test="birthday!=null">
  12. AND ST.STUDENT_BIRTHDAY = #{birthday}
  13. </if>
  14. <if test="classEntity!=null and classEntity.classID !=null and classEntity.classID!='' ">
  15. AND ST.CLASS_ID = #{classEntity.classID}
  16. </if>
  17. </where>
  18. </select>

进行查询:

  1. List<StudentEntity> studentList = studentMapper.getStudentListWhereParam("", "",StringUtil.parse("1985-05-28"), classMapper.getClassByID("20000002"));
  2. for (StudentEntity entityTemp : studentList) {
  3. System.out.println(entityTemp.toString());
  4. }

2.6.5字符串代入法

默认的情况下,使用#{}语法会促使MyBatis 生成PreparedStatement 属性并且使用PreparedStatement 的参数(=?)来安全的设置值。尽量这些是快捷安全,也是经常使用的。但有时候你可能想直接未更改的字符串代入到SQL 语句中。比如说,对于ORDER BY,你可能会这样使用:ORDER BY ${columnName}但MyBatis 不会修改和规避掉这个字符串。         注意:这样地接收和应用一个用户输入到未更改的语句中,是非常不安全的。这会让用户能植入破坏代码,所以,要么要求字段不要允许客户输入,要么你直接来检测他的合法性 。

2.7 cache缓存

MyBatis 包含一个强在的、可配置、可定制的缓存机制。MyBatis 3 的缓存实现有了许多改进,既强劲也更容易配置。默认的情况,缓存是没有开启,除了会话缓存以外,它可以提高性能,且能解决全局依赖。开启二级缓存,你只需要在SQL 映射文件中加入简单的一行:<cache/>

这句简单的语句的作用如下:

1. 所有在映射文件里的select 语句都将被缓存。 2. 所有在映射文件里insert,update 和delete 语句会清空缓存。 3. 缓存使用“最近很少使用”算法来回收 4. 缓存不会被设定的时间所清空。 5. 每个缓存可以存储1024 个列表或对象的引用(不管查询出来的结果是什么)。 6. 缓存将作为“读/写”缓存,意味着获取的对象不是共享的且对调用者是安全的。不会有其它的调用 7. 者或线程潜在修改。

例如,创建一个FIFO 缓存让60 秒就清空一次,存储512 个对象结果或列表引用,并且返回的结果是只读。因为在不用的线程里的两个调用者修改它们可能会导致引用冲突。

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

还可以在不同的命名空间里共享同一个缓存配置或者实例。在这种情况下,你就可以使用cache-ref 来引用另外一个缓存。

  1. <cache-ref namespace="com.liming.manager.data.StudentMapper"/>

Cache 语句属性配置细节:

属性 说明 取值 默认值
eviction 缓存策略: LRU - 最近最少使用法:移出最近较长周期内都没有被使用的对象。 FIFI- 先进先出:移出队列里较早的对象 SOFT - 软引用:基于软引用规则,使用垃圾回收机制来移出对象 WEAK - 弱引用:基于弱引用规则,使用垃圾回收机制来强制性地移出对象 LRU FIFI SOFT WEAK LRU
flushInterval 代表一个合理的毫秒总计时间。默认是不设置,因此使用无间隔清空即只能调用语句来清空。 正整数

不设置

size 缓存的对象的大小 正整数 1024
readOnly

只读缓存将对所有调用者返回同一个实例。因此都不能被修改,这可以极大的提高性能。可写的缓存将通过序列

化来返回一个缓存对象的拷贝。这会比较慢,但是比较安全。所以默认值是false。

true|false false

MyBatis学习 之 一、MyBatis简介与配置MyBatis+Spring+MySql

MyBatis学习 之 二、SQL语句映射文件(1)resultMap

MyBatis学习 之 二、SQL语句映射文件(2)增删改查、参数、缓存

MyBatis学习 之 三、动态SQL语句

MyBatis学习 之 四、MyBatis配置文件

MyBatis学习 之 二、SQL语句映射文件(2)增删改查、参数、缓存的更多相关文章

  1. MyBatis学习(二)、SQL语句映射文件(2)增删改查、参数、缓存

    二.SQL语句映射文件(2)增删改查.参数.缓存 2.2 select 一个select 元素非常简单.例如: <!-- 查询学生,根据id --> <select id=" ...

  2. MyBatis学习 之 三、SQL语句映射文件(2)增删改查、参数、缓存

    2.2 select 一个select 元素非常简单.例如: <!-- 查询学生,根据id --> <select id="getStudent" paramet ...

  3. 二、SQL语句映射文件(2)增删改查、参数、缓存

    //备注:该博客引自:http://limingnihao.iteye.com/blog/106076 2.2 select 一个select 元素非常简单.例如: Xml代码 收藏代码 <!- ...

  4. SQL语句映射文件(2)增删改查、参数、缓存

    2.2 select 一个select 元素非常简单.例如: <!-- 查询学生,根据id --> <select id="getStudent" paramet ...

  5. mybatis3.1-[topic-16-17]-映射文件_增删改查_insert_获取自增主键的值

    笔记要点出错分析与总结 /**测试第16章的增,删,改 的内容 * 错误1: <insert id="addEmp" parameterType="com.bean ...

  6. Android SQL语句实现数据库的增删改查

    本文介绍android中的数据库的增删改查 复习sql语法: * 增 insert into info (name,phone) values ('wuyudong','111') * 删 delet ...

  7. mysql详解常用命令操作,利用SQL语句创建数据表—增删改查

    关系型数据库的核心内容是 关系 即 二维表 MYSQL的启动和连接show variables; [所有的变量] 1服务端启动 查看服务状态 sudo /etc/init.d/mysql status ...

  8. 映射文件中增删改查标签中的parameterType和resultType

    parameterType:指定输入参数类型,mybatis通过ognl从输入对象中获取参数值拼接在sql中. resultType:指定输出结果类型,mybatis将sql查询结果的一行记录数据映射 ...

  9. 通过Sql语句控制SQLite数据库增删改查

    person类属性有Intenger id,String name,Intenger  age,相应的构造方法和set get方法. package com.xh.tx.dao; import jav ...

随机推荐

  1. 因SELinux引起的用户登录问题解决案例

    增强安全性带来的负作用往往是牺牲便利性,就像北京地铁的安检一样,但有些时候我们确实需要它.   案例是,用户有一台安装了KylinOS(国产麒麟,使用的是redhat的内核)的系统,当我们对其系统文件 ...

  2. How does database indexing work?

    When data is stored on disk based storage devices, it is stored as blocks of data. These blocks are ...

  3. POJ1860Currency Exchange(SPFA)

    http://poj.org/problem?id=1860 题意:  题目中主要是说存在货币兑换点,然后现在手里有一种货币,要各种换来换去,最后再换回去的时候看能不能使原本的钱数增多,每一种货币都有 ...

  4. lintcode:Unique Characters 判断字符串是否没有重复字符

    题目: 判断字符串是否没有重复字符 实现一个算法确定字符串中的字符是否均唯一出现 样例 给出"abc",返回 true 给出"aab",返回 false 挑战 ...

  5. jvm调优具体参数配置

    3.JVM参数 在JVM启动参数中,可以设置跟内存.垃圾回收相关的一些参数设置,默认情况不做任何设置JVM会工作的很好,但对一些配置很好的Server和具体的应用必须仔细调优才能获得最佳性能.通过设置 ...

  6. HTML5+开发移动app教程3-mui开发示例

    下面就开始一个简答的例子,以及mui相关内容 mui 官网:http://dcloudio.github.io/mui/ 说明:http://dev.dcloud.net.cn/mui/ui/inde ...

  7. seafile安装日志(非教程)

    需要的软件: python 2.7.x(从 Seafile 5.1 开始,python 版本最低要求为2.7) python-setuptools python-imaging python-mysq ...

  8. Java API —— 递归

    1.方法定义中调用方法本身的现象 2.递归注意实现         1) 要有出口,否则就是死递归         2) 次数不能太多,否则就内存溢出         3) 构造方法不能递归使用 3. ...

  9. Shuffle和排序

    MapReduce确保每个reducer的输入都按键排序.系统执行排序的过程——将map输出作为输入传给reducer——称为shuffle.shuffle属于不断被优化和改进的代码库的一部分,从许多 ...

  10. SqlServer几个注意点

    1.修改系统参数时,必须是单用户情况下才能更改成功!在Properties->Options中修改. 2.数据库字段值默认是不区分大小写的,修改方法如下: 2.1.右键数据库,选择Propert ...