私の結合テーブルは、元の2つのテーブルから自動集計されません。私は無用にさまざまな方法でそれを接続しようと約5時間を費やしました。私のコードに関するすべてのガイダンスは高く評価されます。Rails - 結合テーブルは自動集計されません
ここに私のコードです。
最初の項目:
`class Order < ActiveRecord::Base
belongs_to :orders_users
has_many :users, :through => :orders_users
validates :item, presence: true
end
def add_order(order)
end
def remove_order(order)
end
`
第2項:
class User < ActiveRecord::Base
belongs_to :orders_users
has_many :orders, :through => :orders_users
validates :username, presence: true, uniqueness: true
has_secure_password
end
移行:
class CreateJoinTable < ActiveRecord::Migration
def change
create_join_table :users, :orders do |t|
t.index [:user_id, :order_id]
t.index [:order_id, :user_id]
end
end
end
受注コントローラー:
class OrdersController < ApplicationController
def new
binding.pry
@order = Order.new
end
def create
@order = Order.new(order_params)
if @order.save
redirect_to request.referer
else
redirect_to root_path
end
end
def show
@order
end
private
def order_params
params.require(:order).permit(:item)
end
end
人の
ユーザーコントローラー:
class UsersController < ApplicationController
def new
@user = User.new
end
def create
@user = User.new(user_params)
if @user.save
session[:current_user_id] = @user.id
redirect_to user_path(@user)
else
redirect_to new_user_path(@user)
end
end
def show
@user = User.find(params[:id])
end
def destroy
@user = User.find(params[:id])
session[:current_user_id] = nil
@user.destroy
redirect_to root_path
end
def index
@user
end
private
def user_params
params.require(:user).permit(:username, :password,:password_confirmation)
end
end
そのビットは不明案内
。あなたはこれで達成したいことを説明できますか? –
お返事ありがとうございます。私がしようとしていることは次のとおりです。ユーザーがデータベースに項目を挿入すると、どのユーザーがどの項目をデータベースに入力したかを記録する結合表が必要になります。それは私の質問を明確にしますか? – CodeYogi
私はafter_saveフィルターが、あなたが必要とするものを順番に実行すると思います。あなたはそれを試しましたか? –