Mybatis如何直接执行SQL语句

 更新时间:2022年08月19日 16:07:28   作者:Haolale  
这篇文章主要介绍了Mybatis如何直接执行SQL语句,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

Mybatis直接执行SQL语句

有时候我们如果要对传入的SQL验证语法方面怎么办呢,首先我们是不是要有一条完整的SQL,而且让mybatis去执行,这是小白最近遇到的,对于用户输入进来的语法与参数,进行拼接并且去执行,判断SQL语句有没有语法错误。

第一种方法

建立一个SQL工具进行SQL处理再返回完整的SQL语句

1.建立工具类

public class SqlProviderUtils {
    public String sqlProvider(Map<String, Object> para) {
        // 要替换一些字段的SQL(例子 select * from ${table} where ${filter})
        String str = para.get("sql").toString();
        // 参数用于替换SQL中的一些东西(例子: table ,filter 默认值 1=1)
        List<Params> paramsList = (List<Params>) para.get("ParamsList");
        List<Integer> head = new ArrayList();
        List<Integer> tail = new ArrayList();
        int headNum = 0;
        int tailNum = 0;
        List allStr = new ArrayList();
        // 每个${ 与 } 的位置
        int headPos = str.indexOf("${");
        int tailPos = str.indexOf("}");
        while (headPos > -1){
            if (headPos == headNum + 3) {
                head.set(head.size()-1, headPos);
                tail.set(tail.size() - 1, tailNum);
            } else {
                head.add(headPos);
                tail.add(tailPos);
            }
        headNum = headPos;
        tailNum = tailPos;
        headPos = str.indexOf("${", headPos + 1);
        tailPos = str.indexOf("}", tailPos + 1);
    }
        for (int i = 0; i < head.size(); i++) {
            allStr.add(str.substring(head.get(i)+2, tail.get(i)));
        }
        // 这里是针对上面保存的一些要替换的字段进行替换,具体怎么操作得详细理解代码
        for (int i=0; i<paramsList.size(); i++) {
         str = str.replace("${"+allStr.get(par-1)+"}.${"+paramsList.get(i).getName()+"}","a表");  
        }
        return str;
    }
}

2.在mapper中建立方法调用

// SqlProviderUtils上述类,sqlProvider上述的类方法
@SelectProvider(type = SqlProviderUtils.class, method = "sqlProvider")
 List<HaoDTO> sqlTemTest(@Param("sql") String sqlTemplate,@Param("ParamsList") List ParamsList);

3.controller与server没啥东西就一些三层调用这里不写

第二种方法

1.server层

 @Override
    @Transactional
    public Boolean testTemplate(Param param) {
        String str = Param.getSql();
        List<Params> paramsList = Param.getParamsList();
        List<Integer> head = new ArrayList();
        List<Integer> tail = new ArrayList();
        Boolean templateType = true;
        int headNum = 0;
        int tailNum = 0;
        List allStr = new ArrayList();
        int headPos = str.indexOf("${");
        int tailPos = str.indexOf("}");
        while (headPos > -1){
            if (headPos == headNum + 3) {
                head.set(head.size()-1, headPos);
                tail.set(tail.size() - 1, tailNum);
            } else {
                head.add(headPos);
                tail.add(tailPos);
            }
            headNum = headPos;
            tailNum = tailPos;
            headPos = str.indexOf("${", headPos + 1);
            tailPos = str.indexOf("}", tailPos + 1);
        }
        for (int i = 0; i < head.size(); i++) {
            try {
                allStr.add(str.substring(head.get(i)+2, tail.get(i)));
            } catch (StringIndexOutOfBoundsException e) {
                templateType = false;
            }
        }
        for (int i=0; i<paramsList.size(); i++) {
           str = str.replace("${"+allStr.get(par-1)+"}.${"+paramsList.get(i).getName()+"}", "b_quality_template");
        }
        try {
            if(templateType){
                baseMapper.sqlTest(str);
            }
        } catch (Exception e){
            templateType = false;
        }
        return templateType;
    }

2.mapper层

@Select("${sqlStr}")
List<Map<String, Object>> sqlTest(@Param(value = "sqlStr") String sqlStr);

3.其他东西也只是一些调用

以上只是说明下mybatis中怎么直接处理sql语句,重点在mapper其他是字段处理,这是小白弄毕设时考虑到的需求有点简单莫见怪。

测试Mybatis执行SQL语句步骤

调用mybatis某个对象的方法,执行mapper文件中的sql语句

mybatis核心类:SqlSessionFactory

1.定义mybatis主配置文件的位置, 从类路径开始的相对路径——读取主配置文件里面的信息(1.连接数据库:创建、连接对象的必要数据。2.mapper:找到要执行的sql语句)

2.读取主配置文件。使用mybatis框架中的Resources类

3.创建SqlSessionFactory对象, 使用SqlSessionFactoryBuidler类  

  • 1)每个基于 MyBatis 的应用都是以一个 SqlSessionFactory的实例为核心的。SqlSessionFactory的实例 可以通过 SqlSessionFactoryBuilder 获得。而SqlSessionFactoryBuilder 则可以从 XML 配置文件或一个预先配置的 Configuration实例 来构建出 SqlSessionFactory实例 。
  • 2)既然有了 SqlSessionFactory,顾名思义,可以从中获得SqlSession的实例。SqlSession 提供了在数据库执行 SQL 命令所需的所有方法。可以通过 SqlSession 实例来直接执行已映射的 SQL 语句。

4.获取SqlSession对象

5.指定要执行的sql语句的id

  • sql的id = namespace+"."+ select|update|insert|delete标签的id属性值

6.通过SqlSession的方法,执行sql语句

7.关闭SqlSession对象

举例 

@Test
public void testSelectStudentById2() throws IOException {
    //调用mybatis某个对象的方法,执行mapper文件中的sql语句
    //mybatis核心类: SqlSessionFactory
    //1.定义mybatis主配置文件的位置, 从类路径开始的相对路径
    String config = "mybatis.xml";
    //2.读取主配置文件。使用mybatis框架中的Resources类
    InputStream inputStream = Resources.getResourceAsStream(config);
    //3.创建SqlSessionFactory对象, 使用SqlSessionFactoryBuidler类
    // 每个基于 MyBatis 的应用都是以一个 SqlSessionFactory 的实例为核心的。
    // SqlSessionFactory 的实例可以通过 SqlSessionFactoryBuilder 获得。
    // 而 SqlSessionFactoryBuilder 则可以从 XML 配置文件或一个预先配置的 Configuration 实例来
    // 构建出 SqlSessionFactory 实例。
    SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(inputStream);
    //既然有了 SqlSessionFactory,顾名思义,可以从中获得 SqlSession 的实例。
    // SqlSession 提供了在数据库执行 SQL 命令所需的所有方法。
    // 你可以通过 SqlSession 实例来直接执行已映射的 SQL 语句。
    //4.获取SqlSession对象。
    SqlSession session = factory.openSession();
    //5.指定要执行的sql语句的 id
    //  sql的id = namespace+"."+ select|update|insert|delete标签的id属性值
    String sqlId = "com.bjpowernode.dao.StudentDao" + "." + "selectStudentById";
    // 6.通过SqlSession的方法,执行sql语句
    Student student = session.selectOne(sqlId,1002);
    System.out.println("使用mybatis查询一个学生:" + student);
    // 7.关闭SqlSession对象
    session.close();
}

这些仅为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。 

相关文章

  • Java实现学生管理系统

    Java实现学生管理系统

    这篇文章主要为大家详细介绍了Java实现学生管理系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • Java实现远程控制技术完整源代码分享

    Java实现远程控制技术完整源代码分享

    这篇文章主要为大家详细介绍了Java实现远程控制技术完整源代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • C# 中Excel导入时判断是否被占用三种方法

    C# 中Excel导入时判断是否被占用三种方法

    这篇文章主要介绍了C# 中Excel导入时 判断是否被占用三种方法的相关资料,需要的朋友可以参考下
    2017-04-04
  • java导出Excel通用方法的实例详解

    java导出Excel通用方法的实例详解

    这篇文章主要介绍了java导出Excel通用方法的实例详解的相关资料,需要的朋友可以参考下
    2017-07-07
  • Java生成随机数的2种示例方法代码

    Java生成随机数的2种示例方法代码

    在Java中,生成随机数有两种方法。1是使用Random类。2是使用Math类中的random方法。看下面的例子使用吧
    2013-11-11
  • Java毕业设计实战之食品溯源系统的实现

    Java毕业设计实战之食品溯源系统的实现

    这是一个使用了java+Springboot+Maven+mybatis+Vue+mysql+wd开发的食品溯源系统,是一个毕业设计的实战练习,具有食品溯源该有的所有功能,感兴趣的朋友快来看看吧
    2022-01-01
  • Spring Boot项目搭建的两种方式

    Spring Boot项目搭建的两种方式

    springboot简单快捷方便的优点深受用户喜爱,springboot开发环境搭建过程是每个开发者必须要做的工作,今天小编写的一篇教程关于Spring Boot项目搭建方法,通过两种方式给大家介绍的非常详细,需要的朋友参考下吧
    2021-06-06
  • Java插入修改删除数据库数据的基本方法

    Java插入修改删除数据库数据的基本方法

    这篇文章主要介绍了Java插入修改删除数据库数据的基本方法,是Java入门学习中的基础知识,需要的朋友可以参考下
    2015-10-10
  • JeecgBoot页面Online报表配置过程(动态)

    JeecgBoot页面Online报表配置过程(动态)

    文章介绍了如何根据登录者角色信息动态配置报表,并详细说明了Online报表的配置步骤,包括数据源选择、字段显示、查询条件设置等,同时,文章还涉及了页面代码部分,包括依赖引入、用户信息获取、参数配置和form表单配置等
    2026-01-01
  • Java并发编程之详解CyclicBarrier线程同步

    Java并发编程之详解CyclicBarrier线程同步

    在之前的文章中已经为大家介绍了java并发编程的工具:BlockingQueue接口,ArrayBlockingQueue,DelayQueue,LinkedBlockingQueue,PriorityBlockingQueue,SynchronousQueue,BlockingDeque接口,ConcurrentHashMap,CountDownLatch,本文为系列文章第十篇,需要的朋友可以参考下
    2021-06-06

最新评论