MyBatis动态Sql 的使用
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 的使用的更多相关文章
- mybatis实战教程(mybatis in action)之八:mybatis 动态sql语句
mybatis 的动态sql语句是基于OGNL表达式的.可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类:1. if 语句 (简单的条件判断)2. c ...
- 9.mybatis动态SQL标签的用法
mybatis动态SQL标签的用法 动态 SQL MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么 ...
- 自己动手实现mybatis动态sql
发现要坚持写博客真的是一件很困难的事情,各种原因都会导致顾不上博客.本来打算写自己动手实现orm,看看时间,还是先实现一个动态sql,下次有时间再补上orm完整的实现吧. 用过mybatis的人,估计 ...
- Mybatis动态SQL单一基础类型参数用if标签
Mybatis动态SQL单一基础类型参数用if标签时,test中应该用 _parameter,如: 1 2 3 4 5 6 <select id="selectByName" ...
- 超全MyBatis动态SQL详解!( 看完SQL爽多了)
MyBatis 令人喜欢的一大特性就是动态 SQL. 在使用 JDBC 的过程中, 根据条件进行 SQL 的拼接是很麻烦且很容易出错的. MyBatis 动态 SQL 的出现, 解决了这个麻烦. My ...
- Mybatis动态SQL简单了解 Mybatis简介(四)
动态SQL概况 MyBatis 的强大特性之一便是它的动态 SQL 在Java开发中经常遇到条件判断,比如: if(x>0){ //执行一些逻辑........ } Mybatis应用中,S ...
- mybatis原理分析学习记录,mybatis动态sql学习记录
以下个人学习笔记,仅供参考,欢迎指正. MyBatis 是支持定制化 SQL.存储过程以及高级映射的持久层框架,其主要就完成2件事情: 封装JDBC操作 利用反射打通Java类与SQL语句之间的相互转 ...
- mybatis 动态sql和参数
mybatis 动态sql 名词解析 OGNL表达式 OGNL,全称为Object-Graph Navigation Language,它是一个功能强大的表达式语言,用来获取和设置Java对象的属性, ...
- MyBatis动态SQL之一使用 if 标签和 choose标签
bootstrap react https://segmentfault.com/a/1190000010383464 xml 中 < 转义 to thi tha <if test=&qu ...
- 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 ...
随机推荐
- 题解 P3369 【【模板】普通平衡树(Treap/SBT)】
STL真是个好东西. 最近在看pb_ds库及vector和set的用法,就想用这三种操作来实现一下普通平衡树,结果pb_ds中的rbtree不支持重复值,而本蒟蒻也看不懂不懂各大佬用pb_ds的实现, ...
- [转载]为什么jar包中能看见源码
[转载]为什么jar包中能看见源码 这个也是我之前发现过的一个现象,只是之前没有研究过.今天正好在知乎看见,总结一下: 对于Maven或者Gradle项目,依赖的部分会自动从远程仓库下载源码 生成的j ...
- 17.SpringMVC核心技术-拦截器
SpringMVC 中的 Interceptor 拦截器是非常重要和相当有用的,它的主要作用是拦截指定 的用户请求, 并进行相应的预处理与后处理.其拦截的时间点在“处理器映射器根据用户提 交的请求映射 ...
- Delphi 10.3.3最新消息
有朋友说,已经开始内测,预计10月末发版,按最新的路线图,此版本支持iOS 13及Android 64位. 2019-11-18,今天,下载及注册机都来了,快下载安装,试用吧. 需要的话加入QQ群20 ...
- 第四章、前端之BOM和DOM
目录 第四章.前端之BOM和DOM 一.解释BOM和DOM 二.window对象 三.window子对象 四.弹出框 五.计时相关 六.HTML的DOM树 七.查找元素 八.节点操作 九.JS操作CS ...
- Django—logging日志
简介 Django使用python自带的logging 作为日志打印工具.简单介绍下logging. logging 是线程安全的,其主要由4部分组成: Logger 用户使用的直接接口,将日志传递给 ...
- web开发:javascript动画
一.鼠标事件 二.js盒模型 三.鼠标拖拽 四.键盘事件 五.其他时间应用 六.定时器 七.定时器案例 八.随机数 一.鼠标事件 <!DOCTYPE html> <html> ...
- DA_03_linux网络配置及其远程连接
一: 修改Linux的基本配置 直接运行:setup,根据提示修改 1.修改主机名:vi /etc/sysconfig/network NETWORKING=yes HOSTNAME=shizhan1 ...
- 01_Redis简述
一:关系型数据库和非关系型数据库的区别: 1:关系型数据库(SQL):数据和数据之间,表和字段之间,表和表之间是存在关系的: 优点:数据之间有关系,进行数据的增删改查时非常方便的:关系型数据库有事务操 ...
- Linux磁盘及文件系统管理2
创建文件系统: 格式化:低级格式化(分区之前进行,划分磁道).高级格式化(分区之后对分区进行,创建文件系统) 元数据区,数据区 元数据区: 文件元数据:inode(index node) 大小.权限. ...