MyBatis 真正的力量是在映射语句中。

和对等功能的jdbc来比价,映射文件节省非常多的代码量。

MyBatis的构建就是聚焦于sql的。

sql映射文件有例如以下几个顶级元素:(按顺序)

cache配置给定命名空间的缓存。

cache-ref从其它命名空间引用缓存配置。

resultMap最复杂,也是最有力量的元素。用来描写叙述怎样从数据库结果集中来载入你的对象。

parameterMap已经被废弃了!老式风格的參数映射。

内联參数是首选,这个元素可能在将来被移除。

sql能够重用的SQL块,也能够被其它语句引用。

insert映射插入语句。

update映射更新语句。

delete映射删除语句。

select映射查询语句。

以下就具体描写叙述一些元素:

1、select

查询语句是使用 MyBatis 时最经常使用的元素之中的一个。

<select id=”selectPerson” parameterType=”int” resultType=”hashmap”>
SELECT * FROM PERSON WHERE ID = #{id}
</select>

使用一个int(或Integer)类型的參数,并返回一个HashMap类型的对象,当中的键是列名,值是列相应的值。

注意參数凝视:

#{id}

select
元素有非常多属性同意你配置,来决定每条语句的作用细节。

<select
id=”selectPerson” 在命名空间中唯一的标识符,能够被用来引用这条语句。 parameterType=”int” 将会传入这条语句的參数类的全然限定名或别名。 parameterMap=”deprecated” (已废弃) resultType=”hashmap” 从这条语句中返回的期望类型的类的全然限定名或别名。 注意集合情形。那应该是集合能够包括的类型,而不能是集合本身。 使用resultType或resultMap,但不能同一时候使用。 resultMap=”personResultMap” 命名引用外部的resultMap。返回map是MyBatis最具力量的特性,对其有一个非常好的理解的话,很多复杂映射的情形就能被攻克了。使用 resultMap 或 resultType,但不能同一时候使用。 flushCache=”false” 将其设置为true。不论语句什么时候被调用,都会导致缓存被清空。默认值: false。 useCache=”true” 将其设置为 true。将会导致本条语句的结果被缓存。默认值: true。 timeout=”10000” 这个设置驱动程序等待数据库返回请求结果,并抛出异常时间的最大等待值。默认不设置(驱动自行处理)。 fetchSize=”256” 这是暗示驱动程序每次批量返回的结果行数。默认不设置(驱动自行处理)。
statementType=”PREPARED” STATEMENT,PREPARED 或 CALLABLE 的一种。这会让 MyBatis使用选择使用 Statement, PreparedStatement 或 CallableStatement。默认值: PREPARED。 resultSetType=”FORWARD_ONLY” FORWARD_ONLY|SCROLL_SENSITIVE|SCROLL_INSENSITIVE中的一种。默认是不设置(驱动自行处理)。 >

2、insert。 update, delete

数据变更语句 insert。 update 和 delete 在它们的实现中很相似:

<insert
id="insertAuthor" 在命名空间中唯一的标识符,能够被用来引用这条语句。 parameterType="domain.blog.Author" 将会传入这条语句的參数类的全然限定名或别名。 flushCache="true" 将其设置为 true。不论语句什么时候被调用,都会导致缓存被清
空。默认值: false。 statementType="PREPARED" STATEMENT,PREPARED 或 CALLABLE 的一种。 这会让 MyBatis使用选择使用 Statement, PreparedStatement 或CallableStatement。默认值: PREPARED。 keyProperty="" (仅对 insert实用)标记一个属性, MyBatis 会通过 getGeneratedKeys或者通过 insert 语句的 selectKey 子元素设置它的值。 默认:不设置。 useGeneratedKeys="" ( 仅 对 insert 有 用 ) 这 会 告 诉 MyBatis 使 用 JDBC 的getGeneratedKeys 方法来取出由数据(比方:像 MySQL 和 SQLServer 这种数据库管理系统的自己主动递增字段)内部生成的主键。默认值: false。 timeout="20000" 这个设置驱动程序等待数据库返回请求结果,并抛出异常时间的最大等待值。 默认不设置(驱动自行处理)。
>

以下就是insert, update 和 delete 语句的演示样例:

<insert id="insertAuthor" parameterType="domain.blog.Author">
insert into Author (id,username,password,email,bio) values (#{id},#{username},#{password},#{email},#{bio})
</insert> <update id="updateAuthor" parameterType="domain.blog.Author">
update Author set
username = #{username},
password = #{password},
email = #{email},
bio = #{bio}
where id = #{id}
</update> <delete id="deleteAuthor” parameterType="int">
delete from Author where id = #{id}
</delete>

如前所述。插入语句有一点多,它有一些属性和子元素用来处理主键的生成。首先。假设你的数据库支持自己主动生成主键的字段(比方MySQL和SQLServer)。那么你能够设置
useGeneratedKeys=”true”,并且设置 keyProperty 到你已经做好的目标属性上。比如。假设上面的
Author 表已经对 id 使用了自己主动生成的列类型,那么语句能够改动为:

<insert id="insertAuthor" parameterType="domain.blog.Author"
useGeneratedKeys=”true” keyProperty=”id”>
insert into Author (username,password,email,bio)
values (#{username},#{password},#{email},#{bio})
</insert>

3、sql

这个元素能够被用来定义可重用的SQL代码段。能够包括在其它语句中。

<select id=”selectUsers” parameterType=”int” resultType=”hashmap”>
select <include refid=”userColumns”/>
from some_table
where id = #{id}
</select>

兴许将会具体介绍缓存和resultMap

MyBatis -- sql映射文件具体解释的更多相关文章

  1. Mybatis sql映射文件浅析 Mybatis简介(三)

    简介 除了配置相关之外,另一个核心就是SQL映射,MyBatis 的真正强大也在于它的映射语句. Mybatis创建了一套规则以XML为载体映射SQL 之前提到过,各项配置信息将Mybatis应用的整 ...

  2. Mybatis sql映射文件浅析 Mybatis简介(三) 简介

    Mybatis sql映射文件浅析 Mybatis简介(三)   简介 除了配置相关之外,另一个核心就是SQL映射,MyBatis 的真正强大也在于它的映射语句. Mybatis创建了一套规则以XML ...

  3. Mybatis SQL映射文件详解

    Mybatis SQL映射文件详解 mybatis除了有全局配置文件,还有映射文件,在映射文件中可以编写以下的顶级元素标签: cache – 该命名空间的缓存配置. cache-ref – 引用其它命 ...

  4. SSM - Mybatis SQL映射文件

    MyBatis 真正的力量是在映射语句中.和对等功能的jdbc来比价,映射文件节省很多的代码量.MyBatis的构建就是聚焦于sql的. sql映射文件有如下几个顶级元素:(按顺序) cache配置给 ...

  5. 初始MyBatis、SQL映射文件

    MyBatis入门 1.MyBatis前身是iBatis,是Apache的一个开源项目,2010年这个项目迁移到了Google Code,改名为MyBatis,2013年迁移到GitHub.是一个基于 ...

  6. MyBatis 创建核心配置文件和 SQL 映射文件

    Mybatis 的两个配置文件(mybatis-config.xml  和 xxxMapper.xml)都为 xml 类型,因此在 eclipse 中创建 xml 文件命名为相应的 mybatis-c ...

  7. MyBatis 的基本要素—SQL 映射文件

    MyBatis 真正的强大在于映射语句,相对于它强大的功能,SQL 映射文件的配置却是相当简单.对比 SQL 映射配置和 JDBC 代码,发现使用 SQL 映射文件配置可减少 50% 以上的代码,并且 ...

  8. Mybatis(二) SQL映射文件

    SQL映射文件 单条件查询 1. 在UserMapper接口添加抽象方法 //根据用户名模糊查询 List<User> getUserListByName(); 2. 在UserMappe ...

  9. MyBatis学习-映射文件标签篇(select、resultMap)

    MyBatis 真正的核心在映射文件中.比直接使用 JDBC 节省95%的代码.而且将 SQL 语句独立在 Java 代码之外,可以进行更为细致的 SQL 优化. 一. 映射文件的顶级元素 selec ...

随机推荐

  1. 通俗理解 模糊自适应PID

    模糊自适应PID算法就是在经典的PID的基础上添加模糊控制规则库,建立这个库的目的就是算法能够自己来进行改变P.I.D的值. 就拿温度的上升过程控制来说,刚开始的时候,希望温度能够快速的升到终点温度, ...

  2. xshell通过xftp传输Windows文件到Linux:在输入put后,再摁 TAB 键,可显示当前文件夹的文件

    在输入put后,再摁 TAB 键,可显示当前文件夹的文件 sftp:/home/yan> put $Recycle.Bin\              BluestacksCN\         ...

  3. 第1节 flume:10、flume的更多组件介绍

    作业:flume如何实现收集mysql的数据,没隔几秒钟,查看mysql中的数据是否有变化,一旦有变化,把数据拿过来,存到hdfs上. 需要使用custom source.可网上搜索,github上.

  4. 微信小程序:errcode=40029和invalid code, hints: [ req_id: VyLhYa0451hb31 ]

    问题: 后台用小程序返回的code请求微信服务器换取session_key和openid,返回错误状态码40029 解决问题 当前小程序绑定的appid和请求微信服务器所带的appid参数不一致导致的 ...

  5. select onchange事件的使用

    <select name="expireDay" id="expireDay" class="form-control" onchan ...

  6. PHP调用webService WSDL 接口发送邮件

    1.什么是 webService WSDL?  webService WSDL 暴露一些接口给第三方调用,在底层会转化成一个HTTP请求,主要是不同语言之间为了通讯的一个协议,比如发送邮件的系统是用J ...

  7. Python+selenium登录测试

    我们以登录新浪微博为案例来讲解,首先进入登录页面,输入用户名和密码,点击登录按钮,并且获得用户信息以验证是否登录成功. Web地址:https://login.sina.com.cn/signup/s ...

  8. linux centos7 swap 设置 添加 删除

    操作  需要  root 用户 权限 dd 命令 创建swap用的分区文件 /var/swap  dd if=/dev/zero of=/var/swap bs=1024 count=2048000 ...

  9. 机器学习基础-Logistic回归2

    随机梯度上升法--一次仅用一个样本点来更新回归系数(因为可以在新样本到来时对分类器进行增量式更新,因而属于在线学习算法) 梯度上升法在每次更新回归系统时都需要遍历整个数据集,该方法在处理100个左右的 ...

  10. POJ 2553 The Bottom of a Graph 【scc tarjan】

    图论之强连通复习开始- - 题目大意:给你一个有向图,要你求出这样的点集:从这个点出发能到达的点,一定能回到这个点 思路:强连通分量里的显然都可以互相到达 那就一起考虑,缩点后如果一个点有出边,一定不 ...