- 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
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2015/09/05 14:08