Mybatis如何直接执行SQL语句

目录
  • Mybatis直接执行SQL语句
    • 第一种方法
    • 第二种方法
  • 测试Mybatis执行SQL语句步骤
    • mybatis核心类:SqlSessionFactory
    • 举例

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();
}

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

(0)

相关推荐

  • MyBatis一次执行多条SQL语句的操作

    有个常见的场景:删除用户的时候需要先删除用户的外键关联数据,否则会触发规则报错. 解决办法不外乎有三个: 1.多条sql分批执行: 2.存储过程或函数调用: 3.sql批量执行. 今天我要说的是MyBatis中如何一次执行多条语句(使用mysql数据库). 1.修改数据库连接参数加上allowMultiQueries=true,如: hikariConfig.security.jdbcUrl=jdbc:mysql://xx.xx.xx:3306/xxxxx?characterEncoding=u

  • MyBatis直接执行SQL的工具SqlMapper

    可能有些人也有过类似需求,一般都会选择使用其他的方式如Spring-JDBC等方式解决. 能否通过MyBatis实现这样的功能呢? 为了让通用Mapper更彻底的支持多表操作以及更灵活的操作,在2.2.0版本增加了一个可以直接执行SQL的新类SqlMapper. 我们来了解一下SqlMapper. SqlMapper提供的方法 SqlMapper提供了以下这些公共方法: Map<String,Object> selectOne(String sql) Map<String,Object&

  • 浅谈MyBatis 如何执行一条 SQL语句

    前言 Mybatis 是 Java 开发中比较常用的 ORM 框架.在日常工作中,我们都是直接通过 Spring Boot 自动配置,并直接使用,但是却不知道 Mybatis 是如何执行一条 SQL 语句的,而这篇文章就是来揭开 Mybatis 的神秘面纱. 基础组件 我们要理解 Mybatis 的执行过程,就必须先了解 Mybatis 中都有哪一些重要的类,这些类的职责都是什么? SqlSession 我们都很熟悉,它对外提供用户和数据库之间交互需要使用的方法,隐藏了底层的细节.它默认是实现类

  • 浅谈MyBatis执行SQL的两种方式

    目录 前言 准备接口和Mapper配置文件: 使用SqlSession 发送 SQL 使用 Mapper 接口发送 SQL 比较两种发送 SQL 方式 前言 本文介绍MyBatis执行SQL语句的2种方式:SqlSession和Mapper接口以及它们的区别. 准备接口和Mapper配置文件: 定义UserMapper接口: package cn.cvs.dao; import cn.cvs.pojo.User; import java.util.List; public interface U

  • Mybatis如何直接执行SQL语句

    目录 Mybatis直接执行SQL语句 第一种方法 第二种方法 测试Mybatis执行SQL语句步骤 mybatis核心类:SqlSessionFactory 举例 Mybatis直接执行SQL语句 有时候我们如果要对传入的SQL验证语法方面怎么办呢,首先我们是不是要有一条完整的SQL,而且让mybatis去执行,这是小白最近遇到的,对于用户输入进来的语法与参数,进行拼接并且去执行,判断SQL语句有没有语法错误. 第一种方法 建立一个SQL工具进行SQL处理再返回完整的SQL语句 1.建立工具类

  • 解决mybatis执行SQL语句部分参数返回NULL问题

    今天在写代码的时候发现一个问题:mybatis执行sql语句的时候返回bean的部分属性为null,在数据库中执行该sql语句能够正常返回,把相关代码反反复复翻了个遍,甚至都重启eclipse了,依旧没解决问题,后来网上搜了一下,还真有类似的问题. 闲话少说,直接说问题,该sql语句是自己写的,resultType直接用了该bean全名称,最终导致部分属性显示为null, 原来的写法: <select id="selectByArticle" parametertype=&quo

  • 在mybatis执行SQL语句之前进行拦击处理实例

    比较适用于在分页时候进行拦截.对分页的SQL语句通过封装处理,处理成不同的分页sql. 实用性比较强. import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.List; import java.util.Properties; import org.apache.ibatis.e

  • java执行SQL语句实现查询的通用方法详解

    完成SQL查询 并将查询结果放入Vector容器,以便其他程序使用 /* * 执行sql查询语句 */ public static <T> Vector<T> executeQuery(Class<T> clazz, String sql, Object... args) { Connection conn = null; PreparedStatement preparedstatement = null; ResultSet rs = null; Vector<

  • Mybatis中的动态SQL语句解析

    这篇文章主要介绍了Mybatis中的动态SQL语句解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 Mybatis中配置SQL有两种方式,一种是利用xml 方式进行配置,一种是利用注解进行配置. Mybatis使用注解配置SQL,但是由于配置功能受限,而且对于复杂的SQL而言可读性很差,所以很少使用. Mybatis常用xml配置的方式,使用xml的几个简单的元素,便能完成动态SQL的功能,大量的判断都可以在mybaties的映射xml里面配

  • springboot实现执行sql语句打印到控制台

    springboot 执行sql语句打印到控制台 1.简介 每当写完持久化语句时肯定免不了要查漏补缺一波.这里就可以将执行的sql打印到控制台来检查sql语句哪里出了问题. 2.配置 配置非常简单,只需要在配置文件中设置下mapper日志级别就可以了 3.代码 application-test.properties #logging.level.mapper的路径=异常级别 logging.level.com.shuhe360.auth.auth_main_car_api.mapper.CarC

  • C#实现连接SQL Server2012数据库并执行SQL语句的方法

    本文实例讲述了C#实现连接SQL Server2012数据库并执行SQL语句的方法.分享给大家供大家参考,具体如下: 开发工具:Visual Studio 2012 数据库: SQL Server 2012 使用Visual Studio时还是直接和微软自家的SQL Server数据库连接比较方便,就像使用Eclipse时和MySQL连接便捷一样的道理 无论使用什么工具步骤都一样: 1. 首先保证相关工具都已经正确安装了 2. 开启数据库连接服务 3. 在开发工具中通过用户名和口令与数据库进行关

  • 在ASP.NET中用存储过程执行SQL语句

    存储过程执行效率比单独的SQL语句效率高. 样编写存储过程?存储过程在SQL Server 2005对应数据库的可编程性目录下. 比如,创建一个存储过程 复制代码 代码如下: create procedure procNewsSelectNewNews as begin select top 10 n.id,n.title,n.createTime,c.name from news n inner join category c on n.caId=c.id order by n.createT

  • SQLServer 2000定时执行SQL语句

    我不知道存储过程等能否实现,但是SQL Server 2000的作业调度确实有这样的功能,怎样使某些SQL语句定时执行呢,依次进行下面的操作: 企业管理器 --管理 --SQL Server代理 --右键作业 --新建作业 --"常规"项中输入作业名称 --"步骤"项 --新建 --"步骤名"中输入步骤名 --"类型"中选择"Transact-SQL 脚本(TSQL)" --"数据库"选

  • 使用BAT批处理执行sql语句的代码

    1.把待执行Sql保存在一个文件,这里为20110224.sql.2.新建一个扩展名.bat的批处理文件,输入下面命令并保存后,双击.bat文件,系统会自动执行20110224.sql的语句: 复制代码 代码如下: osql -S gdjlc -d TestDB -U sa -P 1 -i 20110224.sql osql参数见下面=======================================================================: E:\>osql

随机推荐