带空格的模糊搜索方案,比如编码是 ABCD001,要求搜索 AB 01,能搜到,如何实现呢

81 天前
 lifeOsDeveloper
目前我的方案是在 java 把空格替换为%, 到 sql 用 like ,就变成 like '%AB%01%', 有没有好点的方案呢
939 次点击
所在节点    问与答
6 条回复
mumbler
81 天前
两个方案:
1. 用 Elasticsearch
2. 用向量数据库
iyaozhen
81 天前
你现在方案有什么问题嘛?
retanoj
81 天前
我就是想看看解决方案
Atma
81 天前
es
TWorldIsNButThis
81 天前
es 分词呗
yinmin
81 天前
专门写一个函数生成 sql 条件,输入字段列表、查询字串,输出 sql 条件字串,结果格式是:( (flda like ’%AB
%’ and flda like ’%01%’) or (fldb like ’%AB
%’ and fldb like ’%01%’) or (fldb like ’%AB
%’ and fldc like ’%01%’) )

like 字符串要转义,防止 sql 注入

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1098868

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX