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

网友投稿 1806 2022-11-18

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

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

目录MybatisPlus分页排序查询字段带有下划线MybatisPlus字段名称有下划线查询为null原因分析解决方案

MybatisPlus分页排序查询字段带有下划线

如果使用MybatisPlus的自动转驼峰命名法,分页排序查询的字段带有http://下划线时,会出问题。

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 做字段映射,带下划线的字段值查询不到。

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}

原因分析

Mybatis-plus默认开启驼峰转换,ssxkxmjbxx_id 字段会被转换为 ssxkxmjbxxId ,自然查询不到。

解决方案

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

(2)采用 resultMap 做映射,自己写映射关系。

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}

ps: 采用 Mybaits-plus 代码生成器,免去写繁琐映射的烦恼!

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}

ps: 采用 Mybaits-plus 代码生成器,免去写繁琐映射的烦恼!

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}

ps: 采用 Mybaits-plus 代码生成器,免去写繁琐映射的烦恼!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:1. 什么是Docker?
下一篇:【Webpack】Webpack基础入门
相关文章

 发表评论

暂时没有评论,来抢沙发吧~