mysql Union all の効率の問題
同じ構造を持つテーブルが複数あり、結合テーブル クエリを実行する必要があります。次のステートメントを使用します。
select sum(cnt) from (select count(*) as cnt from t1 where a>100 Union all select.. . ) as t; この文は合計を得るのが非常に簡単です。
select * from t1 where a>100 Union all select * from t2 where a>100 Union all select * from t3 where a>100 order by b desc limit 0,10000;
この文は非常に効率が悪いようです。長い間結果が出ました。
どのように最適化すべきですか、ありがとうございます
ディスカッションへの返信 (解決策)
2 番目の文には、何らかの影響があると推定される order by b desc limit 0,10000 が含まれています。削除してみてください。
2 番目の文には、order by b desc limit 0,10000 が含まれているため、これを削除して試してください。
理由はわかります。各テーブルのデータ量が多すぎるため、クエリを実行すると、最初に複数のテーブルから一致するレコードがすべて取得されてから LIMIT されるため、処理が遅くなります。
しかし、各テーブルのクエリに LIMIT と ORDER BY を追加すると、取得されるデータが不正確になります。それを解決する方法はありますか?
あなたの書き方は明らかに不合理、または時代遅れです (手動でテーブルを分割しており、分割が不合理であるため)
MySQL はパーティショニング機能を提供するようになりました適切な設定であれば、単一の小規模テーブルと同等の速度になります (ただし、複数のデータ ファイルに分割されます)

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

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

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

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

ホットトピック











Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

これは、LaravelバックエンドとのReactアプリケーションの構築に関するシリーズの2番目と最終部分です。シリーズの最初の部分では、基本的な製品上場アプリケーションのためにLaravelを使用してRESTFUL APIを作成しました。このチュートリアルでは、開発者になります

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

この記事では、Laravel Webフレームワークの通知システムを検討します。 Laravelの通知システムを使用すると、さまざまなチャネルでユーザーに通知を送信できます。今日は、通知ovを送信する方法について説明します

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

PHPロギングは、Webアプリケーションの監視とデバッグ、および重要なイベント、エラー、ランタイムの動作をキャプチャするために不可欠です。システムのパフォーマンスに関する貴重な洞察を提供し、問題の特定に役立ち、より速いトラブルシューティングをサポートします
