再帰クエリを使用してMySQLの階層データを効率的に取得するにはどうすればよいですか?
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 サイトの他の関連記事を参照してください。

ホット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)

ホットトピック









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

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

INNODBのフルテキスト検索機能は非常に強力であり、データベースクエリの効率と大量のテキストデータを処理する能力を大幅に改善できます。 1)INNODBは、倒立インデックスを介してフルテキスト検索を実装し、基本的および高度な検索クエリをサポートします。 2)一致を使用してキーワードを使用して、ブールモードとフレーズ検索を検索、サポートします。 3)最適化方法には、単語セグメンテーションテクノロジーの使用、インデックスの定期的な再構築、およびパフォーマンスと精度を改善するためのキャッシュサイズの調整が含まれます。

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

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

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

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

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