MybatisPlus分页排序查询字段带有下划线的坑及解决

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

MybatisPlus分页排序查询字段带有下划线的坑及解决⽬录
MybatisPlus分页排序查询字段带有下划线
MybatisPlus字段名称有下划线查询为null
原因分析
解决⽅案
MybatisPlus分页排序查询字段带有下划线
如果使⽤MybatisPlus的⾃动转驼峰命名法,分页排序查询的字段带有下划线时,会出问题。

page = new Page<>(pageNo, pageSize);
OrderItem orderItem = new OrderItem();
orderItem.setColumn("create_date");
orderItem.setAsc(isAsc);
page.addOrder(orderItem);
return page;
如果这样封装分页对象,字段是create_date的话,在最终执⾏时,order by的字段会⾃动变成createDate。

但是数据库是下划线的,就导致找不到字段,如果改成createDate,他还是按createDate去排序,⽆法解决。

不知道⼤家遇到过这个坑没有。

最终我是改数据库字段为createdate了
MybatisPlus字段名称有下划线查询为null
在Mybatis-plus中⾃⼰写sql查询时,采⽤ resultType 做字段映射,带下划线的字段值查询不到。

<select id="pageW_XKXMSJLXRSearch"
resultType="cjw.nic.niceasy.szyzgts.module.wy_ysgl.wy_01.wy_01_03.entity.W_XKXMSJLXR">
SELECT temp.*
FROM (
SELECT t.*
from w_xkxmsjlxr t
INNER JOIN w_xkxmjbxx wx ON t.SSXKXMJBXX_ID = wx.ID AND wx.SCBJ = 0 and t.scbj = 0
INNER JOIN s_xzqh sx ON sx.QHDM = #{qhdm} and wx.XZQHDM like CONCAT('%',sx.XJQHDMBDS,'%')
) as temp
${ew.customSqlSegment}
</select>
原因分析
Mybatis-plus默认开启驼峰转换,ssxkxmjbxx_id 字段会被转换为 ssxkxmjbxxId ,⾃然查询不到。

解决⽅案
(1)关闭 Mybatis-plus 驼峰转换,这样虽然能解决问题,但是会影响整个项⽬,得不偿失。

(2)采⽤ resultMap 做映射,⾃⼰写映射关系。

<!-- 通⽤查询映射结果 -->
<resultMap id="BaseResultMap" type="cjw.nic.niceasy.szyzgts.module.wy_ysgl.wy_01.wy_01_03.entity.W_XKXMSJLXR">
<id column="ID" property="id"/>
<result column="SSXTDM" property="ssxtdm"/>
<result column="SSGCDM" property="ssgcdm"/>
<result column="SSXKXMJBXX_ID" property="ssxkxmjbxx_id"/>
<result column="SSGLDW_ID" property="ssgldw_id"/>
<result column="GLDWLX" property="gldwlx"/>
<result column="LXRJSDM" property="lxrjsdm"/>
<result column="XM" property="xm"/>
<result column="SZBM" property="szbm"/>
<result column="ZW" property="zw"/>
<result column="SJH" property="sjh"/>
<result column="BGDH" property="bgdh"/>
<result column="CZ" property="cz"/>
<result column="YX" property="yx"/>
<result column="LXDZ" property="lxdz"/>
<result column="QQ" property="qq"/>
<result column="BZ" property="bz"/>
<result column="SCBJ" property="scbj"/>
<result column="SCJL_ID" property="scjl_id"/>
<result column="CJR_ID" property="cjr_id"/>
<result column="CJSJ" property="cjsj"/>
<result column="ZHXGR_ID" property="zhxgr_id"/>
<result column="ZHXGSJ" property="zhxgsj"/>
</resultMap>
<select id="pageW_XKXMSJLXRSearch"
resultMap="BaseResultMap">
SELECT temp.*
FROM (
SELECT t.*
from w_xkxmsjlxr t
INNER JOIN w_xkxmjbxx wx ON t.SSXKXMJBXX_ID = wx.ID AND wx.SCBJ = 0 and t.SCBJ = 0
INNER JOIN s_xzqh sx ON sx.QHDM = #{qhdm} and wx.XZQHDM like CONCAT('%',sx.XJQHDMBDS,'%') ) as temp
${ew.customSqlSegment}
</select>
ps: 采⽤ Mybaits-plus 代码⽣成器,免去写繁琐映射的烦恼!
以上为个⼈经验,希望能给⼤家⼀个参考,也希望⼤家多多⽀持。

相关文档
最新文档