直接执行前端传过来的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>

实际操作,直接写的param也成功了;仅供参考。

posted @ 2021-09-14 19:35  小小菜包子  阅读(409)  评论(0)    收藏  举报