zoukankan      html  css  js  c++  java
  • 原!!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>

  • 相关阅读:
    ! JOISC2020DAY2变色龙之恋
    ! JOISC2020DAY1扫除
    JOISC2020DAY1汉堡肉
    JOISC2020DAY1建筑装饰4
    ! JLOI/SHOI2016随机序列
    JLOI/SHOI2016黑暗前的幻想乡
    ! JLOI/SHOI2016成绩比较
    JLOI/SHOI2016方
    JLOI/SHOI2016侦查守卫
    ! AHOI/HNOI2017抛硬币
  • 原文地址:https://www.cnblogs.com/wuyun-blog/p/5769096.html
Copyright © 2011-2022 走看看