mysql - Thinkphp の RBAC 認証では、「user-role」テーブルに独立したテーブルが必要なのはなぜですか? ?
ここで 5 つの表を参照できます: http://www.lyblog.net/detail/...
実際にはテーブルがあります:
ユーザーとロールの間には 1 対 1 の対応関係があります。別のテーブルを作成する代わりに、ロール フィールドをユーザー テーブルに追加するだけではどうでしょうか。
これを行うメリットは何ですか?
補足:
ユーザーとロールの関係は 1 対多であると言う人がいますが、なぜ 1 対多に設定する必要があるのか知りたいです。
1対1の関係のほうがやりやすいんじゃないでしょうか?
返信内容:
ここで 5 つの表を参照できます: http://www.lyblog.net/detail/...
実際にはテーブルがあります:
ユーザーとロールの間には 1 対 1 の対応関係があります。別のテーブルを作成する代わりに、ロール フィールドをユーザー テーブルに追加するだけではどうでしょうか。
これを行うメリットは何ですか?
補足:
ユーザーとロールの関係は 1 対多であると言う人がいますが、なぜ 1 対多に設定する必要があるのか知りたいです。
1対1の関係のほうがやりやすいんじゃないでしょうか?
私の理解では、ユーザーは複数の役割を持つことができるということです
こんな感じです:
1 人が複数のロールを持つことができます
1 つのロールを複数の人が使用することもできます
多対多のリレーションシップでは、通常、マッピング用に中間テーブルを構築する必要があります。
redis のような非リレーショナル データベースを使用している場合を除く
1対多ではなく、多対多です。
あなたのプロジェクトには必要ないかもしれませんが、フレームワークとしては、より広範なニーズを考慮する必要があります。多対多テーブルは 1 対 1 テーブルとして使用できます。 many には 1 対 1 が含まれますが、1 対 1 1 対 1 の設計では、必然的に多対多のニーズを満たすことができなくなります。ここに別の関係テーブルが存在することになりますね?
ユーザーには複数の役割があります。
実際には、別のテーブルを作成しないことも可能です。
デカップリング、単一責任モデル
ManytoMany の関係には中間テーブルが必要です。
多対多のニーズを満たすため
私の理解は正確ではないかもしれません。たとえば、いくつかのロール a、b、c が存在します。あなたの理解によれば、ユーザー 1、2、3 が a に対応できます。 、b、cはそれぞれ大丈夫です。別のユーザー 4 が来た場合、そのユーザーが必要とするロールはたまたまロール a とロール b の権限を持っているため、ユーザー 4 は直接ロール a とロール b に属します。ユーザー 4 のニーズを満たすために新しいロールを作成する必要はありません

まだ人気があるのは、使いやすさ、柔軟性、強力なエコシステムです。 1)使いやすさとシンプルな構文により、初心者にとって最初の選択肢になります。 2)Web開発、HTTP要求とデータベースとの優れた相互作用と密接に統合されています。 3)巨大なエコシステムは、豊富なツールとライブラリを提供します。 4)アクティブなコミュニティとオープンソースの性質は、それらを新しいニーズとテクノロジーの傾向に適応させます。

PHPとPythonはどちらも、Web開発、データ処理、自動化タスクで広く使用されている高レベルのプログラミング言語です。 1.PHPは、ダイナミックウェブサイトとコンテンツ管理システムの構築によく使用されますが、PythonはWebフレームワークとデータサイエンスの構築に使用されることがよくあります。 2.PHPはエコーを使用してコンテンツを出力し、Pythonは印刷を使用します。 3.両方ともオブジェクト指向プログラミングをサポートしますが、構文とキーワードは異なります。 4。PHPは弱いタイプの変換をサポートしますが、Pythonはより厳しくなります。 5. PHPパフォーマンスの最適化には、Opcacheおよび非同期プログラミングの使用が含まれますが、PythonはCprofileおよび非同期プログラミングを使用します。

PHPは主に手順プログラミングですが、オブジェクト指向プログラミング(OOP)もサポートしています。 Pythonは、OOP、機能、手続き上のプログラミングなど、さまざまなパラダイムをサポートしています。 PHPはWeb開発に適しており、Pythonはデータ分析や機械学習などのさまざまなアプリケーションに適しています。

PHPは1994年に発信され、Rasmuslerdorfによって開発されました。もともとはウェブサイトの訪問者を追跡するために使用され、サーバー側のスクリプト言語に徐々に進化し、Web開発で広く使用されていました。 Pythonは、1980年代後半にGuidovan Rossumによって開発され、1991年に最初にリリースされました。コードの読みやすさとシンプルさを強調し、科学的コンピューティング、データ分析、その他の分野に適しています。

PHPはWeb開発と迅速なプロトタイピングに適しており、Pythonはデータサイエンスと機械学習に適しています。 1.PHPは、単純な構文と迅速な開発に適した動的なWeb開発に使用されます。 2。Pythonには簡潔な構文があり、複数のフィールドに適しており、強力なライブラリエコシステムがあります。

PHPは、多数のWebサイトとアプリケーションをサポートし、フレームワークを通じて開発ニーズに適応するため、近代化プロセスで依然として重要です。 1.PHP7はパフォーマンスを向上させ、新機能を紹介します。 2。Laravel、Symfony、Codeigniterなどの最新のフレームワークは、開発を簡素化し、コードの品質を向上させます。 3.パフォーマンスの最適化とベストプラクティスは、アプリケーションの効率をさらに改善します。

phphassiblasifly-impactedwebdevevermentandsbeyondit.1)itpowersmajorplatformslikewordpratsandexcelsindatabase interactions.2)php'sadaptableability allowsitale forlargeapplicationsusingframeworkslikelavel.3)

PHPタイプは、コードの品質と読みやすさを向上させるためのプロンプトがあります。 1)スカラータイプのヒント:php7.0であるため、基本データ型は、int、floatなどの関数パラメーターで指定できます。 3)ユニオンタイプのプロンプト:PHP8.0であるため、関数パラメーターまたは戻り値で複数のタイプを指定することができます。 4)Nullable Typeプロンプト:null値を含めることができ、null値を返す可能性のある機能を処理できます。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境
