博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL模糊查询通配符_和%处理
阅读量:5751 次
发布时间:2019-06-18

本文共 698 字,大约阅读时间需要 2 分钟。

  hot3.png

下划线和百分号在sql模糊查询like语句中为特殊字符,分别可匹配1个字符和0到多个字符,如果需要真正查询特殊字符得转义,如like 'a\_b%' escape '\',将匹配前3个字符为a_b的所有记录。

1、PreparedStatement处理

普遍做法,拼sql时使用like ?,左模糊在查询条件字符串左侧添加%,右模糊在查询条件字符串右侧添加%,对特殊字符进行预先转义

condition = condition.replaceAll("_", "\\\\_");

condition = condition.replaceAll("%", "\\\\%");

ps.setString(idx, "%" + conditon + "%")

为什么replaceAll中需要使用4个\可参考jdk源码Matcher.appendReplacement方法。

专业做法,拼sql时使用like ? escape '\'(java中使用两个\\)

2、多数据库支持处理

在postgres中escape需要使用'\\'(java中使用四个\\)处理

3、其他思考

查找数据库是否有配置模糊查询的默认转义字符,搜索未果,可能关键字抽取有问题,试图在oracle的v$parameter中查找会话相关参数但是没有收获。

建议处理方式:在sql中like后添加escape,但是不对原始输入条件进行转换,用户可在查询条件中使用转义字符查询特殊字符也可以进行中间模糊查询,如输入'a%b','a\%b'。

转载于:https://my.oschina.net/h2do/blog/304421

你可能感兴趣的文章
利用OpenXml生成Word2007文档(转)
查看>>
Python Version 2.7 required which was not found in the registry
查看>>
Asp.net安全架构之1:xss(跨站脚本)
查看>>
Notepad++输入模式之修改模和插入模式的切换
查看>>
Asp.net安全架构之4:Brute force(爆破)
查看>>
DBS:同学录
查看>>
【JUnit4.10源码分析】5 Statement
查看>>
JAVA设计模式之【适配器模式】
查看>>
Mysql备份系列(1)--备份方案总结性梳理
查看>>
C#开发的高性能EXCEL导入、导出工具DataPie(支持MSSQL、ORACLE、ACCESS,附源码下载地址)...
查看>>
[CareerCup] 1.6 Rotate Image 翻转图像
查看>>
Execution Plan 执行计划介绍
查看>>
29.6. nm - list symbols from object files
查看>>
Codeforces Round #423 (Div. 2, rated, based on VK Cup Finals)爆零记
查看>>
jQuery中$.fn的用法示例介绍
查看>>
Python中的画图初体验
查看>>
又一个半成品库 weblog rpc client
查看>>
关于前端的photoshop初探的学习笔记
查看>>
Java程序员的日常 —— 响应式导航Demo
查看>>
敏捷软件开发宣言--常读常新
查看>>