Mapper.xml提示:

1:mapper包中新建一个文件:mybatis-3-mapper.dtd

2:在web app libraries/mybatis.jar/org.apache.ibatis.builder.xml/mybatis-3-mapper.dtd,打开,复制内容,贴到自己新建mybatis-3-mapper.dtd

3:把mapper.xml头上的dtd的路径该为当前目录!

4:关闭StuMapper.xml文件,重新打开,即有提示!

#{}和${}区别:  ${} 不会数值,不考虑数据类型,直接拼入sql,如果是字符串,没有单引号,sql异常!Statment,可能会发生sql注入问题!    #{} 不会发生:自动考虑数据类型,字符串会自动拼接'',PreparedStatment

mybatis:动态sql标签

<if> <choose> <when> <otherwise>  <where>  <set>   <foreach>  必须能解释清楚  剩下:在逆向生成的mapper.xml中:自己看!扩展

<select  id=”findByLike”  resultType=”com.stu.bean.Stu”  parameterType=”com.stu.bean.Stu”>

selec * from stu where 1=1

<if  test=”uname!=null”>and  uname=#{uname}</if>

<if  test=”uage!=null”>and  uage=#{uage}</if>

<if  test=”usex!=null”>and  usex=#{usex}</if>

</select>

<select  id=”findByLike”  resultType=”com.stu.bean.Stu”  parameterType=”com.stu.bean.Stu”>

selec * from stu where 1=1

<if  test=”uname!=null”>or  uname=#{uname}</if>

<if  test=”uage!=null”>or  uage=#{uage}</if>

<if  test=”usex!=null”>or  usex=#{usex}</if>

</select>

问题:如果永远都是全表

<select  id=”findByLike”  resultType=”com.stu.bean.Stu”  parameterType=”com.stu.bean.Stu”>

selec * from stu where 1!=1

<if  test=”uname!=null”>or  uname=#{uname}</if>

<if  test=”uage!=null”>or  uage=#{uage}</if>

<if  test=”usex!=null”>or  usex=#{usex}</if>   </select>解决上面问题

<select id="xxx3" parameterType="com.stu.bean.Stu" resultType="com.stu.bean.Stu">

select * from stu where 1!=1

<choose>      <!-- if  elseif   elseif -->

<when test="sid!=null">

      or sid = #{sid}

</when>

<when test="sname!=null">

or sname like #{sname}

</when>

<when test="sage!=null">

or sage = #{sage}

</when>

<otherwise>

     or saddress like #{saddress}

</otherwise>

</choose>  条件只可能成立一个!

</select>

<select id="xxx4" parameterType="com.stu.bean.Stu" resultType="com.stu.bean.Stu">

   select * from stu

<where>  <!-- 根据条件自动拼接where和and -->

    <if test="sname!=null">

    and sname=#{sname}

  </if>

<if test="saddress!=null">

          and saddress=#{saddress}

</if>

</where>

</select>

<update id="xxx5" parameterType="com.stu.bean.Stu">

      update stu <!-- 根据条件自动拼接set和逗号 -->

<set>

<if test="sname!=null">

    sname=#{sname},

</if>

<if test="sage!=null">

    sage=#{sage},

</if>

<if test="ssex!=null">

     ssex=#{ssex},

</if>

<if test="saddress!=null">

     saddress=#{saddress},

</if>

</set>

<where>

<if test="sid!=null">

     sid=#{sid}

</if>

</where>

</update>

<Delete id=”aaa”  parameterType=”array”>

Delete from stu where sid in

  <foreach collection=”array” index=”index”  item=”item” open=”(”   separator=”,”  close=”)”>     #{item}

</foreach>

</Delete >

=========================================================================================

逆向生成:

1:工具需要插件:放入dropins,重启my10!

2:考入jar包,并且把mysql。jar导入工作区

3: 考入generatorConfig.xml文件,修改路径

4: 右键 generatorConfig.xml,点击蝴蝶   XxxExample:方法条件样例

使用:

SqlSession session= MybatisUtil.getSqlSessionFactory().openSession();

StuMapper sm = session.getMapper(StuMapper.class);

sm.selectByPrimaryKey(Integer sid);  //和原来自己写xml方法一样   sm.selectByExample(Stuexample se);    StuExample se = new StuExample();   Criteria c = se.createCriteria();  c.andxxxxx()   sm.selectByExample(null);  查询所有   sm.countByExample(Stuexample se); 统计Criteria条件的行数   sm.deleteByExample(Stuexample e);   sm.deleteByPrimaryKey(Integer sid);  //和原来自己写xml方法一样   sm.insert(Stu s);   //和原来自己写xml方法一样,注意主键!   sm.insertSelective(Stu s);   哪个属性不为null,插入哪个属性   sm.updateByExample(Stu s, Stuexample e);   sm.updateByExampleSelective(Stu s, Stuexample e);   sm.updateByPrimaryKey(Stu s);   //和原来自己写xml方法一样   sm.updateByPrimaryKeySelective(Stu s);  哪个属性不为null,修改哪个属性      条件或者:   se.or(criteria2);

排序:    se.setOrderByClause("sid desc");

分页:    oracle:     select * from (      select x1.*,rownum rr from (select * from stu order by sid desc) x1 where rr<=5*n     ) x2 where x2.rr>=5*n-4

mysql:     select * from stu order by sid desc limit 5*n-5,5

mybatis:不使用Mapper,使用session.selectList();     使用一个类:RowBounds     SqlSession session= MybatisUtil.getSqlSessionFactory().openSession();     RowBounds rb = new RowBounds(pageSize*pageNow-pageSize,pageSize);     List<Stu> list = session.selectList("com.aaa.mapper.StuMapper.selectByExample",null, rb);

重点:理解selective:所有的属性添加了if判断      Example:  对象的模板      Criteria:sql条件模板    StuExample se = new StuExample();    Criteria c = se.createCriteria();          熟练使用:XXXExample类

============================================================================

作业:2表crud  servlet-》biz->mapper(分页  模糊查询)

SqlSessionFactroy的作用:

SqlSession的作用:

StuMapper.xml中描述:必须清楚,动态sql标签,resultType  resultMap  对象间的关系  xml描述

${}和#{}的区别!  StuExample的作用:提供了条件模板,提供了排序,提供去冗余  Criteria的作用:  排序  分页

=========================================================================

group  by:分组:只要用到分组,只能必须一定查询组信息    组信息:select  组名,5个聚合函数 from  表名  group by  组名    having:给组加条件,只能出现组名,5个聚合函数

符合排序:select * from stu order by sage desc,sid asc  符合分组:select  ssex,count(*) from stu group by ssex,saddress...     是把ssex和saddress完全相同分为一组!

MyBatis动态Sql 的使用的更多相关文章

  1. mybatis实战教程(mybatis in action)之八:mybatis 动态sql语句

    mybatis 的动态sql语句是基于OGNL表达式的.可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类:1. if 语句 (简单的条件判断)2. c ...

  2. 9.mybatis动态SQL标签的用法

    mybatis动态SQL标签的用法   动态 SQL MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么 ...

  3. 自己动手实现mybatis动态sql

    发现要坚持写博客真的是一件很困难的事情,各种原因都会导致顾不上博客.本来打算写自己动手实现orm,看看时间,还是先实现一个动态sql,下次有时间再补上orm完整的实现吧. 用过mybatis的人,估计 ...

  4. Mybatis动态SQL单一基础类型参数用if标签

    Mybatis动态SQL单一基础类型参数用if标签时,test中应该用 _parameter,如: 1 2 3 4 5 6 <select id="selectByName" ...

  5. 超全MyBatis动态SQL详解!( 看完SQL爽多了)

    MyBatis 令人喜欢的一大特性就是动态 SQL. 在使用 JDBC 的过程中, 根据条件进行 SQL 的拼接是很麻烦且很容易出错的. MyBatis 动态 SQL 的出现, 解决了这个麻烦. My ...

  6. Mybatis动态SQL简单了解 Mybatis简介(四)

    动态SQL概况 MyBatis 的强大特性之一便是它的动态 SQL 在Java开发中经常遇到条件判断,比如: if(x>0){ //执行一些逻辑........ }   Mybatis应用中,S ...

  7. mybatis原理分析学习记录,mybatis动态sql学习记录

    以下个人学习笔记,仅供参考,欢迎指正. MyBatis 是支持定制化 SQL.存储过程以及高级映射的持久层框架,其主要就完成2件事情: 封装JDBC操作 利用反射打通Java类与SQL语句之间的相互转 ...

  8. mybatis 动态sql和参数

    mybatis 动态sql 名词解析 OGNL表达式 OGNL,全称为Object-Graph Navigation Language,它是一个功能强大的表达式语言,用来获取和设置Java对象的属性, ...

  9. MyBatis动态SQL之一使用 if 标签和 choose标签

    bootstrap react https://segmentfault.com/a/1190000010383464 xml 中 < 转义 to thi tha <if test=&qu ...

  10. MyBatis动态SQL(认真看看, 以后写SQL就爽多了)

    目录 0 一起来学习 mybatis 1 数据准备 2 if 标签 2.1 在 WHERE 条件中使用 if 标签 2.1.1 查询条件 2.1.2 动态 SQL 2.1.3 测试 2.2 在 UPD ...

随机推荐

  1. javascript——获取元素方式

    //1:依据id //var element = document.getElementById("test"); console.log(element); //2:依据clas ...

  2. Signalr Vue Echarts绘制实时CPU使用率

    后端基于Asp.net webapi,前端Vue,前后端分离,该demo仅做演示,实现的细节可以自己优化 Echarts:4.2.1  可参考 官网 Jquery:3.4.1 Signalr:2.4. ...

  3. ubuntu14 vim编译

    (1) ./configure --prefix=/usr (2) make VIMRCLOC=/etc/vim VIMRUNTIMEDIR=/usr/share/vim/vim74 MAKE=&qu ...

  4. net core体系-Xamarin-2概要(lignshi)

    通过本套课程的学习,各位学员能够对Xamarin有一个比较清楚的认识,掌握Xamarin常用功能的使用方法,能够比较熟练的使用Xamarin进行App(移动应用)的开发,能够比较轻松.快速地投入项目当 ...

  5. 对vuex分模块管理

    为什么要分模块: 由于使用单一状态树,应用的所有状态会集中到一个比较大的对象.当应用变得非常复杂时,store 对象就有可能变得相当臃肿.为了解决以上问题,Vuex 允许我们将 store 分割成模块 ...

  6. canvas之五角星的绘制

    <html> <head> <meta charset=utf-8> <title>绘制简单图形线及矩形</title> <style ...

  7. Mac下安装Redis及Redis Desktop Manager

    1.简介 Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库.缓存和消息中间件. 它支持多种类型的数据结构,如 字符串(strings), 散列(hashes), 列表 ...

  8. CHD-5.3.6集群安装

    我是基于Apache-hadoop2.7.3版本安装成功后,已有的环境进行安装chd-5..6 已用的环境: JDK版本: java version "1.8.0_191" Jav ...

  9. Linux环境下交叉编译器安装及运行

    描述: 由于 使用第三方编译器是提示No such file or directory 原因:编译器为32位版本,而系统是64位的 解决方法:安装32位版本编译支持库 sudo apt-get ins ...

  10. Map的使用及遍历方式

    Java中Map遍历的四种方式 如果同时需要key和value推荐使用entrySet(第一种): 如果只是获取key,或者value,推荐使用keySet或者values方式(第二种): 如果需要在 ...