博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
原!!mybatis如何直接 执行传入的任意sql语句 并按照顺序取出查询的结果集
阅读量:4557 次
发布时间:2019-06-08

本文共 805 字,大约阅读时间需要 2 分钟。

 

需求:

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>

 

转载于:https://www.cnblogs.com/wuyun-blog/p/5769096.html

你可能感兴趣的文章
ACM/ICPC 之 欧拉回路两道(POJ1300-POJ1386)
查看>>
避免死锁的银行家算法
查看>>
resultMap自定义某个javaBean的封装规则代码
查看>>
oracle tkprof 工具详解
查看>>
[Django实战] 第3篇 - 用户认证(初始配置)
查看>>
简单逆向分析修改软件标题
查看>>
20180607jquery实现切换变色
查看>>
框架大集合
查看>>
Centos7单网卡带VLAN多IP配置
查看>>
element-ui radio 再次点击取消选中
查看>>
hibernate9
查看>>
一大波放鄙视接近中
查看>>
任意类型转换为IntPtr
查看>>
$.each 和$(selector).each()的区别
查看>>
11-EasyNetQ之多态发布和订阅
查看>>
iOS App 的运行周期
查看>>
XSS Script
查看>>
qt中文乱码问题
查看>>
sed 删除最后几行 和删除指定行 awk使用
查看>>
LeetCode: Candy
查看>>