sqlserver模糊查询问题

针对mybatisplus

最早写法

复制代码
lqw.eq(OrgCodeView::getPositionEnabled, 1).like(StringUtils.isNotBlank(req.getPositionCode()), OrgCodeView::getPositionCode, req.getPositionCode())....

失败 关键是 其他字段汉字还行,但是PO07 code输入07 查不出来数据

中间写法

复制代码
lqw.eq(OrgCodeView::getPositionEnabled, 1).and(StringUtils.isNotBlank(req.getPositionCode()), i -> i.apply("PositionCode LIKE '%' + {0} + '%'", req.getPositionCode()))

这样不推荐!

  • MyBatis-Plus 的 apply("... {0} ...", param) 底层生成的是预编译 SQL(PreparedStatement),占位符 {0} 会被替换为 ?
  • 引发sql注入风险

===========

改为

// 1. 在 Java 代码中处理好参数

String positionCode = req.getPositionCode();

String likeCode = StringUtils.isNotBlank(positionCode) ? "%" + positionCode + "%" : null; // 2. 使用 Wrapper 构建查询 lqw.eq(OrgCodeView::getPositionEnabled, 1) .and(StringUtils.isNotBlank(likeCode), i -> i.like("PositionCode", likeCode));

这个没测试 ,需要的可以试下

最后写法 使用过没发现问题

复制代码
<if test="req.positionCode!=null and req.positionCode!='' ">
and PositionCode like '%'+ #{req.positionCode}+'%'
</if>
相关推荐
韶博雅2 小时前
emcc24ai
开发语言·数据库·python
专吃海绵宝宝菠萝屋的派大星2 小时前
使用Dify对接自己开发的mcp
java·服务器·前端
有想法的py工程师2 小时前
PostgreSQL 分区表排序优化:Append Sort 优化为 Merge Append
大数据·数据库·postgresql
大数据新鸟2 小时前
操作系统之虚拟内存
java·服务器·网络
Tong Z2 小时前
常见的限流算法和实现原理
java·开发语言
凭君语未可2 小时前
Java 中的实现类是什么
java·开发语言
He少年2 小时前
【基础知识、Skill、Rules和MCP案例介绍】
java·前端·python
迷枫7122 小时前
达梦数据库的体系架构
数据库·oracle·架构
克里斯蒂亚诺更新2 小时前
myeclipse的pojie
java·ide·myeclipse