インターネットの発展に伴い、Web サイトのコンテンツはますます複雑になり、Web ページ内のさまざまなデータの分類もますます複雑になってきました。無制限の分類は、商品を分類する非常に一般的な方法であり、さまざまなビジネス シナリオにおける複雑な分類問題に対処できます。この記事ではNodejsを使って無制限の分類機能を実装する方法を紹介します。
1. 前提条件の知識ポイント
無限分類を実現する方法を学ぶ前に、次の前提条件の知識ポイントを理解する必要があります:
Mysql データベースは、オープンソースのリレーショナル データベース管理システムです。無制限の分類では、データベースを使用して分類データを保存する必要があります。
Express Framework は、Nodejs プラットフォームに基づいて迅速に開発された Web アプリケーション フレームワークです。ルーティング、ミドルウェア、テンプレート エンジンなどのいくつかの強力な機能を提供し、Web アプリケーションの開発をより簡単かつ迅速にします。
データベースを操作するには、クエリ、挿入、変更、削除などの基本的な SQL ステートメントをマスターする必要があります。
2. 無限分類の定義
無限分類とは、商品データを階層関係に従って分割する分類方法です。たとえば、電子商取引では、製品が衣料品などの大きなカテゴリに属する場合があり、この衣料品の大きなカテゴリ内には、トップス、パンツ、スカートなどの小さなカテゴリが多数あり、これらの小さなカテゴリはカテゴリにはさらに詳細なカテゴリがあり、ポイントの内容が表示されます。
したがって、無限分類の重要な特徴は、カテゴリ間に階層関係があることです。つまり、各カテゴリにはサブカテゴリが含まれる可能性があり、各サブカテゴリは独自のサブカテゴリを持つことができます。関係は分類の最下位レベルまで拡張され続ける可能性があります。
さらに、無制限の分類の重要な特徴は、分類の数が不確実であることです。既存の分類の階層構造を大幅に調整することなく、いつでも分類を追加または削除できます。
3. データベース構造の設計
無制限の分類機能を実現する前に、分類に必要なデータストレージに合わせて適切なデータベース構造を設計する必要があります。分類情報を保存するテーブルをデータベースに作成する必要があります。このテーブルには次のフィールドが含まれる必要があります:
このフィールドは、分類情報の一意の識別子です。自己増加する整数型を使用して作成できます。
このフィールドはカテゴリの名前です。varchar 型は、文字列型のデータを格納するために使用できます。
このフィールドは、現在のカテゴリの親カテゴリ ID を保存するために使用されます。現在のカテゴリが第 1 レベルのカテゴリの場合、parent_id は 0 です。
4. 無制限のカテゴリの API インターフェイスを作成する
データベース構造を作成した後、Nodejs Express フレームワークを使用して、無制限のカテゴリの API インターフェイスを作成する必要があります。次のインターフェイスを実装する必要があります。
このインターフェイスはすべてのカテゴリのクエリに使用され、返された結果は階層に従って並べ替える必要があります。カテゴリの関係。実装プロセスは次のとおりです。
① データベースの接続プールまたは接続操作を使用してデータベースに接続します。
② SQL ステートメントを使用して、すべての機密データをクエリします。 SQL ステートメントは次のとおりです。
SELECT * FROM `category` ORDER BY parent_id, id;
この SQL ステートメントは、parent_id と id に従ってすべてのカテゴリを並べ替えます。
③ クエリ結果をフロントエンド表示ページに返します。
このインターフェイスは、カテゴリ名、ID、親カテゴリ ID などを含む単一カテゴリの情報をクエリするために使用されます。実装プロセスは次のとおりです。
① フロントエンドから渡されたカテゴリ ID を取得します。
② SQL ステートメントを使用して、指定されたカテゴリの情報をクエリします。 SQL ステートメントは次のとおりです。
SELECT * FROM `category` WHERE `id` = ?;
この SQL ステートメントは、指定された ID の分類をクエリするために使用されます。
③ クエリ結果をフロントエンド表示ページに返します。
このインターフェイスは、新しいカテゴリを追加するために使用されます。実装プロセスは次のとおりです。
① フロントエンドによって渡された分類情報 (分類名と親分類 ID を含む) を取得します。
② SQL ステートメントを使用して、新しい機密データを挿入します。 SQL ステートメントは次のとおりです。
INSERT INTO `category` (`name`, `parent_id`) VALUES (?, ?);
この SQL ステートメントは、新しい分類されたデータをデータベースに挿入するために使用されます。
③ 挿入結果をフロントエンド表示ページに返します。
このインターフェースは、指定されたカテゴリの情報を編集するために使用されます。実装プロセスは次のとおりです。
① フロントエンドから渡された分類名と分類 ID を含む分類情報を取得します。
② SQL ステートメントを使用して、指定されたカテゴリのデータを更新します。 SQL ステートメントは次のとおりです。
UPDATE `category` SET `name` = ? WHERE `id` = ?;
この SQL ステートメントは、指定された ID でカテゴリの名前を更新するために使用されます。
③ 更新結果をフロントエンド表示ページに返します。
このインターフェイスは、指定されたカテゴリを削除するために使用されます。実装プロセスは次のとおりです。
① フロントエンドから渡されたカテゴリ ID を取得します。
② SQL文を使用して、指定したIDのカテゴリを削除します。 SQL ステートメントは次のとおりです。
DELETE FROM `category` WHERE `id` = ?;
この SQL ステートメントは、指定された ID を持つカテゴリを削除するために使用されます。
③ 削除結果をフロントエンド表示ページに返します。
5. 無制限の分類の実装
上記のインターフェイスを作成することで、分類されたデータに対する基本的な操作を実装することができました。ただし、Nodejs で無限分類のコア ロジックを実装する必要もあります。
実装プロセスは次のとおりです。
① SQL ステートメントを使用して、すべての機密データをクエリします。
② クエリ結果を処理し、階層関係に従ってすべてのカテゴリを並べ替えます。
③ 再帰関数を使用してカテゴリ データを走査し、各カテゴリのサブカテゴリをその属性として保存します。
④ 処理した分類データをフロントエンド表示ページに返します。
無限分類を実現するプロセスでは、再帰関数を使用する必要があります。カテゴリ間には親子関係があり、各カテゴリにはサブカテゴリがあり、各サブカテゴリには独自のサブカテゴリが存在する可能性があるためです。 -カテゴリー。再帰関数はすべてのカテゴリを反復処理し、各カテゴリのサブカテゴリをその属性として保存できるため、カテゴリの数は無制限になります。
6. 概要
この記事の導入部を通じて、Nodejs と Express フレームワークを使用して無制限の分類機能を実現する方法を学びました。習得する必要がある知識ポイントには、Mysql データベース、Express フレームワーク、手書き SQL ステートメント、API インターフェイス設計などが含まれます。さらに、この記事では、再帰関数を使用して無限分類ロジックを実装する方法についても説明します。この記事があなたのお役に立ち、無限分類を実現する技術にさらに習熟できることを願っています。
以上がNodejsは無制限の分類を実現しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。