我们的表格只有一列名为number
。它包含黑名单号码。
例如,如果任何记录有 12345
号码,则所有以 12345
开头的号码都将被列入黑名单,这里 123456789
将被列入黑名单。
为此,我们使用下面的 sql 查询
select number from table WHERE '12345679' like concat(number,'%')
number
===
12345
1234587
98708293
我认为这个查询没有使用任何索引,所以我想优化这个查询
最佳答案
将查询更改为:
SELECT number
FROM table
WHERE number IN ('1', '12', '123', '1234', '12345', '123456', '1234567', '12345679')
并在 number
上创建索引。
如果您从编程语言执行查询,它应该能够使用输入字符串上的循环动态创建 IN
列表。如果您完全在 MySQL 中执行此操作,则可以在存储过程中执行。
关于mysql - 优化mysql中的反向LIKE查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37971124/