当前位置:  开发笔记 > 后端 > 正文

使用IN或文本搜索

如何解决《使用IN或文本搜索》经验,为你挑选了1个好方法。

我想搜索一个表来查找一个特定字段是两个值之一的所有行.我确切知道这些值是什么,但我想知道哪种搜索方式最有效:

为了举例,两个值是"xpoints"和"ypoints".我肯定知道该字段中没有其他值在末尾有"点",所以我正在考虑的两个查询是:

WHERE `myField` IN ('xpoints', 'ypoints')
--- or...
WHERE `myField` LIKE '_points'

在这种情况下会给出最好的结果?



1> Kibbee..:

与SQL查询一样,通过分析器运行它以查找.然而,我的直觉本能不得不说IN搜索会更快.特别是在您给出的示例中,如果字段已编入索引,则只需执行2次查找.如果您进行了类似搜索,则可能需要进行扫描,因为您正在查找以特定值结尾的记录.它也会更准确,因为LIKE'_ points'也可以返回'gpoints'或任何其他类似的字符串.

推荐阅读
重庆制造漫画社
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有