#1. スロー クエリとは何ですか。
MySQL のスロー クエリとは何ですか?実際、クエリ SQL ステートメントには長い時間がかかります。遅いクエリの計算にはどのくらい時間がかかりますか?これは実際には人によって異なります。遅いクエリのしきい値を 100 ミリ秒としている企業もあれば、500 ミリ秒のしきい値を設定している企業もあります。つまり、クエリ時間がこのしきい値を超えると、遅いクエリとみなされます。
通常の状況では、MySQL はスロー クエリを自動的に有効にしません。有効になっている場合、デフォルトのしきい値は 10 秒です# slow_query_log 表示是否开启 mysql> show global variables like '%slow_query_log%'; +---------------------+--------------------------------------+ | Variable_name | Value | +---------------------+--------------------------------------+ | slow_query_log | OFF | | slow_query_log_file | /var/lib/mysql/0bd9099fc77f-slow.log | +---------------------+--------------------------------------+ # long_query_time 表示慢查询的阈值,默认10秒 show global variables like '%long_query_time%'; +-----------------+-----------+ | Variable_name | Value | +-----------------+-----------+ | long_query_time | 10.000000 | +-----------------+-----------+
2. スロー クエリの危険性
クエリが遅いことを非常に懸念しているため、いくつかの欠点があるはずです。一般的な欠点は次のとおりです:
1. ユーザー エクスペリエンスが低い。
何かにアクセスしたり、何かを保存したりするのに長い時間待たなければならないのに、毎分諦めてはどうでしょうか?エクスペリエンスが低下することはわかっていますが、低速クエリのしきい値を 100 ミリ秒に設定するのは低すぎるように思えます。1 ~ 2 秒間何かにアクセスするのは許容できるはずです。実際、このしきい値は SQL のしきい値であるため、低すぎるわけではありません。1 つのインターフェイスに対して SQL を数回チェックする必要がある場合があり、外部インターフェイスを調整することも非常に一般的です。
2. MySQL メモリの占有とパフォーマンスへの影響
MySQL メモリは本質的に制限されています (メモリが大きいと追加コストがかかります!) SQL クエリが遅いのはなぜですか?場合によっては、テーブル全体をスキャンし、さまざまなフィルターと組み合わせて大量のデータをクエリすると、処理が遅くなることがあります。したがって、クエリが遅いということは、メモリ使用量の増加を意味することがよくあります。メモリが多い場合、SQL クエリは、搭載できる量が少なくなり、性能が低下します。
3. DDL 操作のブロックを引き起こす
ご存知のとおり、InnoDB エンジンはデフォルトで行ロックを追加しますが、ロックは実際にはインデックスに追加されます。フィルター条件が満たされていないインデックスを作成すると、テーブル ロックにダウングレードされます。クエリが遅い原因のほとんどはインデックスの不足によるもので、クエリ時間が長すぎるとテーブルのロック時間も非常に長くなり、このときに DDL が実行されるとブロッキングが発生します。
3. 遅いクエリの一般的なシナリオ
遅いクエリは非常に多くの問題を引き起こすため、一般的にどのようなシナリオで遅いクエリが発生するのでしょうか?
1. インデックスが追加されていない/インデックスを有効に活用できていない
インデックスを追加していないの場合、次のような問題が発生します。テーブル全体のスキャン、または
インデックスに到達しない (またはインデックスが最適なインデックスではない) これら 2 つの状況により、スキャンされる行数が増加し、クエリ時間が遅くなります。 以下は私のテストの例です: # 这是我的表结构,算是一种比较常规的表
create table t_user_article
(
id bigint unsigned auto_increment
primary key,
cid tinyint(2) default 0 not null comment 'id',
title varchar(100) not null,
author varchar(15) not null,
content text not null,
keywords varchar(255) not null,
description varchar(255) not null,
is_show tinyint(1) default 1 not null comment ' 1 0',
is_delete tinyint(1) default 0 not null comment ' 1 0',
is_top tinyint(1) default 0 not null comment ' 1 0',
is_original tinyint(1) default 1 not null,
click int(10) default 0 not null,
created_at timestamp default CURRENT_TIMESTAMP not null,
updated_at timestamp default CURRENT_TIMESTAMP not null on update CURRENT_TIMESTAMP
)
collate = utf8mb4_unicode_ci;
上記のテーブル構造の下で、
を渡しました。この Web サイトは、テスト用にデータのバッチをランダムに生成しました。インデックスを作成しないと、データが 50,000 個になると遅いクエリが開始されることがわかります (しきい値が 100 ミリ秒であると仮定します)
クエリタイプ | クエリ時間 | ||
---|---|---|---|
#テーブル全体 (すべて) | 約 80ms | 50000 | |
フルテーブル (すべて) | 約 120 ミリ秒 | 100000 | |
テーブル全体 (すべて) | 概要180ms |
2、单表数据量太大 如果本身单表数据量太大,可能超千万,或者达到亿级别,可能加了索引之后,个别查询还是存在慢查询的情况,这种貌似没啥好办法,要么就看索引设置得到底对不对,要么就只能分表了。 3、Limit 深分页 深分页的意思就是从比较后面的位置开始进行分页,比如每页有10条,然后我要看第十万页的数据,这时候的分页就会比较“深” 还是上面的 -- 个人测试: 106000条数据,耗时约 150ms select * from t_user_article where click > 0 order by id limit 100000, 10; 在这种情况下,即使你的 结合上面的分析,目前的解决思路都是先查出主键字段(id),避免回表,再根据主键查出所有字段。 第一种,延迟关联,此时SQL变为: -- 个人测试: 106000条数据,耗时约 90ms select * from t_user_article t1, (select id from t_user_article where click > 0 order by id limit 100000, 10) t2 WHERE t1.id = t2.id; 第二种,分开查询,分开查询的意思就是分两次查,此时SQL变为: -- 个人测试: 106000条数据,耗时约 80ms select id from t_user_article where click > 0 order by id limit 100000, 10; -- 个人测试: 106000条数据,耗时约 80ms select * from t_user_article where id in (上述查询得到的ID) 大家可能会很疑惑,为什么要分开查呢,毕竟分开查可能最终耗时比一次查询还要高!这是因为有些公司(比如我司)可能只对单条SQL的查询时长有要求,但对整体的并没有要求,这时候这种办法就能达到一个折中的效果。 另外,大家在网上可能会看到利用子查询解决的办法,比如改成这样: select * from t_user_article where id in (select id from t_user_article where click > 0 limit 100000, 10) 但这时候执行你会发现抛出一个错误: “This version of MySQL doesn't yet support 'LIMIT & IN/ALL/ANY/SOME subquery’”,翻译过来就是子查询不支持Limit,解决办法也很简单,多嵌套一层即可: -- 个人测试: 106000条数据,耗时约 200ms select * from t_user_article where id in (select t.id from (select id from t_user_article where click > 0 order by id limit 100000, 10) as t) 但问题是测试后发现耗时反而变长了,所以并没有列举为一种解决办法。 4、使用FileSort查询 什么是 当查询的数据较少,没有超过系统变量 FileSort出现的场景主要有以下两种: 4.1 排序字段没加索引 # click 字段此时未加索引 explain select id, click from t_user_article where click > 0 order by click limit 10; # explain 结果: type:ALL Extra:Using where; Using filesort 解决办法就是在 click 字段上加索引。 4.2 使用两个字段排序,但是排序规则不同,一个正序,一个倒序 # click 字段此时已加索引 explain select id, click from t_user_article where click > 0 order by click desc, id asc limit 10; # explain 结果: type:range Extra:Using where; Using index; Using filesort 这种场景常出现于排行榜中,因为排行榜经常需要按照 某个指标倒序 + 创建时间正序 排列。这种目前暂时无解,有解决办法的大佬望在评论区留言。 总结总的来说,看完本文应该对慢查询有所了解了,慢查询优化是一个经久不衰的话题,场景也非常多元化,需要对索引的原理以及索引命中有一定了解,如有错漏,望大佬们在评论区留言。 【相关推荐:mysql视频教程】 |
以上がこの記事では、MySQL の遅いクエリについて簡単に理解できます。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

MySQLは、初心者がデータベーススキルを学ぶのに適しています。 1.MySQLサーバーとクライアントツールをインストールします。 2。selectなどの基本的なSQLクエリを理解します。 3。マスターデータ操作:テーブルを作成し、データを挿入、更新、削除します。 4.高度なスキルを学ぶ:サブクエリとウィンドウの関数。 5。デバッグと最適化:構文を確認し、インデックスを使用し、選択*を避け、制限を使用します。

MySQLは、テーブル構造とSQLクエリを介して構造化されたデータを効率的に管理し、外部キーを介してテーブル間関係を実装します。 1.テーブルを作成するときにデータ形式と入力を定義します。 2。外部キーを使用して、テーブル間の関係を確立します。 3。インデックス作成とクエリの最適化により、パフォーマンスを改善します。 4.データベースを定期的にバックアップおよび監視して、データのセキュリティとパフォーマンスの最適化を確保します。

MySQLは、Web開発で広く使用されているオープンソースリレーショナルデータベース管理システムです。その重要な機能には、次のものが含まれます。1。さまざまなシナリオに適したInnodbやMyisamなどの複数のストレージエンジンをサポートします。 2。ロードバランスとデータバックアップを容易にするために、マスタースレーブレプリケーション機能を提供します。 3.クエリの最適化とインデックスの使用により、クエリ効率を改善します。

SQLは、MySQLデータベースと対話して、データの追加、削除、変更、検査、データベース設計を実現するために使用されます。 1)SQLは、ステートメントの選択、挿入、更新、削除を介してデータ操作を実行します。 2)データベースの設計と管理に作成、変更、ドロップステートメントを使用します。 3)複雑なクエリとデータ分析は、ビジネス上の意思決定効率を改善するためにSQLを通じて実装されます。

MySQLの基本操作には、データベース、テーブルの作成、およびSQLを使用してデータのCRUD操作を実行することが含まれます。 1.データベースの作成:createdatabasemy_first_db; 2。テーブルの作成:createTableBooks(idintauto_incrementprimarykey、titlevarchary(100)notnull、authorvarchar(100)notnull、published_yearint); 3.データの挿入:InsertIntoBooks(タイトル、著者、公開_year)VA

WebアプリケーションにおけるMySQLの主な役割は、データを保存および管理することです。 1.MYSQLは、ユーザー情報、製品カタログ、トランザクションレコード、その他のデータを効率的に処理します。 2。SQLクエリを介して、開発者はデータベースから情報を抽出して動的なコンテンツを生成できます。 3.MYSQLは、クライアントサーバーモデルに基づいて機能し、許容可能なクエリ速度を確保します。

MySQLデータベースを構築する手順には次のものがあります。1。データベースとテーブルの作成、2。データの挿入、および3。クエリを実行します。まず、createdAtabaseおよびcreateTableステートメントを使用してデータベースとテーブルを作成し、InsertINTOステートメントを使用してデータを挿入し、最後にSelectステートメントを使用してデータを照会します。

MySQLは、使いやすく強力であるため、初心者に適しています。 1.MYSQLはリレーショナルデータベースであり、CRUD操作にSQLを使用します。 2。インストールは簡単で、ルートユーザーのパスワードを構成する必要があります。 3.挿入、更新、削除、および選択してデータ操作を実行します。 4. Orderby、Where and Joinは複雑なクエリに使用できます。 5.デバッグでは、構文をチェックし、説明を使用してクエリを分析する必要があります。 6.最適化の提案には、インデックスの使用、適切なデータ型の選択、優れたプログラミング習慣が含まれます。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

ドリームウィーバー CS6
ビジュアル Web 開発ツール

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、
