mybatis如何直接 执行传入的任意sql语句 并按照顺序取出查询的结果集
发布日期:2021-05-04 16:20:20 浏览次数:20 分类:精选文章

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

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配置文件中增加如下配置:

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

相匹配的xml文件:

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

上一篇:Mysql 计算当前日期是本月第几周:一个自定义算法
下一篇:MySQL DATE_FORMAT() 函数

发表评论

最新留言

网站不错 人气很旺了 加油
[***.192.178.218]2025年04月01日 10时39分07秒