Mysqlは隣接リスト(隣接リスト)を通じてツリー構造を保存します。

Mysqlは隣接リスト(隣接リスト)を通じてツリー構造を保存します。

以下の内容では、隣接リストを使用してツリー構造を保存する MYSQL のプロセスとソリューションを紹介し、保存された図を分析します。

今日は、もっと厄介な問題、つまりツリー構造をデータベースに保存する方法を見てみましょう。

MySQL のようなリレーショナル データベースは、テーブルのようなフラットなデータを保存するのに適していますが、ツリー構造のような深いデータに遭遇すると制御が難しくなります。

たとえば、会社の人員構成を保存する必要があります。一般的な階層構造は次のとおりです。

(絵を描くのは簡単ではありません。)

では、この構造をどのように保存するのでしょうか?そして、次の情報を取得します。

1. Xiaotian の直属の上司が誰であるかを調べます。

2. Lao Song の管理下にある直接従業員を確認します。

3. Xiaotianの上司全員を確認します。

4. Lao Wang によって管理されているすべての従業員を照会します。

解決策 1: (隣接リスト) は、現在のノードの親ノード情報のみを保存します。

従業員テーブルを作成する(
イードイント、
名前VARCHAR(100)、
位置 VARCHAR(100)、
親ID int

記録された情報は単純で粗いので、次の構造情報を保存します。

さて、それでは答えの部分に入りましょう。

1. Xiaotian の直属の上司に問い合わせる:

e2.eid、e2.ename を employees e1、employees e2 から選択します。ここで、e1.parent_id=e2.eid AND e1.ename='小天';

2. Lao Song の管理下にある直接従業員に問い合わせます。

e1.eid、e1.ename を employees e1、employees e2 から選択します。ここで、e1.parent_id=e2.eid AND e2.ename='老宋';

3. Xiaotianの上司全員を確認します。

ここで直接チェックする方法は絶対にありません。ループを使用してループ内でクエリを実行することしかできません。最初に直属の上司をチェックし、次に直属の上司の直属の上司をチェックする、というように繰り返します。このような面倒なことのために、まずストアド プロシージャを作成する必要があります。

目を開けてよく見てください。次のステップはショー操作です。

CREATE DEFINER=`root`@`localhost` FUNCTION `getSuperiors`(`uid` int) 戻り値 varchar(1000) CHARSET gb2312
始める
  上司をVARCHAR(1000) DEFAULTとして宣言します '';
  sTemp INTEGER DEFAULT uid を宣言します。
  tmpName VARCHAR(20) を宣言します。
  (sTemp>0)の間、
    SELECT parent_id into sTemp FROM employees where eid = sTemp;
    eid = sTemp の場合、従業員から ename を tmpName に選択します。
    IF(sTemp>0)の場合
      SET 上司 = concat(tmpName,',',上司);
    終了の場合;
  終了しながら;
    SET 上司 = LEFT(上司,CHARACTER_LENGTH(上司)-1);
  上司に返す。
終わり

このストアド プロシージャは、子ノードのすべての親ノードをクエリできます。試してみましょう。

はい、操作は完了しました。

どうやらこれ。子ノードの親ノードをすべて取得するのは面倒です。 。

4. Lao Wang によって管理されているすべての従業員を照会します。

考え方は次のとおりです。まず、親ノードが Lao Wang の ID であるすべての従業員の従業員 ID を取得し、次に従業員の名前を結果リストに追加し、マジカル検索関数を呼び出してマジカル検索を実行します。

CREATE DEFINER=`root`@`localhost` FUNCTION `getSubordinate`(`uid` int) 戻り値 varchar(2000) CHARSET gb2312
始める
str varchar(1000) を宣言します。
cid varchar(100) を宣言します。
結果をVARCHAR(1000)として宣言します。
tmpName VARCHAR(100) を宣言します。
str = '$' を設定します。
SET cid = CAST(uid as char(10));
cidがnullでない場合に実行
SET str = concat(str, ',', cid);
SELECT group_concat(eid) INTO cid FROM employees where FIND_IN_SET(parent_id,cid);
終了しながら;
SELECT GROUP_CONCAT(ename) INTO result FROM employees WHERE FIND_IN_SET(parent_id,str);
結果を返します。
終わり

驚くべき結果をご覧ください:

私はそれを理解しましたが、正直に言うと、それは簡単ではありませんでした。 。 。

この方法の利点は、保存する情報が少なく、直属の上司と直属の部下を確認するのに非常に便利なことです。欠点は、複数レベルのクエリを実行するのが非常に難しいことです。したがって、直接の上司と部下の関係のみを使用する必要がある場合、この方法は依然として適切な選択であり、多くのスペースを節約できます。その他のストレージソリューションについては後ほど紹介します。良いものと悪いものの絶対的な区別はなく、単にさまざまな状況に適しているだけです。

以下もご興味があるかもしれません:
  • MySQL ツリー構造データベース テーブル設計

<<:  Linux でユーザーをグループに追加する 4 つの方法の概要

>>:  Vue が価格カレンダー効果を実現

推薦する

Vueはダイアログのカプセル化を実装します

目次Vue2 ライティングVue3プラグインのバージョンの記述Vue3 動的コンポーネントの記述書き...

HTMLがHikvisionカメラのリアルタイム監視機能を実現

最近、同社は CCFA 関連のいくつかの作業を行う予定で、その 1 つはカメラのリアルタイム監視を再...

Linux 7.6 バイナリに MySQL 8.0.27 をインストールする詳細な手順

目次1. 環境整備1.1 オペレーティング システムのバージョン1.2 ディスク容量1.3 ファイア...

Windows 10 に MySQL 8.0.19 を zip 形式でインストールする詳細なチュートリアル

目次1.ダウンロード後、インストールしたいディレクトリに解凍します。 2. インストールディレクトリ...

JS で async await をエレガントに使用する方法

目次jQuery の $.ajax Webpack時代の始まり約束について深く考えるネストをなくすj...

Mysql+JavaSwing に基づくスーパーマーケット商品管理システムの設計と実装

目次1. 機能紹介2. キーコード2.1 ホームページの機能2.2 製品情報を追加する2.3 データ...

Vue+element はローカル検索機能付きのドロップダウン メニューを実装します

必要:バックエンドは配列オブジェクトを返し、それがフロントエンドで配列に結合されます。配列は名前に従...

Vueは移動可能なフローティングボタンを実装します

この記事の例では、どこにでも移動できるフローティングボタンを実現するためのVueの具体的なコードを共...

Vue 監視プロパティと計算プロパティ

目次1. 監視プロパティを監視する1. ショッピングカート2. すべて選択し、すべて選択解除する2....

Nginx の書き換え正規マッチング書き換え方法の例

Nginx の書き換え機能は、リダイレクトと同様に、URL アドレスを一時的または永続的に新しい場所...

Vue は URL に基づいて非同一オリジンのファイルをどのようにダウンロードするのか

一般的に、URL に基づいてファイルをダウンロードする場合、次の 2 つの解決策があります。 1. ...

MySQL 5.7.22 バイナリパッケージのインストールとインストール不要版 Windows 設定方法

次のコードは、MySQL 5.7.22 バイナリ パッケージのインストール方法を紹介しています。具体...

Nodeはkoa2を使用してシンプルなJWT認証方式を実装します

JWT の紹介JWTとは正式名称はJSON Web Tokenで、現在最も人気のあるクロスドメイン認...

CSSは座席選択効果を実現するためにautoflow属性を使用する

1. 自動フロー属性、要素コンテンツの長さと幅が要素自体の長さと幅を超える場合、スクロールバーが表示...

シンプルな虫眼鏡効果を実現するJavaScript

大きな箱の中に写真があります。マウスをその上に置くと、半透明のマスク レイヤーが表示されます。マウス...