首页 > 解决方案 > 在 SQL 选择搜索中格式化字符串数据

问题描述

老实说,我不知道如何表达这一点。所以我只是解释一下这个问题

为了找到尽可能多的匹配项,我目前运行一段代码,将数据转换为大写,删除空格和无效字符。例如:

Hi there, I'm very happy! -> HITHEREIMVERYHAPPY

我的数据库达到了一个大小,运行检查 a 中每一行的代码不再有效ResultSet,所以我想知道这是否可能以SQL某种方式实现?

SELECT * FROM Data WHERE Input.replaceAll("[^a-zA-Z0-9]", "").replace(" ", "").toUpperCase() = INPUT AND Response.replaceAll("[^a-zA-Z0-9]", "").replace(" ", "").toUpperCase() = RESPONSE

标签: mysqlsqlselectresultsetformat-string

解决方案


你可能会喜欢RLIKE

-- Sample data
create table Data
(
  Id int primary key auto_increment,
  Input varchar(100),
  Response varchar(100)
);
insert into Data (Input, Response) values
  ('Hi there, I''m very happy! ->', 'To have 1 solution.')
, ('HITHEREIMVERYHAPPY', 'ToHave1Solution')
, ('I rlike this', 'IRLikeThis')

询问:

SELECT *
FROM Data
WHERE Input RLIKE '[^ A-Za-z0-9]'
  AND Response RLIKE '[^ A-Za-z0-9]'

结果:

身份证 | 输入 | 回复           
-: | :---------------------------- | :-----------------
 1 | 你好,我很高兴!-> | 有1个解决方案。

db<>在这里摆弄

它基本上使用正则表达式[^ A-Za-z0-9],它匹配包含任何不是字母、数字或空格的字符的字符串。


推荐阅读