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-2源码

框架应用:Mybatis(二) - 动态SQL的更多相关文章

  1. 使用Mybatis实现动态SQL(二)

    使用Mybatis实现动态SQL 作者 : Stanley 罗昊 [转载请注明出处和署名,谢谢!] 写在前面:        *本章节适合有Mybatis基础者观看* 使用Mybatis实现动态SQL ...

  2. 9、SpringBoot+Mybatis整合------动态sql

    开发工具:STS 前言: mybatis框架中最具特色的便是sql语句中的自定义,而动态sql的使用又使整个框架更加灵活. 动态sql中的语法: where标签 if标签 trim标签 set标签 s ...

  3. MyBatis的动态SQL详解

    MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑,本文详解mybatis的动态sql,需要的朋友可以参考下 MyBatis 的一个强大的特性之一通常是它 ...

  4. mybatis中的.xml文件总结——mybatis的动态sql

    resultMap resultType可以指定pojo将查询结果映射为pojo,但需要pojo的属性名和sql查询的列名一致方可映射成功. 如果sql查询字段名和pojo的属性名不一致,可以通过re ...

  5. MyBatis的动态SQL详解-各种标签使用

    MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑. MyBatis中用于实现动态SQL的元素主要有: if choose(when,otherwise) ...

  6. Java-MyBatis:MyBatis 3 动态 SQL

    ylbtech-Java-MyBatis:MyBatis 3 动态 SQL 1.返回顶部 1. 动态 SQL MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其它类似框架 ...

  7. 一分钟带你了解下MyBatis的动态SQL!

    MyBatis的强大特性之一便是它的动态SQL,以前拼接的时候需要注意的空格.列表最后的逗号等,现在都可以不用手动处理了,MyBatis采用功能强大的基于OGNL的表达式来实现,下面主要介绍下. 一. ...

  8. Mybatis中动态SQL语句中的parameterType不同数据类型的用法

    Mybatis中动态SQL语句中的parameterType不同数据类型的用法1. 简单数据类型,    此时#{id,jdbcType=INTEGER}中id可以取任意名字如#{a,jdbcType ...

  9. Mybatis解析动态sql原理分析

    前言 废话不多说,直接进入文章. 我们在使用mybatis的时候,会在xml中编写sql语句. 比如这段动态sql代码: <update id="update" parame ...

随机推荐

  1. 包含常用功能的 gulpfile.js

    相关包安装 建议使用cnpm npm install --save-dev ***** 其中 ***** 部分表示所需要的包模块,如 gulpfile 中的 require('gulp-useref' ...

  2. Linux主分区,扩展分区,逻辑分区的联系和区别

    主分区,也称为主磁盘分区,和扩展分区.逻辑分区一样,是一种分区类型.主分区中不能再划分其他类型的分区,因此每个主分区都相当于一个逻辑磁盘(在这一点上主分区和逻辑分区很相似,但主分区是直接在硬盘上划分的 ...

  3. Akka(21): Stream:实时操控:人为中断-KillSwitch

    akka-stream是多线程non-blocking模式的,一般来说,运算任务提交到另外线程后这个线程就会在当前程序控制之外自由运行了.任何时候如果需要终止运行中的数据流就必须采用一种任务柄(han ...

  4. 一起学ASP.NET Core 2.0学习笔记(二): ef core2.0 及mysql provider 、Fluent API相关配置及迁移

    不得不说微软的技术迭代还是很快的,上了微软的船就得跟着她走下去,前文一起学ASP.NET Core 2.0学习笔记(一): CentOS下 .net core2 sdk nginx.superviso ...

  5. open文件操作之mode模式剖析

    Python可以使用open函数来实现文件的打开,关闭,读写操作: Python3中的open函数定义为: open(file, mode='r', buffering=None, encoding= ...

  6. UEditor编辑器第一次赋值失败的解决方法

    网上查了很多方式都不是很好用,最后想到了这样的处理方式 首先在js中定义一个全局变量 var ue = null; 然后在初始化显示编辑器的时候js这样写 if (ue == null) { ue = ...

  7. struts分页实现

  8. 最近做了一个通达OA的大料:20170905最新版本破解可改单位名称,无限制安装

    最近做了一个通达OA的大料:20170905最新版本破解可改单位名称,无限制安装 用户约七十家,总体不错,修改了两次注册授权文件,完美使用中 可联系麦枫http://www.mfsun.com管理员Q ...

  9. PowerBI入门 第三篇:报表设计技巧

    最近做了几个PowerBI报表,对PowerBI的设计有了更深的理解,对数据的塑形(sharp data),不仅可以在Data Source中实现,例如在TSQL查询脚本中,而且可以在PowerBI中 ...

  10. Word直接发布新浪博客(以Wo…

    原文地址:Word直接发布新浪博客(以Word 2013为例)作者:paulke2011 注意:这篇博客直接由Word 2013发出!这虽然也算是一个教程,但更多的是一个试验品. 老早就知道Word有 ...