Mybatis如何直接执行SQL语句

这篇文章主要介绍了Mybatis如何直接执行SQL语句,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

Mybatis直接执行SQL语句

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

第一种方法

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

1.建立工具类

public class SqlProviderUtils {     public String sqlProvider(Map para) {         // 要替换一些字段的SQL(例子 select * from ${table} where ${filter})         String str = para.get("sql").toString();         // 参数用于替换SQL中的一些东西(例子: table ,filter 默认值 1=1)         List paramsList = (List) para.get("ParamsList");         List head = new ArrayList();         List 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 

2.在mapper中建立方法调用

// SqlProviderUtils上述类,sqlProvider上述的类方法 @SelectProvider(type = SqlProviderUtils.class, method = "sqlProvider")  List 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 paramsList = Param.getParamsList();         List head = new ArrayList();         List 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 

2.mapper层

@Select("${sqlStr}") List> 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(); } 

这些仅为个人经验,希望能给大家一个参考,也希望大家多多支持0133技术站。 

以上就是Mybatis如何直接执行SQL语句的详细内容,更多请关注0133技术站其它相关文章!

赞(0) 打赏
未经允许不得转载:0133技术站首页 » Java