记住一个点:
springboot 项目中有后门,即在html 页面中,可输入sql 传到后台去操作数据库。因此,select 语句时,查询的字段是随机的,但平时使用 mybatis 时都会建立 resultMap ,使数据库表中的字段,与实体类的 属性一一对应。查询字段随机,所以在 mybatis 的 xml 文件里无法建立返回 resultMap 。
做法:在 <select> 标签 中,resultType 直接写 java.util.Map 。
<select id="selectSql" parameterType="java.lang.String" statementType="STATEMENT" resultType="java.util.Map">
${exeSql}
</select>
此时就进入正题,若某条数据的某个字段值为 null ,则在返回形成的 Map中,没有该字段的 key键 (若值是空字符串,"",该key键也会有)。
解决:在配置文件 application.yml 的 mybatis 配置中,添加参数设置
mybatis:
configuration:
call-setters-on-nulls: true
此时,生成的 Map 中就会出现字段值为 null 的 key 键。当然,值依然是 null。