当前位置: 首页 > 面试题库 >

使用“ like”和通配符优化MySQL搜索

袁鸿畅
2023-03-14
问题内容

查询如何

SELECT * FROM sometable WHERE somefield LIKE '%value%'

被优化?

这里的主要问题是第一个通配符,它​​阻止DBMS使用索引。

编辑:此外,某字段值是纯字符串(不是一段文本),因此无法执行全文搜索。


问题答案:

两种方式:

(1)使用内存中的表,它可以非常快速地运行。

(2)制定比更好的索引和搜索算法foo LIKE '%bar%'。如果不了解您的问题,就不可能对此提出任何建议。

正如您所指出的那样,%bar%模式可确保对每个查找进行表扫描,从而使数据库软件中任何可能的搜索独创性都无效。



 类似资料:
  • 本文向大家介绍mysql优化之like和=性能详析,包括了mysql优化之like和=性能详析的使用技巧和注意事项,需要的朋友参考一下 引言 那使用过数据库的人大部分都知道,like和=号在功能上的相同点和不同点,那我在这里简单的总结下: 1,不同点:like可以用作模糊查询,而'='不支持此功能;如下面的例子,查询info表中字段id第一个字母为1的数据: 2,相同点:like和"="都可以进行

  • 问题内容: 以下是我用于通过电子邮件搜索人的查询 在“电子邮件”上添加索引会加快查询速度吗? 问题答案: 不可以,因为当您使用通配符时,MySQL将无法使用该索引。如果您将LIKE更改为’f%’,那么它将能够使用索引。

  • 问题内容: 我已经使用此批量请求设法用4个文档填充了索引: 开机自检 现在如何在所有可用 标题* 上使用 通配符 进行 搜索 ? *** 类似于 但提供一个或多个通配符的东西。例如,搜索“ ”并解析来自elasticsearch的响应以最终返回如下内容: 谢谢! 问题答案: Elasticsearch在常规匹配查询中提供正则表达式支持 给你这个 要更新到您的问题URI搜索,我不确定是否可行,如果使

  • 问题内容: 和MySQL中的通配符有什么区别? 在这样的查询中: 问题答案: 只能在全文搜索中用作通配符(或截断),而(匹配0个或更多字符)和(恰好匹配一个字符)仅适用于LIKE查询。

  • 本文向大家介绍Mysql| 使用通配符进行模糊查询详解(like,%,_),包括了Mysql| 使用通配符进行模糊查询详解(like,%,_)的使用技巧和注意事项,需要的朋友参考一下 通配符的分类: %百分号通配符: 表示任何字符出现任意次数 (可以是0次). _下划线通配符:表示只能匹配单个字符,不能多也不能少,就是一个字符. like操作符: LIKE作用是指示mysql后面的搜索模式是利用通

  • 问题内容: 我想在我的网页中进行全文搜索。我需要分页进行搜索。我的数据库每张表有50,000+行。我已经改变了我的表,并使其成为索引。该表始终处于更新状态,仍然有一个自动增加的列。而最新的总是在表格的末尾。 但整个查询时间将花费。我通过Google搜索了许多文章,有的文章写道,只有限制字段字长才能帮助更快地进行搜索。但作为一种类型,它会像这样改变一定的长度(我尝试过标题TEXT(500) CHAR