1. COUNT(*) と COUNT(COL) COUNT(*)は通常、主キーに対してインデックススキャンを実行しますが、COUNT(COL)は必ずしもそうではありません。また、前者は統計テーブル内の一致するすべてのレコードの合計数をカウントしますが、後者は計算テーブル内の一致するすべてのCOLレコードの数をカウントします。違いはあります。 1. SELECT COUNT(*) FROM tablename は、どのような場合でも最適な選択です。 2. SELECT COUNT(*) FROMtablename WHERE COL = 'value'; のようなクエリを減らしてみてください。 3. SELECT COUNT(COL) FROM tablename WHERE COL2 ='value' の発生を防ぎます。 2. COUNT(*) または COUNT(id) 私の理解によれば、ID が自動増分主キーである場合、その番号を計算するとすべてのフィールドの数を計算するよりも明らかにリソースの消費が少なくなるため、COUNT(id) を使用する方が高速になるはずです。しかし、MySQL クエリを高速化する方法についての同様の記事を複数見てきました。これらの記事では、主キーを直接 COUNT するのではなく、SELECT COUNT(*) を使用することを推奨しています。これはなぜでしょうか? これは、MyISAM エンジンを使用するテーブルがエントリの総数を格納するためと思われます。WHERE がない場合、または WHERE が常に true の場合 (WHERE 1 など)、COUNT(*) はエントリの総数を直接返すことができます。 さらに、COUNT(*) が「すべてのフィールドを計算する」ことを意味しないことは明らかです。明らかに、MySQL は * を「データの一部」として解釈します。 テストデータ、単純な比較、それ以上のテストなし: #0.817 - 100万件のレコードのクエリ時間 select count(*) from student ; #0.789 - 100 万件のレコードのクエリ時間 select count(id) from student; #1.011-100万件のレコードのクエリ時間 select count(name) from student; #1.162-100万件のレコードのクエリ時間SELECT COUNT(*) FROM student WHERE namelike '%xiaoli%';#デフォルトでは、クエリには主キーインデックスが使用されますが、like条件を追加するとインデックスが無効になります 要約する 一般的に、COUNT(id) を使用する方が高速です。参考までに簡単な比較を示します。 以上が、MySQL 最適化の概要 - クエリの総数に関するこの記事の内容のすべてです。皆様のお役に立てれば幸いです。興味のある方は、サブクエリの代わりに結合を使用した MySQL の最適化、MYSQL サブクエリとネストされたクエリの最適化例の分析、MySQL のステートメント サブクエリの効率最適化スキル例などを参照してください。不足がある場合は、メッセージを残して指摘してください。このサイトをサポートしてくれた友人たちに感謝します! 以下もご興味があるかもしれません:
|
<<: jsはシングルクリックでテーブルを変更することを実装します
>>: docker で php+nginx+swoole+mysql+redis 環境を構築する方法
序文ページの HTML 構造にネストされたボックスが多数含まれている場合、ページに複数の垂直スクロー...
今日の午後からVS2019をMySQLで使えるのではないかと思い、いろいろ環境構築を始めました。プロ...
仮想マシン内のUbuntu 18.04がネットワークに接続できない問題の解決策は次のとおりですVMw...
目次コンテナ階層サーブレットの検索を要求するプロセス仕組みTomcat のコンテナは Servlet...
2時間近くかけて、さまざまな方法を試しました。後で、whereでフィルタリングした後のデータ量が1ペ...
コンテンツ詳細タグ: <h1>~<h6>タイトルタグ<pre>テ...
では、早速リソースについて見ていきましょう。 123WORDPRESS.COM ダウンロードSQLy...
目次序文コンポーネントの作成要約する序文Vue3 には多くの注目すべき機能が追加されましたが、サスペ...
数字で始まる次の CSS クラス名は有効になりません。 .1番目{ 色: 赤; }有効な CSS ク...
Mybatis ページングプラグイン pageHelper の詳細な説明と簡単な例動作フレームワーク...
ゲーム史上最高スコアトップ100をチェックSQLコード cdb_playsgame ps から ps...
質問最近、SSH フレームワークを使用して実用的なプロジェクトを完了していたときに、長い間悩まされて...
目次502 不正なゲートウェイ エラーの発生1. 502 不正なゲートウェイ エラーとは何ですか? ...
1. MavenをダウンロードするMaven 公式サイト: http://maven.apache...
説明: テキストエリアの値の改行を新しい行に変更しますコードをコピーコードは次のとおりです。 <...