mybatis如何直接 执行传入的任意sql语句 并按照顺序取出

作者: 光剑书架上的书 | 来源:发表于2017-09-04 22:52 被阅读88次

mybatis如何直接 执行传入的任意sql语句 并按照顺序取出查询的结果集

需求:

1.直接执行前端传来的任何sql语句,parameterType="String",

2.对于任何sql语句,其返回值类型无法用resultMap在xml文件里配置或者返回具体的bean类型,因此设置resultType="java.util.Map",但是Map并不保证存入取出顺序一致,

因此设置resultType="java.util.LinkedHashMap",为保证查询的字段值有序(存入与取出顺序一致)所以采用LinkedHashMap。

3.当返回值为LinkedHashMap时,表中存储的null值并不会存入Map中,因此还要在mybatis配置文件中增加如下配置:

<settings>
<setting name="callSettersOnNulls" value="true"/>
</settings>

mapper的接口方法:List<LinkedHashMap<String, Object>> superManagerSelect(String sql);

相匹配的xml文件:

<select id="superManagerSelect" parameterType="String" resultType="java.util.LinkedHashMap"> 
${sql} 
</select>

这样配置时,会出现:there no getter sql in java.lang.String 的异常,因此sql改成value,便不会报错。

<select id="superSelect" parameterType="String" resultType="java.util.LinkedHashMap"> 
${value} 
</select>

相关文章

  • mybatis如何直接 执行传入的任意sql语句 并按照顺序取出

    mybatis如何直接 执行传入的任意sql语句 并按照顺序取出查询的结果集 需求: 1.直接执行前端传来的任何s...

  • Mybatis-传入动态sql

    1. mybatis 传入sql 语句执行 实现: application.yml pom

  • Mybatis

    mybatis 执行传入的sql语句:https://blog.csdn.net/Laichilueng/arti...

  • TypeHandler源码简单分析

    简述 我们在使用mybatis时,经常会有这样的操作:传入参数到SQL语句中,SQL执行后,返回结果集并封装转化为...

  • MyBatis入门实验(一)之入门

    实验内容 使用Mybatis执行SQL语句从数据库中取出数据,并封装成Java对象返回 操作步骤 每个基于 MyB...

  • mybatis执行原生sql,并防止注入,并支持数据源动态切换(

    需求1:使用mybatis执行一个任意的sql语句,参数注入。 比如这条sql语句可能是动态生成的,并且我们并不知...

  • SQL性能分析

    sql语句执行顺序: sql语句和其他相关的编程语言最大不同的地方应该是执行顺序。对于大多数编程语言来说都是按照顺...

  • 2018-09-27

    sqlSession的作用:1、向sql语句传入参数2、执行sql语句3、获取执行sql语句的结果4、事务控制 如...

  • postgresql自定义函数语法

    最近在写postgres的函数,整理下常用语法备忘 定义内部变量 执行动态sql,并传入参数 执行动态sql,取出...

  • hive sql执行顺序

    mysq和hive的sql执行顺序对比 msyql语句执行顺序代码写的顺序: 代码的执行顺序: hive 语句执行...

网友评论

    本文标题:mybatis如何直接 执行传入的任意sql语句 并按照顺序取出

    本文链接:https://www.haomeiwen.com/subject/ukyyjxtx.html