MySQL 再帰クエリ: 階層データの効率的な処理
背景:
ファイル システムや組織図などの多くの階層データ構造では、親子関係に基づいてデータを取得する効率的な方法が必要です。 MySQL には、これらの構造を効率的に走査する再帰的クエリを作成する方法がいくつか用意されています。
MySQL 8 再帰構文ソリューション
MySQL 8 では、再帰的 WITH 構文が導入され、再帰的クエリが大幅に簡素化されています。
WITH RECURSIVE cte (id, name, parent_id) AS ( SELECT id, name, parent_id FROM products WHERE parent_id = 19 UNION ALL SELECT p.id, p.name, p.parent_id FROM products p JOIN cte ON p.parent_id = cte.id ) SELECT * FROM cte;
parent_id = 19
内の値を、子を取得する親ノードの ID に置き換えるだけです。
MySQL 5.x パス ID ソリューション
MySQL 8 より前では、再帰クエリには他のメソッドが必要でした。 1 つのアプローチは、ID 列に階層情報を埋め込んでパス ID を割り当てることです。
たとえば、パス ID を含むテーブルは次のようになります:
ID | NAME |
---|---|
19 | category1 |
19/1 | category2 |
19/1/1 | category3 |
19/1/1/1 | category4 |
ここで、次のクエリは category1 のすべての子ノードを取得します:
SELECT * FROM products WHERE id LIKE '19%'
MySQL 5.x インライン変数と自己結合ソリューション
MySQL 5.x のもう 1 つのオプションは、インライン変数、パス ID、または自己結合を使用して再帰的クエリを作成することです。以下はインライン変数の使用例です:
SELECT id, name, parent_id FROM (SELECT * FROM products ORDER BY parent_id, id) products_sorted, (SELECT @pv := '19') initialisation WHERE FIND_IN_SET(parent_id, @pv) AND LENGTH(@pv := CONCAT(@pv, ',', id))
@pv := '19'
の値を、子ノードを取得する親ノードの ID に設定します。
概要
MySQL には、階層データを処理する再帰クエリを作成する方法がいくつか用意されています。どの方法を選択するかは、使用している MySQL のバージョンとクエリの特定の要件によって異なります。
以上が再帰クエリを使用してMySQLの階層データを効率的に取得するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、MySQLのAlter Tableステートメントを使用して、列の追加/ドロップ、テーブル/列の名前の変更、列データ型の変更など、テーブルを変更することについて説明します。

記事では、証明書の生成と検証を含むMySQL用のSSL/TLS暗号化の構成について説明します。主な問題は、セルフ署名証明書のセキュリティへの影響を使用することです。[文字カウント:159]

記事では、MySQLで大規模なデータセットを処理するための戦略について説明します。これには、パーティション化、シャード、インデックス作成、クエリ最適化などがあります。

記事では、MySQLワークベンチやPHPMyAdminなどの人気のあるMySQL GUIツールについて説明し、初心者と上級ユーザーの機能と適合性を比較します。[159文字]

この記事では、ドロップテーブルステートメントを使用してMySQLのドロップテーブルについて説明し、予防策とリスクを強調しています。これは、バックアップなしでアクションが不可逆的であることを強調し、回復方法と潜在的な生産環境の危険を詳述しています。

記事では、外部キーを使用してデータベース内の関係を表すことで、ベストプラクティス、データの完全性、および避けるべき一般的な落とし穴に焦点を当てています。

この記事では、クエリパフォーマンスを強化するために、PostgreSQL、MySQL、MongoDBなどのさまざまなデータベースでJSON列にインデックスの作成について説明します。特定のJSONパスのインデックス作成の構文と利点を説明し、サポートされているデータベースシステムをリストします。

記事では、準備されたステートメント、入力検証、および強力なパスワードポリシーを使用して、SQLインジェクションおよびブルートフォース攻撃に対するMySQLの保護について説明します。(159文字)


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

WebStorm Mac版
便利なJavaScript開発ツール

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

ホットトピック



