目录


select、update、delete、insert

设置参数类型以及取值

基本数据类型

对象数据类型

map数据类型

#{  } 和 ${  } 的区别

ResultMap

Auto-mapping

cache


select、update、delete、insert

  这分别对应有四个标签<select>、<update>、<delete>、<insert>,在绑定sql语句的时候,可以有很多的属性,属性可以见名知意,具体如下:

<select
id="selectPerson"
parameterType="int"
resultType="hashmap"
resultMap="personResultMap"
flushCache="false"
useCache="true"
timeout="10000"
fetchSize="256"
statementType="PREPARED"
resultSetType="FORWARD_ONLY"> <insert
id="insertAuthor"
parameterType="domain.blog.Author"
flushCache="true"
statementType="PREPARED"
keyProperty=""
keyColumn=""
useGeneratedKeys=""
timeout="20"> <update
id="insertAuthor"
parameterType="domain.blog.Author"
flushCache="true"
statementType="PREPARED"
timeout="20"> <delete
id="insertAuthor"
parameterType="domain.blog.Author"
flushCache="true"
statementType="PREPARED"
timeout="20">

  对于<select>、<insert>、<update>、<delete>,SqlSession分别有两个方法与之对应:

<select>
int SqlSession.select(String statement)
int SqlSession.select(String statement, Object parameter) <insert>
int SqlSession.insert(String statement)
int SqlSession.insert(String statement, Object parameter) <update>
int SqlSession.update(String statement)
int SqlSession.update(String statement, Object parameter) <delete>
int SqlSession.delete(String statement)
int SqlSession.delete(String statement, Object parameter)

  

设置参数类型以及取值

  设置参数类型,是通过设置parameterType的值,设置的类型不同,sql中取值的方式也有所区别。

  parameterType属性可以有下面几种取值:

  1、基本数据类型

    比如int、double,其实应该写为Integer、Double,但是有自动装箱功能,所以可以直接写基本数据类型。

    sql取值的方式:对于这种的参数,在接收传入的参数值时,可以使用#{index}来获取,注意,index从0开始计数,如果只有一个参数,那么index可以写成任意名称。

<mapper namespace="cn.ganlixin.mapper.PersonMapper">

	<select id="selectPersonById1" parameterType="int" resultType="cn.ganlixin.pojo.Person">
select * from person where id=#{0}
</select> <!-- 如果只有参数,可以将#{0} 写为任意名称 -->
<select id="selectPersonById2" parameterType="int" resultType="cn.ganlixin.pojo.Person">
select * from person where id=#{id}
</select>
</mapper>

  

  2、Object类型

    可以写实体类(如果没有配置alias,需要写全路径),比如cn.ganlixin.pojo.Person类。

    sql取值的方式:对于对象这种类型,可以使用#{property}去访问实体类中的property属性值,比如#{age},可以获取Person的age属性值。

<mapper namespace="cn.ganlixin.mapper.PersonMapper">
<select id="selectPersonByName"
parameterType="cn.ganlixin.pojo.Person"
resultType="cn.ganlixin.pojo.Person"> select * from person where name=#{name}
<!-- 相当于取Person.name的值 -->
</select>
</mapper>

    简单测试:

String method = "cn.ganlixin.mapper.PersonMapper.selectPersonByName";
Person person = new Person();
person.setName("aaaa");
person = (Person) session.selectOne(method, person);

  

  3、map类型

    将要传入一个数据,封装到一个map中,然后再传入即可。

    sql取值的方式:对于map的取值,和object的取值类似,使用#{key}即可获取map中key对应value。

<mapper namespace="cn.ganlixin.mapper.PersonMapper">
<select id="selectPersonByName" parameterType="map" resultType="cn.ganlixin.pojo.Person">
select * from person where name=#{name}
<!-- 相当于取map.get(name)的值 -->
</select>
</mapper>

    简单测试:

String method = "cn.ganlixin.mapper.PersonMapper.selectPersonByName";
Map<String, String> data = new HashMap<>();
data.put("name", "aaaa");
Person person = (Person) session.selectOne(method, data);

  

  4、#{  } 和 ${  } 的区别

  需要注意的是,sql中取值可以使用#{  } 和 ${  }两种方式,区别在于:

  1、#{  } 会使用预处理操作,而${  }不会进行预处理操作。

  2、${  } 只是很简单的使用字符串拼接

select * from person where name='${name}'
如果上面不适用引号将${name}括起来,那么就会将${name}的值当做字段名,而不是字段值 select * from person where name=${0}
上面这条sql语句,并不会使用传入的第1个参数,而是真的name=0

  

ResultMap

  关于resultMap的使用,可以查看:

  mybatis 使用resultMap实现表间关联

Auto-mapping

  关于auto-mapping的使用,可以查看:

  mybatis 使用auto mapping原理实现表间关联

cache

  mybatis中的缓存有两种,一级缓存和二级缓存。

  可以查看:mybatis 使用缓存策略

  

mybatis mapper映射文件全解的更多相关文章

  1. Mybatis SQL映射文件详解

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

  2. Mybatis(三) 映射文件详解

    前面说了全局配置文件中内容的详解,大家应该清楚了,现在来说说这映射文件,这章就对输入映射.输出映射.动态sql这几个知识点进行说明,其中高级映射(一对一,一对多,多对多映射)在下一章进行说明. 一.输 ...

  3. Mybatis Mapper 映射文件(xxxMapper.xml)

    什么是 Mapper 映射文件 Mapper 映射文件是 Mybatis 用于实现 ORM 映射规则的配置文件,Mybatis 通过映射文件可将数据库查询结构映射为 Java 对象. 创建 Mappe ...

  4. 框架学习系列 mybatis mapper映射文件之输出映射

    1: mapper映射文件输出映射(输入类型) 2:resultType的使用 3:resultMap的使用 3:总结&下节预告 本文是<凯哥陪你学系列-框架学习之mybatis框架学习 ...

  5. 笔记:MyBatis Mapper XML文件详解 - 映射和参数

    MyBatis 的真正强大在于它的映射语句,也是它的魔力所在.由于它的异常强大,映射器的 XML 文件就显得相对简单.如果拿它跟具有相同功能的 JDBC 代码进行对比,你会立即发现省掉了将近 95% ...

  6. 笔记:MyBatis Mapper XML文件详解 - Cache

    缓存(Cache) 从数据库中加载的数据缓存到内存中,是很多应用程序为了提高性能而采取的一贯做法.MyBatis对通过映射的SELECT语句加载的查询结果提供了内建的缓存支持.默认情况下,启用一级缓存 ...

  7. 笔记:MyBatis Mapper XML文件详解 - Result Maps

    Result Maps(结果集) resultMap 元素是 MyBatis 中最重要最强大的元素.它就是让你远离 90%的需要从结果 集中取出数据的 JDBC 代码的那个东西, 而且在一些情形下允许 ...

  8. Mybatis系列全解(五):全网最全!详解Mybatis的Mapper映射文件

    封面:洛小汐 作者:潘潘 若不是生活所迫,谁愿意背负一身才华. 前言 上节我们介绍了 < Mybatis系列全解(四):全网最全!Mybatis配置文件 XML 全貌详解 >,内容很详细( ...

  9. Mybatis学习(三)————— 映射文件详解

    前面说了全局配置文件中内容的详解,大家应该清楚了,现在来说说这映射文件,这章就对输入映射.输出映射.动态sql这几个知识点进行说明,其中高级映射(一对一,一对多,多对多映射)在下一章进行说明. 一.输 ...

随机推荐

  1. MVC+angularjs

    angularjs可以解决开发人员不擅长HTML的问题,采用模块化配置,但是不支持样式的微调和修改 angularjs+MVC开发的协同办公平台,贴下图 编辑页面+附件 列表页 一个页面涉及另一个子表 ...

  2. Java学习笔记 抽象类 接口 多态

    instanceof 对象名 instanceof 类名 该对象是否属于该类 Animal animal = new Dog(); if(animal instanceof Dog){ Dog d = ...

  3. vue HTTP 请求(vue-resource)

    来自:https://www.cnblogs.com/lhl66/p/8022423.html 侵删 //初始化页面需要做什么事情 //点击后需要做什么事情 //鼠标.键盘.冒泡.默认行为等事件 // ...

  4. 介绍Dynamics 365 Performance Center

    关注本人微信和易信公众号: 微软动态CRM专家罗勇 ,回复257或者20170517可方便获取本文,同时可以在第一间得到我发布的最新的博文信息,follow me!我的网站是 www.luoyong. ...

  5. 36.Odoo产品分析 (四) – 工具板块(6) – 午餐管理(2)

    查看Odoo产品分析系列--目录 接上一篇Odoo产品分析 (四) – 工具板块(6) – 午餐管理(1) 4 查看订单 点击"之前的订单",可以看到刚才的订单信息:  点击右边的 ...

  6. 自定义switchButton

    这篇博客要讲的是自定义switchButton,不过没有设置动画效果. 我用GradientDrawable来绘制switchButton,我们先看看最终的效果: 点击前: 点击后 接下来我们看看如何 ...

  7. 微信小程序(五) 利用模板动态加载数据

    利用模板动态加载数据,其实是对上一节静态数据替换成动态数据:

  8. Node.js模块导入导出

    这篇文章本来是想模块导入导出和事件循环一起写的,但是感觉一起写的话会太长了,所以就分开两篇文章写吧.下一篇会重点介绍一下js中的事件循环,js代码到底是以何种顺序去执行的呢?我相信你看懂了事件循环再去 ...

  9. alloc_page分配内存空间--Linux内存管理(十七)

    1 前景回顾 在内核初始化完成之后, 内存管理的责任就由伙伴系统来承担. 伙伴系统基于一种相对简单然而令人吃惊的强大算法. Linux内核使用二进制伙伴算法来管理和分配物理内存页面, 该算法由Know ...

  10. Eclipse启动报错,解决办法

    打开log日志,发现如下错误.原因是修改了计算机用户名导致 !SESSION Thu Aug 30 08:55:41 CST 2018 -------------------------------- ...