本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用.

转载请注明 出自 : luogg的博客园 谢谢配合!

优化

1.起别名(一般不用,写全方便查看类出处)

以前的写法:

<insert id="insert"parameterType="com.luogg.domain.Person">

在config.xml文件下
<!--起别名-->
<typeAliases>
<typeAlias type="com.luogg.domain.Person" alias="Person"/>
</typeAliases>
在Mapper.xml文件下
<select id="selById" parameterType="int" resultType="Person">
SELECT * FROM person WHERE id = #{id}
</select>

2.命名空间的优化(一般不用,写全方便查看类出处)

命名空间是可以随意修改的,但是有可能不同包下出现相同的实体类,所以还是加上包名方便区分.

3.sql片段

很多时候会写一大串的列名,比如select 所有字段,我们把经常出现的字段放入sql标签中,将来直接引用
<!--sql片段-->
<sql id="cols">id,user_name,age,sex</sql> <select id="find" resultMap="personRM">
SELECT <include refid="cols"/> from person
</select>

动态sql语句(根据用户填入条件查询,比如可以填入name搜索,也可以填入age搜索,也可以都填)

将parameterType设置成map即可

<where> 表示条件查询,并在后边自动添加一个1=1

<set>标签,表示修改时候用的,自动删除最后一个条件的逗号

<foreach>标签,循环标签,用于in子查询

<!--动态sql语句,where标签相当于where 1=1 -->
<select id="selDongtai" parameterType="map" resultMap="personRM">
SELECT <include refid="cols"/> FROM person
<where>
<if test="name != null">and user_name like #{name}</if>
<if test="sex != null">and sex = #{sex}</if>
</where>
</select>
@Test //动态sql语句
public void selDongtai(){
SqlSession session = factory.openSession();
Map<String,Object> map = new HashMap<String, Object>();
map.put("name","l%");
map.put("sex",1);
List<Person> list = session.selectList("com.luogg.mapper.PersonMapper.selDongtai",map);
System.out.println(list.size());
for(Person p : list){
System.out.println(p);
}
}

特殊字符处理 CDATA

遇到特殊字符,我们需要将其原样输出,比如<>,此时加上<![CDATA[原样输出的内容 ]]>
<!--特殊字符的处理,查询年龄在20到22岁的人员-->
<select id="selTeshu" parameterType="map" resultMap="personRM">
SELECT <include refid="cols"/> FROM person
<where>
<if test="name != null">and user_name like #{name}</if>
<if test="ageStart !=null"> and age >= #{ageStart}</if>
<if test="ageEnd !=null"> <![CDATA[and age <=]]> #{ageEnd}</if>
</where>
</select>
@Test  //特殊字符处理
public void testTeshu(){
SqlSession session = factory.openSession();
Map<String,Object> map = new HashMap<String, Object>();
map.put("ageStart",20);
map.put("ageEnd",22);
List<Person> list = session.selectList("com.luogg.mapper.PersonMapper.selTeshu",map);
System.out.println(list.size());
for(Person p : list){
System.out.println(p);
}
}

MyBatis入门3_mapper.xml优化(parameterType简写_NameSpace简写_sql片段_特殊字符处理)_动态SQL的更多相关文章

  1. MyBatis入门学习教程-优化MyBatis配置文件中的配置

    一.连接数据库的配置单独放在一个properties文件中 之前,我们是直接将数据库的连接配置信息写在了MyBatis的conf.xml文件中,如下: 1 <?xml version=" ...

  2. mybatis的mapper.xml使用parameterType使用的报错

    错误在于一个写的get(Long id)的查询方法, 而在Mapper.xml中我定义了这个接收的参数的类型是int类型, 结果就报了如下的错误 org.mybatis.spring.MyBatisS ...

  3. Mybatis入门(四)配置优化(一)

    这一章主要实验Mybatis的引入外部配置文件,属性(properties)这个属性都是可外部配置且可动态替换的,既可以在典型的 Java 属性文件中配置,亦可通过 properties 元素的子元素 ...

  4. mybatis的mapper特殊字符转移以及动态SQL条件查询

    前言 我们知道在项目开发中之前使用数据库查询,都是基于jdbc,进行连接查询,然后是高级一点jdbcTemplate进行查询,但是我们发现还是不是很方便,有大量重复sql语句,与代码偶合,效率低下,于 ...

  5. MyBatis 入门(一)

    1. MyBatis 概述 MyBatis 是一个半自动化的持久层框架; 核心SQL,开发人员可以进行优化; SQL和Java编码分开,功能边界清晰,一个专注业务,一个专注数据; JDBC: SQL ...

  6. Mybatis:缓存,动态SQL,注解SQL以及动态标签使用

    1 转义字符 字符 转义 描述 < < 小于 <= <= 小于等于 > > 大于 >= >= 大于等于 <> <> 不等于 &a ...

  7. Mybatis的动态SQL实现

    一.动态SQL简介 MyBatis的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么痛苦.拼接的时候要确保不能忘了必要的 ...

  8. MyBatis注解及动态Sql

    一.注解实现MyBatis配置 java注解是在jdk1.5版本之后开始加入的,不得不说注解对于我们开发人员来说是个很方便的东西,实现起来也非常的简单,下边我们说一下在MyBatis中使用注解来替换M ...

  9. SpringBoot使用Mybatis注解开发教程-分页-动态sql

    代码示例可以参考个人GitHub项目kingboy-springboot-data 一.环境配置 1.引入mybatis依赖 compile( //SpringMVC 'org.springframe ...

随机推荐

  1. Linux ANSI 乱码问题

    原帖http://blog.chinaunix.net/u/24624/showart_184609.html Windows 到 linux 解决samba-3.x客户端中文乱码问题 dos cha ...

  2. sql 分组取每组的前n条或每组的n%(百分之n)的数据

    sql 分组取每组的前n条或每组的n%(百分之n)的数据 sql keyword: SELECT * ,ROW_NUMBER() OVER(partition by b.UserID order by ...

  3. 创建.m文件一片空白的错误解决方式

    今天写代码,想继承一个类,突然发现创建的类文件一片空白,如图 之后各种调试发现都解决不了问题,以为是装了xcode6 beta2 版本号的问题,结果发现事实上是我创建错了 我创建的是 watermar ...

  4. oc78--NSFileManager

    // main.m // NSFileManager #import <Foundation/Foundation.h> int main(int argc, const char * a ...

  5. Netlink通信机制【转】

    本文转载自:http://www.cnblogs.com/wenqiang/p/6306727.html 一.什么是Netlink通信机制  Netlink套接字是用以实现用户进程与内核进程通信的一种 ...

  6. cmd 批处理文件(.bat)文件的编写

    1. 获取当前文件所在的路径信息 CMD获取当前目录的绝对路径 创建如下的名为 test.bat的文本文件: @echo off echo 当前盘符:%~d0 echo 当前盘符和路径:%~dp0 e ...

  7. P3469 [POI2008]BLO-Blockade tarjan

    好久没发博客了啊!自我反省1s...今天再捡起来. 这个题是一道有一点特殊的tarjan,用tarjan维护子树大小,然后判断是否有边多次连接,(就是非树边),然后就进行乘法计算就行了. 具体在代码里 ...

  8. CSS小代码汇总整理

    /**实现斑马线的表格*/table.flexme tbody tr:nth-child(2n){background-color:#D6E7FC;} /*返回偶数序的子元素*/table.flexm ...

  9. kmp的练习们

    //poj3461 Oulipo //kmp模板 统计子串在母串中的位置 #include<iostream> #include<cstdio> #include<cst ...

  10. [App Store Connect帮助]二、 添加、编辑和删除用户(5)创建一个沙盒测试员帐户

    如果您的 App 使用了 App 内购买项目或 Apple Pay,您可以在 App Store Connect 中创建沙盒测试员帐户,以便您向用户提供该 App 前,可以使用该帐户在测试环境中运行您 ...