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

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

新規登録して質問してみよう
ただいま回答率
85.50%
Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Q&A

解決済

1回答

11248閲覧

ECサイトのテーブル設計について

takeroyasuhara

総合スコア15

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

0グッド

1クリップ

投稿2015/09/04 11:46

  • Railsを学習するためにECサイトを制作しています
  • カート機能を持ったECサイトを想定しているのですが、カート内の仕様を想定したときにどういったテーブル設計にすべきかわからないポイントが一点あったのでご質問しました
  • カート内の未購入商品の商品情報が変更されたときに、ユーザにその変更を通知するような仕様を考えているのですが、その仕様を実現できるテーブル設計のあり方がわかりません
  • 以下のテーブル設計・モデル設計にどういった変更を加えるべきかアドバイスをいただけないでしょうか?

<制約条件>

usersテーブル
  • プライマリーキー:id
  • その他制約
    • ユーザ名(フィールド名:name, 型:string):30文字まで、null値許可しない
    • メールアドレス(フィールド名:email, 型:string):30文字まで、null値許可しない
addressesテーブル
  • プライマリーキー:id
  • その他制約
    • 住所(フィールド名:address, 型:string):100文字まで、null値許可しない
productsテーブル
  • プライマリーキー:id
  • ユニークキー:title,descriotionの組み合わせが一意
  • その他制約
    • 商品名(フィールド名:title, 型:string):20文字まで、null値許可しない
    • 商品詳述(フィールド名:description, 型:text):500文字まで、null値許可しない
    • 商品画像URL(フィールド名:image_url, 型:string):null値許可しない
    • 価格(フィールド名:price, 型:intger):null値許可しない
    • 在庫数(フィールド名:stock_quantity, 型:intger):null値許可しない
cart_itemsテーブル
  • プライマリーキー:id
  • ユニークキー:user_id,product_idの組み合わせが一意
  • 外部キー:user_idはusersテーブルの外部キーとなり、product_idはproductsテーブルの外部キーとなる
  • その他制約
    • ユーザID(フィールド名:user_id, 型:intger):null値許可しない
    • 商品ID(フィールド名:product_id, 型:intger):null値許可しない
    • 購入希望数(フィールド名:quantity, 型:intger):null値許可しない
order_itemsテーブル
  • プライマリーキー:id
  • ユニークキー:user_id,product_id,order_idの組み合わせが一意
  • 外部キー:user_idはusersテーブルの外部キーとなり、product_idはproductsテーブルの外部キーとなり、order_idはordersテーブルの外部キーとなる
  • その他制約
    • ユーザID(フィールド名:user_id, 型:intger):null値許可しない
    • 商品ID(フィールド名:product_id, 型:intger):null値許可しない
    • 注文ID(フィールド名:order_id, 型:intger):null値許可しない
    • 価格(フィールド名:price, 型:intger):null値許可しない
    • 購入数(フィールド名:quantity, 型:intger):null値許可しない
ordersテーブル
  • プライマリーキー:id
  • その他制約
    • 送付先住所(フィールド名:address, 型:string):null値許可しない

<スクリプト>

Ruby

1 class CreateUsers < ActiveRecord::Migration 2 create_table :users do |t| 3 t.string :name, limit: 30, null: false 4 t.string :email, limit: 30, null: false 5 6 t.timestamps null: false 7 end 8 end 9 10 class CreateAddresses < ActiveRecord::Migration 11 create_table :addresses do |t| 12 t.string :address, limit: 100, null: false 13 14 t.timestamps null: false 15 end 16 end 17 18 class CreateProducts < ActiveRecord::Migration 19 create_table :products do |t| 20 t.string :title, limit: 20, null: false 21 t.text :description, limit: 500, null: false 22 t.string :image_url, null: false 23 t.integer :price, null: false 24 t.integer :stock_quantity, null: false 25 26 t.timestamps null: false 27 end 28 t.index[title, descriotion], unique: true 29 end 30 31 class CreateCartItems < ActiveRecord::Migration 32 create_table :cart_items do |t| 33 t.belongs_to :user, null: false 34 t.belongs_to :product, null: false 35 t.integer :quantity, null: false 36 37 t.timestamps null: false 38 end 39 t.index[user_id, product_id], unique: true 40 end 41 42 class CreateOrders < ActiveRecord::Migration 43 create_table :cart_items do |t| 44 t.belongs_to :user, null: false 45 t.belongs_to :product, null: false 46 t.belongs_to :order, null: false 47 t.integer :price, null: false 48 t.integer :quantity, null: false 49 50 t.timestamps null: false 51 end 52 t.index[user_id, product_id, order_id], unique: true 53 end 54 55 class CreateOrders < ActiveRecord::Migration 56 create_table :assignments do |t| 57 t.string :address, null: false 58 59 t.timestamps null: false 60 end 61 end 62 63 64 class User < ActiveRecord::Base 65 has_many :addresses 66 has_many :cart_items 67 has_many :purchasing_products, class_name: "Product", through: :cart_items 68 has_many :order_items 69 has_many :purchased_products, class_name: "Product", through: :order_items 70 end 71 72 class Address < ActiveRecord::Base 73 belongs_to :user 74 end 75 76 class Product < ActiveRecord::Base 77 has_many :cart_items 78 has_many :purchasing_users, class_name: "User",through: :cart_items 79 has_many :order_items 80 has_many :purchased_users, class_name: "User",through: :order_items 81 end 82 83 class CartItem < ActiveRecord::Base 84 belongs_to :user 85 belongs_to :product 86 belongs_to :order 87 end 88 89 class Order < ActiveRecord::Base 90 has_many :order_items 91 end

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

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

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

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

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

guest

回答1

0

ベストアンサー

カートに投入した時刻をもっておいて、商品情報にも更新日時をもっておいて、
カートに投入時刻より新しい更新がある商品が入っていたら通知とか、どうでしょう。

投稿2015/09/05 00:42

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

takeroyasuhara

2015/09/05 14:08

なるほど!参考になりました。そのように設計してみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問