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

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

ただいまの
回答率

91.36%

  • データベース設計

    95questions

    データベース設計はデータベースの論理的や物理的な部分を特定する工程です。

アプリケーション運用中のデータベースってどんな風に変更するものなのでしょうか?

解決済

回答 1

投稿 2017/12/05 01:36

  • 評価
  • クリップ 2
  • VIEW 88

turuwo

score 1

前提・実現したいこと

アプリケーション運用中のデータベースってどんな風に変更するものなのでしょうか?

僕は完全に独学でやっているうえ相談できる友達もいません。

なのでプロのプログラマーってのはこうやってデータベースを変更するもんなんだぜッみたいな方法を教えて欲しく思います。

たぶん僕と同じような悩みを持っている独学プログラマーにも役に立つはず・・・

発生している問題・エラーメッセージ

運用中のアプリケーションのデータベースの構造に変更があった時、というかどのように変更すべきなのかという問題なのですが・・・

はじめはusersテーブルとuser_idみたいな外部キーをもったimagesテーブルがあったとします。

しかし運用中にitemsテーブルが必要になりました。

しかもitemsテーブルも商品画像を掲載したいためimagesテーブルが必要です。

この時僕は2つの方法を思いつきました。

1・新たにitem_idみたいな外部キーを持ったitem_imagesテーブルを作成する。
この場合user_idを持ったuser_imagesテーブルも新たに作成してそこにimagesの
データを移動させたのちimagesテーブルを削除する。

2・items_imagesみたいな中間テーブルを作成する。
この場合users_imagesテーブルを作成してそこにimagesのuser_idのデータを移動してimagesのuser_idカラムを消去する。

試したこと

とりあえず動くからまあいいかと思って安直に1の方法をとっていますが、なんとなく2の方法がプロっぽくてカッコイイような気がします。

でも2の場合userを消してもitemを消してもimageは残り続けてしまうような気がします。
親を殺したら確実に子にも死んでほしいです。

・・・こんな時皆さんは一体どのようにしているのでしょうか?

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

checkベストアンサー

0

そもそも元からある images は、ユーザーに対応する画像ですよね。
一方で items に対応する images は、商品?に対応する画像ですよね。

つまり両者は同じく画像を管理するテーブルではありますが、詳細が異なるはずです。ですから同じ images というテーブルにすること自体が誤りといえます。

ですから普通に考えるなら 1. の方式が正しいと思います。

投稿 2017/12/05 09:52

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/12/05 12:16

    回答ありがとうございます。

    >>つまり両者は同じく画像を管理するテーブルではありますが、詳細が異なるはずです。ですから同じ images というテーブルにすること自体が誤りといえます。

    迷いが晴れました。

    キャンセル

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

ただいまの回答率

91.36%

関連した質問

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

  • データベース設計

    95questions

    データベース設計はデータベースの論理的や物理的な部分を特定する工程です。