Inhaltsverzeichnis
回复内容:
Heim Backend-Entwicklung PHP-Tutorial 单表如何提高Select的效率?

单表如何提高Select的效率?

Jun 06, 2016 pm 08:18 PM
mysql php 数据库 数据库性能优化

情景:一个分类页面,因为每页显示的文章数量是固定的,通过设置偏移量来实现分页,大致如下:

<code>SELECT * FROM test WHERE status=1 AND category='mycat' LIMIT 0, 30</code>
Nach dem Login kopieren
Nach dem Login kopieren

在访问量大且偏移量大的情况下,性能不是很理想,而且随着数据量增长也比较快,所以想请教在单表的情况下,如何尽可能地进行优化,希望能提供些思路,谢谢

回复内容:

情景:一个分类页面,因为每页显示的文章数量是固定的,通过设置偏移量来实现分页,大致如下:

<code>SELECT * FROM test WHERE status=1 AND category='mycat' LIMIT 0, 30</code>
Nach dem Login kopieren
Nach dem Login kopieren

在访问量大且偏移量大的情况下,性能不是很理想,而且随着数据量增长也比较快,所以想请教在单表的情况下,如何尽可能地进行优化,希望能提供些思路,谢谢

抛开业务上的优化不谈 你可以做的有 优化表结构尽量能在区分度高的条件字段加索引 常用数据走缓存 数据里大的情况下按时间或id进行分表

mysql可以尝试分区(按月份分区),不是水平分表。

就你这个的情况,增加下联合索引再试试。

<code>ALTER TABLE `tablename`   
  ADD  INDEX `xxx-index` (`status`, `category`);</code>
Nach dem Login kopieren

再根据访问量统计一下 status,category组合中查询频率最高的,做一下缓存(可临时table,也可以直接redis等内存数据库)

我有单表接近6000万,组合条件查询结果在90万数据的情况下,翻页还算是正常的,当然可能访问量没你的大。

具体情况要具体分析哈,explain下 扫表的情况,如果表太大用limit比较吃力的时候,可以分表,也可以redis辅助一下

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

PHP 8.4 Installations- und Upgrade-Anleitung für Ubuntu und Debian PHP 8.4 Installations- und Upgrade-Anleitung für Ubuntu und Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 Installations- und Upgrade-Anleitung für Ubuntu und Debian

CakePHP-Projektkonfiguration CakePHP-Projektkonfiguration Sep 10, 2024 pm 05:25 PM

CakePHP-Projektkonfiguration

CakePHP Datum und Uhrzeit CakePHP Datum und Uhrzeit Sep 10, 2024 pm 05:27 PM

CakePHP Datum und Uhrzeit

CakePHP-Datei hochladen CakePHP-Datei hochladen Sep 10, 2024 pm 05:27 PM

CakePHP-Datei hochladen

CakePHP-Routing CakePHP-Routing Sep 10, 2024 pm 05:25 PM

CakePHP-Routing

Besprechen Sie CakePHP Besprechen Sie CakePHP Sep 10, 2024 pm 05:28 PM

Besprechen Sie CakePHP

So beheben Sie den Fehler „mysql_native_password nicht geladen' unter MySQL 8.4 So beheben Sie den Fehler „mysql_native_password nicht geladen' unter MySQL 8.4 Dec 09, 2024 am 11:42 AM

So beheben Sie den Fehler „mysql_native_password nicht geladen' unter MySQL 8.4

So richten Sie Visual Studio-Code (VS-Code) für die PHP-Entwicklung ein So richten Sie Visual Studio-Code (VS-Code) für die PHP-Entwicklung ein Dec 20, 2024 am 11:31 AM

So richten Sie Visual Studio-Code (VS-Code) für die PHP-Entwicklung ein

See all articles