什么是执行语句(执行怎么造句子)

湘潭网餐饮知识
204

湘潭网小编为大家带来以下内容:

本篇内容介绍了“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主配置文件的位置, 从类路径开始的相对路径&mdash;&mdash;读取主配置文件里面的信息(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对象

举例 @Testpublic 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();}

“Mybatis怎么直接执行SQL语句”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注花开半夏网站,小编将为大家输出更多高质量的实用文章!

君子莲(www.junzilian.com)湖南省长沙、株洲、湘潭城市宣传信息网,提供房产,人才招聘,家居装饰,教育,论坛,旅游,特产,美食,天气,娱乐,企业等资讯。



最新餐饮知识

热门推荐

为你推荐