mysql - 为什么使用Group By对SQL的索引性能会有很大的影响
问题描述
为什么使用Group By对SQL的索引性能会有很大的影响?索引是不是能提升group by的性能?
还有一点关于SQL的疑问,为什么在使用模糊查询的时候,%name%, 如果使用了前模糊,会使得索引没有了效果,这个怎么理解,虽然模糊的知道可能是这样的,但是找不到官方对此的说法。谢谢~
问题解答
回答1:“对索引性能有很大影响”是指什么?索引的时间太久了?但这似乎又和gruop by没什么关系。
所以我猜你的问题是不是“索引是不是能提升group by的性能”?这个问题的因果关系好想更容易理解些,那如果是这个问题的话,可能下面这段话能给你一些提示:
SQL databases use two entirely different group by algorithms. Thefirst one, the hash algorithm, aggregates the input records in atemporary hash table. Once all input records are processed, the hashtable is returned as the result. The second algorithm, the sort/groupalgorithm, first sorts the input data by the grouping key so that therows of each group follow each other in immediate succession.Afterwards, the database just needs to aggregate them. In general,both algorithms need to materialize an intermediate state, so they arenot executed in a pipelined manner. Nevertheless the sort/groupalgorithm can use an index to avoid the sort operation, thus enablinga pipelined group by.
原文出处:Indexing Group By
相关文章:
1. docker-machine添加一个已有的docker主机问题2. dockerfile - 我用docker build的时候出现下边问题 麻烦帮我看一下3. angular.js - angularjs的自定义过滤器如何给文字加颜色?4. 关docker hub上有些镜像的tag被标记““This image has vulnerabilities””5. 请问怎么改变超链接字体的颜色?6. docker网络端口映射,没有方便点的操作方法么?7. angular.js - angular2 有什么cool的loading组件么?8. docker内创建jenkins访问另一个容器下的服务器问题9. java - 做数据库向手机端的推送要系统地学习哪些知识?求大神指点,谢谢!10. java编程思想第4版中文版的几处谬误?
![docker-machine添加一个已有的docker主机问题](http://www.haobala.com/attached/image/news/202311/1028320972.png)