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

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

ただいまの
回答率

90.50%

  • MongoDB

    250questions

    MongoDBはオープンソースのドキュメント指向データベースの1つです。高性能で、多くのリトルエンディアンシステムを利用することができます。

  • NoSQL

    61questions

    NoSQL(not only SQL)は、リレーショナルデータベース管理システムとは異なるデータベースシステムを指す言葉です。

  • データ構造

    48questions

    データ構造とは、データの集まりをコンピュータの中で効果的に扱うために、一定の形式に系統立てて格納する形式を指します。(配列/連想配列/木構造など)

MongoDBでのデータ設計(コードの扱い)について

解決済

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 336

TakahiRoyte

score 20

NoSQL (MongoDB) でのデータ設計について悩んでいます。

例えば書類申請データがあり、1つの申請に対して「申請中」「承認」「否認」のいずれかのステータスが設定されるとします。

RDBの場合は、以下のように正規化をするとします。

申請ID 申請者 ステータスID
1 佐藤 0
2 佐藤 1
3 山田 9
ステータスID ステータス名
0 申請中
1 承認
9 否認

この場合JOINをしてステータス名を取得し1つのデータとしてまとめると思います。

これがMongoDBなどのドキュメント指向データベースになった場合は、ステータスをどう持つのが良い設計なのでしょうか。アプリケーションによりけりとしか言えないというような気もしますが……

  • ステータスIDとステータス名を持つ場合
{
  "application_id": 1,
  "applicant_name": "佐藤",
  "status_id": 0,
  "status": "申請中"
}
  • ステータスをオブジェクトとして持つ
{
  "application_id": 1,
  "applicant_name": "佐藤",
  "status": {
    "id": 0,
    "name": "申請中"
  }
}
  • ステータス名のみ
{
  "application_id": 1,
  "applicant_name": "佐藤",
  "status": "申請中"
}

あまり、ステータスIDというフィールドをNoSQLにおいて持つことにメリットを見い出せません。処理中の分岐とかで使うくらいでしょうか。それすらもステータス名でやってしまえば良いような気がしています。

ステータス名をあとから変えたいケースも考えられますがNoSQLであれば保存されているデータもすべて上書きする必要はどうしてもでてくると思うので、これもメリットとしては薄く見えます。

以上よろしくお願いいたします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+1

あまり詳しくないですが、今までの経験で話しますと。

MongoDBはドキュメントストア型ですから
行をドキュメントと置き換える(ドキュメント内にドキュメントを埋め込める)ことで
スパース(疎データ)に対処できるようになっていますが、
インデックスを明示的に設定する必要がありますし、インデックスの個数にも制限があります。
#ただしパフォーマンスを考えると、できるだけインデックスは少ないほうが良いので問題にはならない

またその機構上、結合に制約があったり、全文検索に弱いなどという欠点もあります。

仰られるとおり、リレーショナルDBとは違いますので、
ステータスIDとステータス名を持つ場合は、両方持たせる名称のみ持たせるかになります。
どちらを取るかは、アプリケーション側で簡単に利用しやすい方を選べば良いと思います。
今のところ他のやり方は、見たことがありませんね。

■FYI
MongoDBにおけるスキーマ
MongoDBのスキーマデザインする時の3つのポイント
MongoDBにおける関連(Relation)のスキーマ設計

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/04/18 16:55

    ありがとうございます。
    経験者の方から後押しいただけて安心できました。
    参考リンクも非常に勉強になりました。

    キャンセル

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

  • ただいまの回答率 90.50%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

  • 受付中

    pymongoのfind()メソッドについて

    pymongoのfind()でデータを取得するとinsertしたfieldの順番が変わってしまいますが、insertした順番でデータを取得する方法が知りたい… 例) 1.O

  • 解決済

    service mongod --dbpath /[PATH]/ で起動できない

    MongoDBについて質問です。 起動するとき、dbpathを指定したうえで起動しっぱなしにしてやりたいのですが、 service mongod --dbpath /[PA

  • 解決済

    MongoDBのエラー ERR TypeError: Cannot read property 'c...

    mongodbをローカルやクラウド上にディプロイする際に時たまエラーが起こり、ログにでてくるのが以下のものなのですが、MongoDBが下記のようなエラーを吐き出しやすい理由などある

  • 受付中

    mongodb 置換方法

    質問 このMysqlの記事ようにmongodbにおいて、documentの値を置換するsqlはあるのでしょうか。 mysqlではreplace関数を用いて、レコード値の特定の文字列

  • 解決済

    node mongo.jsでthrow err;が出る

    お世話になります DotinstallでNode.jsを勉強中です 15章 https://dotinstall.com/lessons/basic_nodejs/26215の部分

  • 解決済

    mongoDBでcountしたい

    mongodb version v3.6.1 こういうしょうもない設計のレコードが50万件くらいあります。 { "_id" : ObjectId("5a51d36b

  • 解決済

    HTMLからのPOSTメソッドについて

    大至急お願いしたいです https://qiita.com/itagakishintaro/items/a1519998a91061cbfb1e#mongodb%E6%93%8

  • 解決済

    mongodbのネストした配列から特定の値を持つものだけ削除

     前提・実現したいこと mongodbで、ネストした配列のなかから、特定の値を持つものを削除したいです。  発生している問題・エラーメッセージ mongodbで以下のようなデー

同じタグがついた質問を見る

  • MongoDB

    250questions

    MongoDBはオープンソースのドキュメント指向データベースの1つです。高性能で、多くのリトルエンディアンシステムを利用することができます。

  • NoSQL

    61questions

    NoSQL(not only SQL)は、リレーショナルデータベース管理システムとは異なるデータベースシステムを指す言葉です。

  • データ構造

    48questions

    データ構造とは、データの集まりをコンピュータの中で効果的に扱うために、一定の形式に系統立てて格納する形式を指します。(配列/連想配列/木構造など)