ホームページ データベース mysql チュートリアル SQL データベース ステートメントの最適化分析と最適化手法の概要 (SQL 最適化ツール)

SQL データベース ステートメントの最適化分析と最適化手法の概要 (SQL 最適化ツール)

Aug 03, 2018 pm 05:37 PM

通常、SQL データベースは最適化および分析する必要がありますが、SQL 最適化のいくつかの方法についてはここでは詳しく紹介しません。また、最適化ツール SQL Tuning Expert for Oracle も付属しています。使用方法としては、まずデータベース最適化のいくつかの原則に従う必要があります:

1. インデックスの失敗を引き起こすため、結合を使用する必要があります。複雑な結合クエリを複数のクエリに分割しながら、小さな結果セットを使用して大きな結果セットを駆動します。そうしないと、結合するテーブルが増えるほど、ロックや輻輳が発生します。

3. ファジー クエリの使用に注意し、%% の使用を避けてください。たとえば、select * from a where name like '%de%';

置換ステートメント: select * from a where name >= ' de' と name < ; 'df';

4. クエリが必要なフィールドのみをリストし、メモリを節約するために select * from... を使用しないでください。

insert into a (id ,name)
values(2,&#39;a&#39;),
(3,&#39;s&#39;);
ログイン後にコピー

6.limit ベースは比較的大きいです

7. ランダムにレコードを取得するために rand 関数を使用しないでください。テーブルを構築するときに null を使用しないでください。

9. count(id) ではなく count(*) を使用します

10. 不要なソートを行わず、可能な限りインデックス内でソートを完了します

まず SQL を見てみましょう:

 select
                    ii.product_id, 
                    p.product_name, 
                    count(distinct pim.pallet_id) count_pallet_id, 
                    if(round(sum(itg.quantity),2) > -1 && round(sum(itg.quantity),2) < 0.005, 0, round(sum(itg.quantity),2)) quantity,
                    round(ifnull(sum(itag.locked_quantity), 0.00000),2) locked_quantity,
                    pc.container_unit_code_name,
                    if(round(sum(itg.qoh),2) > -1 && round(sum(itg.qoh),2) < 0.005, 0, round(sum(itg.qoh),2)) qoh,
                    round(ifnull(sum(itag.locked_qoh), 0.00000),2) locked_qoh,
                    p.unit_code,
                    p.unit_code_name
                from (select 
                        it.inventory_item_id item_id, 
                        sum(it.quantity) quantity, 
                        sum(it.real_quantity) qoh 
                    from 
                        ws_inventory_transaction it
                    where 
                        it.enabled = 1 
                    group by 
                        it.inventory_item_id  
                    ) itg 
                    left join (select 
                                    ita.inventory_item_id item_id, 
                                    sum(ita.quantity) locked_quantity, 
                                    sum(ita.real_quantity) locked_qoh 
                               from 
                                    ws_inventory_transaction_action ita
                               where 
                                    1=1 and ita.type in (&#39;locked&#39;, &#39;release&#39;) 
                               group by 
                                    ita.inventory_item_id 
                               )itag on itg.item_id = itag.item_id
                    inner join ws_inventory_item ii on itg.item_id = ii.inventory_item_id 
                    inner join ws_pallet_item_mapping pim on ii.inventory_item_id = pim.inventory_item_id  
                    inner join ws_product p on ii.product_id = p.product_id and p.status = &#39;OK&#39;
                    left join ws_product_container pc on ii.container_id = pc.container_id
//总起来说关联太多表,设计表时可以多一些冗余字段,减少表之间的关联查询;
                where 
                    ii.inventory_type = &#39;raw_material&#39; and 
                    ii.inventory_status = &#39;in_stock&#39; and 
                    ii.facility_id = &#39;25&#39; and 
                    datediff(now(),ii.last_updated_time) < 3  //违反了第一个原则
                     and p.product_type = &#39;goods&#39;
                     and p.product_name like &#39;%果%&#39;   // 违反原则3

                group by 
                    ii.product_id
                having 
                    qoh < 0.005
                order by 
                    qoh desc
ログイン後にコピー

上記の SQL では、クエリに非常に悪影響を与えるサブクエリを使用しました。

より良い方法は次のステートメントです:

1. from ステートメントではサブクエリを使用しないでください。

2. 検索範囲を制限して狭める場合は、より多くのインデックスを使用します。

ツール SQL Tuning Expert を使用します。 for Oracle は SQL ステートメントを最適化します

SQL 開発者や DBA にとって、ビジネス ニーズに基づいて正しい SQL を作成するのは簡単です。では、SQL の実行パフォーマンスはどうでしょうか?より高速に実行できるように最適化できますか?上級DBAでないと自信がない人も多いのではないでしょうか。

幸いなことに、自動最適化ツールがこの問題の解決に役立ちます。これが今日紹介する Tosska SQL Tuning Expert for Oracle ツールです。 ダウンロード

https://tosska.com/tosska-sql-tuning-expert-tse-oracle-free-download/

このツールの発明者は、Dell の元チーフ エンジニアである Richard To です。 20 年以上の SQL 経験 最適化の経験。

1. データベース接続を作成します。これは後で作成することもできます。接続情報を入力し、「接続」ボタンをクリックします。 Oracle クライアントをインストールし、Oracle クライアント上で TNS を構成している場合は、このウィンドウで「接続モード」として「TNS」を選択し、「データベース エイリアス」でデータベース エイリアスとして構成された TNS を選択できます。


Oracle クライアントをインストールしていない場合、または Oracle クライアントをインストールしたくない場合は、「接続モード」として「基本タイプ」を選択し、データベースサーバーの IP、ポート、サービス名のみが必要です。


2. パフォーマンスに問題がある SQL を入力します。

3. [調整] ボタンをクリックすると、同等の SQL が多数自動的に生成され、実行が開始されます。テストはまだ完了していませんが、SQL 20 のパフォーマンスが 100% 向上していることがすでに確認できます。

SQL データベース ステートメントの最適化分析と最適化手法の概要 (SQL 最適化ツール)

SQL 20 を詳しく見てみましょう。SQL 20 は 2 つのヒントを使用し、最も速い実行速度を実現します。元の SQL には 0.99 秒かかりますが、最適化された SQL の実行時間は 0 秒に近くなります。

この SQL はデータベース内で毎日数万回実行されるため、最適化後はデータベースの実行時間を約 165 秒節約できます。

SQL データベース ステートメントの最適化分析と最適化手法の概要 (SQL 最適化ツール)最後に、アプリケーションのソース コード内のパフォーマンスの問題がある SQL を同等の SQL 20 に置き換えます。アプリケーションを再コンパイルし、パフォーマンスが向上しました。

調整タスクは正常に完了しました。

関連記事: SQL データベース ステートメントの最適化分析と最適化手法の概要 (SQL 最適化ツール)

SQL パフォーマンスの最適化の概要と SQL ステートメントの最適化の記事

SQL ステートメント最適化の原則、SQL ステートメントの最適化

関連ビデオ:

MySQL 最適化ビデオ チュートリアル — ブール教育

以上がSQL データベース ステートメントの最適化分析と最適化手法の概要 (SQL 最適化ツール)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

MySQLの役割:Webアプリケーションのデータベース MySQLの役割:Webアプリケーションのデータベース Apr 17, 2025 am 12:23 AM

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

MySQL対その他のプログラミング言語:比較 MySQL対その他のプログラミング言語:比較 Apr 19, 2025 am 12:22 AM

他のプログラミング言語と比較して、MySQLは主にデータの保存と管理に使用されますが、Python、Java、Cなどの他の言語は論理処理とアプリケーション開発に使用されます。 MySQLは、データ管理のニーズに適した高性能、スケーラビリティ、およびクロスプラットフォームサポートで知られていますが、他の言語は、データ分析、エンタープライズアプリケーション、システムプログラミングなどのそれぞれの分野で利点があります。

初心者向けのMySQL:データベース管理を開始します 初心者向けのMySQL:データベース管理を開始します Apr 18, 2025 am 12:10 AM

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

InnoDBバッファープールとそのパフォーマンスの重要性を説明してください。 InnoDBバッファープールとそのパフォーマンスの重要性を説明してください。 Apr 19, 2025 am 12:24 AM

Innodbbufferpoolは、データをキャッシュしてページをインデックス作成することにより、ディスクI/Oを削減し、データベースのパフォーマンスを改善します。その作業原則には次のものが含まれます。1。データ読み取り:Bufferpoolのデータを読む。 2。データの書き込み:データを変更した後、bufferpoolに書き込み、定期的にディスクに更新します。 3.キャッシュ管理:LRUアルゴリズムを使用して、キャッシュページを管理します。 4.読みメカニズム:隣接するデータページを事前にロードします。 BufferPoolのサイジングと複数のインスタンスを使用することにより、データベースのパフォーマンスを最適化できます。

MySQL:構造化データとリレーショナルデータベース MySQL:構造化データとリレーショナルデータベース Apr 18, 2025 am 12:22 AM

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

MySQLの学習:新しいユーザー向けの段階的なガイド MySQLの学習:新しいユーザー向けの段階的なガイド Apr 19, 2025 am 12:19 AM

MySQLは、データストレージ、管理、分析に適した強力なオープンソースデータベース管理システムであるため、学習する価値があります。 1)MySQLは、SQLを使用してデータを操作するリレーショナルデータベースであり、構造化されたデータ管理に適しています。 2)SQL言語はMySQLと対話するための鍵であり、CRUD操作をサポートします。 3)MySQLの作業原則には、クライアント/サーバーアーキテクチャ、ストレージエンジン、クエリオプティマイザーが含まれます。 4)基本的な使用には、データベースとテーブルの作成が含まれ、高度な使用にはJoinを使用してテーブルの参加が含まれます。 5)一般的なエラーには、構文エラーと許可の問題が含まれ、デバッグスキルには、構文のチェックと説明コマンドの使用が含まれます。 6)パフォーマンスの最適化には、インデックスの使用、SQLステートメントの最適化、およびデータベースの定期的なメンテナンスが含まれます。

MySQL:データストレージに対する初心者向けのアプローチ MySQL:データストレージに対する初心者向けのアプローチ Apr 17, 2025 am 12:21 AM

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

MySQL:初心者が習得するための必須スキル MySQL:初心者が習得するための必須スキル Apr 18, 2025 am 12:24 AM

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

See all articles