免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 16738 | 回复: 9
打印 上一主题 下一主题

[索引问题]MYSQL对于LIKE的优化,谁能给变个法子? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-03-22 09:57 |只看该作者 |倒序浏览
在ORALCE中对于
like 'str%'
like '%str'
都可以用到索引。

MYSQL只能对第一种情况用到索引。

如果第二种要用到的话,必须在程序端反转到第一种方式,
在MYSQL端好像不可以做到。不知道有人做过试验没有?

论坛徽章:
0
2 [报告]
发表于 2008-03-24 10:23 |只看该作者
我个人的经验是 如果是MYISAM引擎 英文的直接全文索引-中文的分词索引,用以取代LIKE

论坛徽章:
0
3 [报告]
发表于 2008-03-24 11:04 |只看该作者
原帖由 yueliangdao0608 于 2008-3-22 09:57 发表
在ORALCE中对于
like 'str%'
like '%str'
都可以用到索引。

MYSQL只能对第一种情况用到索引。

如果第二种要用到的话,必须在程序端反转到第一种方式,
在MYSQL端好像不可以做到。不知道有人做过试验没有?


突然想到一个变态的办法,就是新建一个字段,存储原是字段的反向内容,然后搜索时,就可以倒过来搜索了。例如:
like '%str‘  可以改成
like 'rts%'

呵呵,谁有兴趣可以去试试看

论坛徽章:
0
4 [报告]
发表于 2008-03-24 16:16 |只看该作者
嗯,楼上的这个变态,变得不错,哈哈

论坛徽章:
1
双子座
日期:2013-08-19 14:56:16
5 [报告]
发表于 2008-03-24 16:47 |只看该作者
原帖由 col.g 于 2008-3-24 16:16 发表
嗯,楼上的这个变态,变得不错,哈哈


论坛徽章:
0
6 [报告]
发表于 2008-03-24 17:07 |只看该作者
在其他数据库中反向索引是很正常的事,搞不懂为啥mysql不做。

论坛徽章:
0
7 [报告]
发表于 2008-03-24 20:48 |只看该作者
原帖由 yejr 于 2008-3-24 11:04 发表


突然想到一个变态的办法,就是新建一个字段,存储原是字段的反向内容,然后搜索时,就可以倒过来搜索了。例如:
like '%str‘  可以改成
like 'rts%'

呵呵,谁有兴趣可以去试试看



版主的方法好。

论坛徽章:
0
8 [报告]
发表于 2008-03-24 20:49 |只看该作者
原帖由 sunnyfun 于 2008-3-24 17:07 发表
在其他数据库中反向索引是很正常的事,搞不懂为啥mysql不做。



这个的确搞不明白。我那天也看到好几家数据库厂商都有。

论坛徽章:
0
9 [报告]
发表于 2011-07-26 15:10 |只看该作者
突然想到一个变态的办法,就是新建一个字段,存储原是字段的反向内容,然后搜索时,就可以倒过来搜索了 ...
yejr 发表于 2008-03-24 11:04



虽然不失为一个办法,但这个代价太大了

论坛徽章:
0
10 [报告]
发表于 2011-07-26 15:22 |只看该作者
老叶的那个倒序存放看起来不错。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP