框架应用:Mybatis(二) - 动态SQL
MybatisUtil工具类
在实际开发中,我们可以编写一个MybatisUtil辅助类来进行对进行操作。
1)在静态初始化块中加载mybatis配置文件和StudentMapper.xml文件一次
2)使用ThreadLocal对象让当前线程与SqlSession对象绑定在一起
3)获取当前线程中的SqlSession对象,如果没有的话,从SqlSessionFactory对象中获取SqlSession对象
4)获取当前线程中的SqlSession对象,再将其关闭,释放其占用的资源
/** * MyBatis工具类 * @author AdminTC */ public class MyBatisUtil { private static ThreadLocal<SqlSession> threadLocal = new ThreadLocal<SqlSession>(); private static SqlSessionFactory sqlSessionFactory; static{ try { Reader reader = Resources.getResourceAsReader("mybatis.xml"); sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader); } catch (IOException e) { e.printStackTrace(); throw new RuntimeException(e); } } private MyBatisUtil(){} public static SqlSession getSqlSession(){ SqlSession sqlSession = threadLocal.get(); if(sqlSession == null){ sqlSession = sqlSessionFactory.openSession(); threadLocal.set(sqlSession); } return sqlSession; } public static void closeSqlSession(){ SqlSession sqlSession = threadLocal.get(); if(sqlSession != null){ sqlSession.close(); threadLocal.remove(); } } public static void main(String[] args) { Connection conn = MyBatisUtil.getSqlSession().getConnection(); System.out.println(conn!=null?"连接成功":"连接失败"); } }
MybatisUtil.java
动态SQL
什么是动态SQL,如下图,当你不知道用户会选择多少个筛选条件的时候,你只有等待用户选择而动态地选择SQL查询条件。
动态SQL-选择
加入IUserDao接口,注意因为与数据库互动需要,Dao接口一般要以类作为参数。
package com.harry.dao; import java.sql.SQLException; import java.util.List; import java.util.Set; import com.harry.entity.User; public interface IUserDao { public boolean doCreate(User entity) throws Exception; public boolean doUpdate(User entity) throws Exception; public boolean doRemove(Set<Integer> ids)throws Exception; public User findById(Integer id)throws Exception; public List<User> findAll() throws Exception; public List<User> findAllSplite(String column, String keyword, Integer currentPage, Integer lineSize) throws Exception; public Integer getAllCount(String column, String keyword) throws Exception; }
IUserDao
书写UserDaoImpl,并在其后添加动态查询的查询方法dynaSQLwithSelect。
package com.harry.dao.impl; import java.util.LinkedHashMap; import java.util.List; import java.util.Map; import java.util.Set; import org.apache.ibatis.session.SqlSession; import com.harry.dao.IUserDao; import com.harry.entity.User; import com.harry.util.MybatisUtil; public class UserDaoImpl implements IUserDao { @Override public boolean doCreate(User entity) throws Exception { // TODO Auto-generated method stub return false; } @Override public boolean doUpdate(User entity) throws Exception { // TODO Auto-generated method stub return false; } @Override public boolean doRemove(Set<Integer> ids) throws Exception { // TODO Auto-generated method stub return false; } @Override public User findById(Integer id) throws Exception { // TODO Auto-generated method stub return null; } @Override public List<User> findAll() throws Exception { // TODO Auto-generated method stub return null; } @Override public List<User> findAllSplite(String column, String keyword, Integer currentPage, Integer lineSize) throws Exception { // TODO Auto-generated method stub return null; } @Override public Integer getAllCount(String column, String keyword) throws Exception { // TODO Auto-generated method stub return null; } public List<User> dynaSQLwithSelect(String uname,Character usex) throws Exception{ SqlSession sqlSession = MybatisUtil.getSqlSession(); try{ Map<String,Object> map = new LinkedHashMap<String, Object>(); map.put("uname",uname); map.put("usex", usex); return sqlSession.selectList("dynaSQLwithSelect",map); }catch(Exception e){ e.printStackTrace(); sqlSession.rollback(); throw e; }finally{ sqlSession.commit(); MybatisUtil.closeSqlSession(); } } }
UserDaoImpl
在User.xml中配置相应的SQL方法映射。
<!-- map为调用该方法的外界传入 --> <select id="dynaSQLwithSelect" parameterType="map" resultType="com.harry.entity.User"> select id,username,sex from user <where> <!-- 如果map中uname不为null,则在where后添加username = uname; --> <if test="uname!=null"> and username=#{uname} </if> <!-- 如果map中usex不为null,则在where语句后添加 and sex = usex; --> <if test="usex!=null"> and sex=#{usex} </if> </where> </select>
User.xml
测试方法
@Test public void testdynaSQLwithSelect() throws Exception { UserDaoImpl userDao = new UserDaoImpl(); List<User> list = userDao.dynaSQLwithSelect("张飞", null); Iterator<User> iterator = list.iterator(); while(iterator.hasNext()){ System.out.println(iterator.next()); } }
MybatisTest
动态SQL增删改查基本相同,重点是Mybatis通过在配置文件中书写<where>语句来避免数据库SQL拼接。
动态SQL-更新
public boolean dynaSQLwithUpdate(Integer uid, String uname, String usex) throws Exception{ //session应该在事务层进行开关,这里为了方便 SqlSession sqlSession = MybatisUtil.getSqlSession(); try{ Map<String,Object> map = new LinkedHashMap<>(); map.put("uid", uid); map.put("uname", uname); map.put("usex", usex); sqlSession.update("dynaSQLwithUpdate",map); return true; }catch(Exception e){ e.printStackTrace(); sqlSession.rollback(); throw e; }finally{ sqlSession.commit(); MybatisUtil.closeSqlSession(); } }
UserDaoImpl
<update id="dynaSQLwithUpdate" parameterType="map"> UPDATE user <set> <if test="uname!=null"> username=#{user.username}, </if> <if test="usex!=null"> sex=#{usex}, </if> </set> where id=#{uid} </update>
User.xml
动态SQL-删除
public boolean dynaSQLwithDelete(Integer... ids) throws Exception{ //session应该在事务层进行开关,这里为了方便 SqlSession sqlSession = MybatisUtil.getSqlSession(); try{ Map<String, Object> map = new LinkedHashMap<>(); map.put("ids", ids); sqlSession.delete("dynaSQLwithDelete",map); return true; }catch(Exception e){ e.printStackTrace(); sqlSession.rollback(); throw e; }finally{ sqlSession.commit(); MybatisUtil.closeSqlSession(); } }
UserDaoImpl
<delete id="dynaSQLwithDelete" parameterType="map"> DELETE FROM user WHERE id IN <!-- foreach 用来迭代数组元素 --> <!-- open表示开始符号 --> <!-- close表示结束符号 --> <!-- separator表示分隔符 --> <!-- item表示迭代的数组 --> <foreach collection="ids" open="(" close=")" separator="," item="id"> #{id} </foreach> </delete>
User.xml
动态SQL- 插入
public boolean dynaSQLwithInsert(User... users) throws Exception{ //session应该在事务层进行开关,这里为了方便 SqlSession sqlSession = MybatisUtil.getSqlSession(); try{ Map<String, Object> map = new LinkedHashMap<>(); map.put("users", users); sqlSession.insert("dynaSQLwithInsert",map); return true; }catch(Exception e){ e.printStackTrace(); sqlSession.rollback(); throw e; }finally{ sqlSession.commit(); MybatisUtil.closeSqlSession(); } }
UserDaoImpl
<insert id="dynaSQLwithInsert" parameterType="map" useGeneratedKeys="true" keyProperty="id"> INSERT INTO user (username, birthday, sex, address) VALUES <foreach collection="users" item="user" separator=","> (#{user.username},#{user.birthday},#{user.sex},#{user.address}) </foreach> </insert> </mapper>
User.xml
框架应用:Mybatis(二) - 动态SQL的更多相关文章
- 使用Mybatis实现动态SQL(二)
使用Mybatis实现动态SQL 作者 : Stanley 罗昊 [转载请注明出处和署名,谢谢!] 写在前面: *本章节适合有Mybatis基础者观看* 使用Mybatis实现动态SQL ...
- 9、SpringBoot+Mybatis整合------动态sql
开发工具:STS 前言: mybatis框架中最具特色的便是sql语句中的自定义,而动态sql的使用又使整个框架更加灵活. 动态sql中的语法: where标签 if标签 trim标签 set标签 s ...
- MyBatis的动态SQL详解
MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑,本文详解mybatis的动态sql,需要的朋友可以参考下 MyBatis 的一个强大的特性之一通常是它 ...
- mybatis中的.xml文件总结——mybatis的动态sql
resultMap resultType可以指定pojo将查询结果映射为pojo,但需要pojo的属性名和sql查询的列名一致方可映射成功. 如果sql查询字段名和pojo的属性名不一致,可以通过re ...
- MyBatis的动态SQL详解-各种标签使用
MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑. MyBatis中用于实现动态SQL的元素主要有: if choose(when,otherwise) ...
- Java-MyBatis:MyBatis 3 动态 SQL
ylbtech-Java-MyBatis:MyBatis 3 动态 SQL 1.返回顶部 1. 动态 SQL MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其它类似框架 ...
- 一分钟带你了解下MyBatis的动态SQL!
MyBatis的强大特性之一便是它的动态SQL,以前拼接的时候需要注意的空格.列表最后的逗号等,现在都可以不用手动处理了,MyBatis采用功能强大的基于OGNL的表达式来实现,下面主要介绍下. 一. ...
- Mybatis中动态SQL语句中的parameterType不同数据类型的用法
Mybatis中动态SQL语句中的parameterType不同数据类型的用法1. 简单数据类型, 此时#{id,jdbcType=INTEGER}中id可以取任意名字如#{a,jdbcType ...
- Mybatis解析动态sql原理分析
前言 废话不多说,直接进入文章. 我们在使用mybatis的时候,会在xml中编写sql语句. 比如这段动态sql代码: <update id="update" parame ...
随机推荐
- AC Analysis
1.从Options---sheet properties—circuit—show all调出来节点编号 :
- Java对象中的finalize()方法使用说明
我在写java程序的时候,从来没有遇见过是用Object.finalize()的时候,但是在学习Java虚拟机的垃圾回收机制时,虚拟机在进行垃圾回收时需要使用finalize()方法来进行对象清理.下 ...
- C# 根据Excel模版导出文件
string fileName = Path.Combine(Application.StartupPath, "kfwh_yhxf.xls"); Microsoft.Office ...
- webSocket浏览器握手不成功(解决)
websocket与服务端握手会报握手不成功的错误解决方法: 首先是服务端首次收到请求要回报给客户端的报文要做处理多的不说,方法敬上: /// <summary> /// 打包请求连接数据 ...
- MongoDB对应SQL语句
-------------------MongoDB对应SQL语句------------------- 1.Create and Alter 1. sql: crea ...
- 转: 深入Java虚拟机】之二:Class类文件结构
转载请注明出处:http://blog.csdn.net/ns_code/article/details/17675609 平台无关性 Java是与平台无关的语言,这得益于Java源代码编译后生成的存 ...
- JS基础--函数与BOM、DOM操作、JS中的事件以及内置对象
前 言 絮叨絮叨 这里是JS基础知识集中讲解的第三篇,也是最后一篇,三篇JS的基础,大多是知识的罗列,并没有涉及更难得东西,干货满满!看完这一篇后,相信许多正在像我一样正处于初级阶段的同学, ...
- 分而治之(Work Breakdown Structure, WBS)
不知道大家有没有和我一样的情况,就是想写一篇博客,不知道从何写起,如何组织语言,如何安排这篇博客的要交待的事情的前因后果:如果在写作过程中被打断,又不知道如何重新拾起键盘,从哪里写起."就如 ...
- sudoku--设想
在查阅了一些资料和自己动手写一写后,找到一种可行的解法. 第一步 首先将9x9的数独方格分成九份3x3的九宫格,如下图 B1 B2 B3 B4 B5 B6 B7 B8 B9 而后在左上角的B1上随机生 ...
- bean的单例
通过改变中的scope属性,默认是singleton单例.而prototype则指定每getbean得到的都是不同实例. 验证代码: ①:验证默认singleton //验证<bean id=& ...