mysql - 如何在数据库里优化 汉明距离 查询?
问题描述
项目里需要一个搜索相似图片的功能,百度了一些dhash的算法,生成了16个长度的hash值,在mysql里这样查询:
SELECT pk, hash, BIT_COUNT( CONV(hash, 16, 10) ^ CONV(’4c8e3366c275650f’, 16, 10) ) as hamming_distance FROM image_hashes HAVING hamming_distance < 4 ORDER BY hamming_distance ASC;
经测试,15W条数据,搜索需要很长时间。第二次速度会快些,有啥办法可以优化?
问题解答
回答1:谢邀。
抱歉地说,这个我也没有做过,只是之前听说过汉明距离。15w数据,不是很多,但是用了mysql的函数,没办法创建索引。。。
大概搜了一下,有相同的问题。可以参考mysql 图片汉明距离计算, 近40w的异或计算, 如何破
Hamming distance on binary strings in SQL
你可以试试mysql的内存表 MySQL内存表的特性与使用介绍
回答2:不好意思,没有“汉明距离”的相关经验。
如果只是15W数据的话,可以把数据加载到内存里缓存起来,然后在程序里运算,毕竟SQL并不擅长做这种事情。
仅从你的SQL来说,的确没有太大的优化空间,能想到的就只有以下几点:
hash列用char代替varchar
舍弃ORDER BY hamming_distance ASC,改为由程序排序
建议把DDL语句和EXPLAIN结果也发上来一并分析,不过最大的性能卡口应该是BIT_COUNT(CONV(hash, 16, 10) ^ CONV(’4c8e3366c275650f’, 16, 10)) as hamming_distance,其实相当于全表扫描了。
相关文章:
1. mysql - 分库分表、分区、读写分离 这些都是用在什么场景下 ,会带来哪些效率或者其他方面的好处2. css - 移动端 oppo 手机之 Border-radius3. 关于Mysql联合查询4. python 计算两个时间相差的分钟数,超过一天时计算不对5. 人工智能 - python 机器学习 医疗数据 怎么学6. 如何修改phpstudy的phpmyadmin放到其他地方7. javascript - vue-echarts-v3使用的过程中折线图区域呈渐变色。8. 爬虫图片 - 关于Python 爬虫的问题9. pip安装提示Twisted错误问题(Python3.6.4安装Twisted错误)10. c++ - 请问MySQL_Connection::isReadOnly 怎么解决?
