質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Q&A

解決済

1回答

2113閲覧

DB設計をしていますが、アドバイスをお願いします

yuki84web

総合スコア1857

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

0グッド

1クリップ

投稿2017/02/26 07:56

DB設計をしていますが、なにぶん経験が浅いもので、宜しければアドバイスをお願いいたします。

要件:
ユーザーを管理するユーザーマスタと、アップロードされたファイルを管理するファイル管理テーブルがある。
各ファイルに対してアクセス権をユーザーIDで紐づけて管理する。

上記要件について、
ファイル管理テーブルにアクセス許可ユーザーIDフィールドを作成し、
カンマ区切り等で管理する方法を考えましたが、
中間テーブルを作成して管理する方が望ましいでしょうか?

[ユーザーマスタ]
ユーザーID(PK)
名前
メールアドレス
[ファイル管理テーブル]
ファイル管理ID(PK)
アップロードユーザーID(FK)
アクセス許可ユーザーID(FK)

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

中間テーブルを作成して管理する方が望ましいでしょうか?

はい。
簡単に思いつく理由は以下の通りです。

  • ユーザーがアクセスできるファイルへのCRUDがしづらい(逆も)
  • アクセス許可ユーザーIDの登録数は列の長さに制限される
  • 区切り文字をアプリ側で強制的に統一する必要がある

投稿2017/02/26 08:20

xenbeat

総合スコア4258

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yuki84web

2017/02/26 08:46

ありがとうございます。 中間テーブルは、名称は仮に"ファイル権限ユーザーテーブル"とし、 テーブルの管理ID(PK)・ユーザーID(FK)・ファイル管理ID(FK)・権限(boolean)とするか そもそも権限フィールドは作らずレコードの存在有無でのみ判別する、どちらが良いでしょうか。
xenbeat

2017/02/26 08:58

単純にファイルにアクセスできるできないを管理したいのであれば、権限(boolean)は定義せずにレコードの存在有無で良いと思います。 要件として、読み取り権限や書き込み権限等、詳細にファイルへの権限を管理したいのであれば、読み取り権限(boolean)、書き込み権限(boolean)等を定義するのが良いと思います。
yuki84web

2017/02/26 09:19

今のところ、アクセスできるできないのみを管理する仕様ですので前者を選択しようと思います。 とても分かりやすい回答ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問