MybatisPlus分页排序查询字段带有下划线的坑及解决
作者:__Nexo 发布时间:2022-08-16 22:26:28
标签:MybatisPlus,分页,排序查询,字段,下划线
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 代码生成器,免去写繁琐映射的烦恼!
来源:https://blog.csdn.net/bhy5683/article/details/107608394


猜你喜欢
- 在Android开发中,Animation是用来给控件制作效果的。大多数的控件都可以用这个类,这个类包含了4种基本动作,分别为移动,旋转,淡
- Java IO中File的使用是比较频繁的,在文件的上传和删除中都会用到的。比如我们在写管理系统的时候有可能会用到图片的上传,和删除。那么我
- MyBatis的注解实现复杂映射开发实现复杂关系映射之前我们可以在映射文件中通过配置来实现,使用注解开发后,我们可以使用@Results注解
- 像javascript中有eval()来执行动态代码,c#中是没有的,于是自己动手丰衣足食,先来代码using System;using S
- 工作以来,代码越写越多,程序也越来越臃肿,效率越来越低,对于我这样一个追求完美的程序员来说,这是绝对不被允许的,于是除了不断优化程序结构外,
- Java 多线程方法详解startstart方法 启动线程 在start方法中调用start0方法,而start0是一个
- 前言上一篇博客内容对 RecyclerView 回收复用机制相关源码进行了分析,本博客从自定义 View 三大流程 measure、layo
- 一、概述UDP和TCP是网络通讯常用的两个传输协议,C#一般可以通过Socket来实现UDP和TCP通讯,由于.NET框架通过UdpClie
- 一、题目给出二叉搜索树的根节点,该树的节点值各不相同,请你将其转换为累加树(Greater Sum Tree),使每个节点 node 的新值
- 流程引擎对象和其配置对象都是activiti的核心对象一、activiti的简单使用流程activiti在工作时,一般有以下几个步骤:创建一
- 什么是分布式锁?在回答这个问题之前,我们先回答一下什么是锁。普通的锁,即在单机多线程环境下,当多个线程需要访问同一个变量或代码片段时,被访问
- synchronized原理在java中,每一个对象有且仅有一个同步锁。这也意味着,同步锁是依赖于对象而存在。当我们调用某对象的synchr
- 在平时开发应用的时候,经常会遇到列表排序、滑动删除的需求。如果列表效果采用的是 ListView 的话,需要经过自定义 View 才能实现效
- MyBatis-Plus 使用简单,内置通用 Mapper、通用 Service,仅仅通过少量配置,即可实现单表大部分 CRUD 操作。下面
- 前言:文件的上传和下载在日常开发中很是常见,那么这一功能是如何实现的呢,下面我给大家介绍一下实现条件:1、需要一个form标签,method
- Android自定义SwipeLayout仿QQ侧滑条目,供大家参考,具体内容如下先看动图 看布局文件activity_main.xml&l
- string fileExt = Path.GetExtension(excelPath);string conn = "&quo
- 提到java里的注解,和我们平时的注释还是有很大的区别,主要是作为java特性来使用的,跟我们常见的类是同一个使用的层面。关于java注解的
- 协程源码的结构在研究Kotlin源码之前,得先搞懂Kotlin源码结构分布。不然找不到该看哪里的代码。看源码之前当然先得有一个目标,最好是带
- CLR要求每一个类型都最终从object类型派生,如下: class Typer {} === class Typer :object {}