首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >RoR错误:SQlite3::RoR异常:没有这样的列: comments.micropost_id:从"comments“WHERE”comments“中选择"comments".*。”micropost_id“=2

RoR错误:SQlite3::RoR异常:没有这样的列: comments.micropost_id:从"comments“WHERE”comments“中选择"comments".*。”micropost_id“=2
EN

Stack Overflow用户
提问于 2012-05-24 10:31:08
回答 1查看 1.9K关注 0票数 0

我正在与用户开发一个应用程序,他们每个人都有一组微帖子显示在他们的页面上。我正在尝试给这些微博添加评论。每次我访问本地主机:3000/users/(user_id_#)。在标题中给出的错误中,user_id为2。

SQLite3::SQLException:无此列: comments.micropost_id:从"comments“WHERE”comments“中选择"comments".*。”micropost_id“=2

只有当用户有要显示的微帖子时,才会出现此错误。否则它只会显示他们的空白页面。错误来自app/views/users/show.html.erb的此视图。此视图呈现此部分,其中错误发生在第13行。

代码语言:javascript
运行
复制
<li>
  <span class="content"><%= micropost.content %></span>
  <span class="timestamp">
    Posted <%= time_ago_in_words(micropost.created_at) %> ago.
  </span>
  <% if current_user?(micropost.user) %>
    <%= link_to "delete", micropost, method:  :delete,
                                     confirm: "You sure?",
                                     title:   micropost.content %>
  <% end %>

  <h2>Comments</h2>
  <% micropost.comments.each do |comment| %>
    <p>
      <b>Commenter:</b>
      <%= comment.commenter %>
    </p>

    <p>
      <b>Comment:</b>
      <%= comment.body %>
    </p>
  <% end %>

  <h3>Add a comment:</h3>
  <%= form_for([micropost, micropost.comments.build]) do |f| %>
    <div class="field">
      <%= f.label :commenter %><br />
      <%= f.text_field :commenter %>
    </div>
    <div class="field">
      <%= f.label :body %><br />
      <%= f.text_area :body %>
    </div>
    <div class="actions">
      <%= f.submit %>
    </div>
  <% end %>
</li>

这是我的comment.rb文件

代码语言:javascript
运行
复制
class Comment < ActiveRecord::Base
  belongs_to :micropost
  attr_accessible :body, :user_id

end

和我的micropost.rb文件

代码语言:javascript
运行
复制
class Micropost < ActiveRecord::Base
  attr_accessible :content
  belongs_to :user
  has_many :comments

  validates :content, presence: true, length: { maximum: 140 }
  validates :user_id, presence: true
end

还有我的comments_controller.rb

代码语言:javascript
运行
复制
class CommentsController < ApplicationController
  def create
    @micropost = Micropost.find(params[:micropost_id])
    @comment = @micropost.comments.create(params[:comment])
    redirect_to micropost_path(@micropost)
  end

end

最后是我的microposts_controller.rb

代码语言:javascript
运行
复制
class MicropostsController < ApplicationController
  before_filter :signed_in_user
  before_filter :correct_user,   only: :destroy

  def create
    @micropost = current_user.microposts.build(params[:micropost])
    if @micropost.save
      flash[:success] = "Micropost created!"
      redirect_to root_path
    else
      @feed_items = []
      render 'static_pages/home'
    end
  end


  def new
    @micropost = Micropost.new(params[:micropost])
  end

  def show

    @micropost = Micropost.find(params[:id])


  end

  def destroy
    @micropost.destroy
    redirect_back_or root_path
  end

  private

    def correct_user
      @micropost = current_user.microposts.find_by_id(params[:id])
      redirect_to root_path if @micropost.nil?
    end
end


    class CommentsController < ApplicationController
      def create
        @micropost = Micropost.find(params[:micropost_id])
        @comment = @micropost.comments.create(params[:comment])
        redirect_to micropost_path(@micropost)
      end

    end

这里还有users_controller.rb

代码语言:javascript
运行
复制
class UsersController < ApplicationController
  before_filter :signed_in_user, 
                only: [:index, :edit, :update, :destroy, :following, :followers]
  before_filter :correct_user,   only: [:edit, :update]
  before_filter :admin_user,     only: :destroy

  def index
    @users = User.paginate(page: params[:page])
  end

  def show
    @user = User.find(params[:id])
    @microposts = @user.microposts.paginate(page: params[:page])

  end

  def new
    @user = User.new
  end

  def create
    @user = User.new(params[:user])
    if @user.save
      sign_in @user
      flash[:success] = "Welcome to the Sample App!"
      redirect_to @user
    else
      render 'new'
    end
  end

  def edit
  end

  def update
    if @user.update_attributes(params[:user])
      flash[:success] = "Profile updated"
      sign_in @user
      redirect_to @user
    else
      render 'edit'
    end
  end

  def destroy
    User.find(params[:id]).destroy
    flash[:success] = "User destroyed."
    redirect_to users_path
  end

  def following
    @title = "Following"
    @user = User.find(params[:id])
    @users = @user.followed_users.paginate(page: params[:page])
    render 'show_follow'
  end

  def followers
    @title = "Followers"
    @user = User.find(params[:id])
    @users = @user.followers.paginate(page: params[:page])
    render 'show_follow'
  end

  private

    def correct_user
      @user = User.find(params[:id])
      redirect_to(root_path) unless current_user?(@user)
    end

    def admin_user
      redirect_to(root_path) unless current_user.admin?
    end
end

从错误中听起来@micropost没有在def show下的microposts_controller.rb文件中初始化。但我想是吧?我做错了什么?谢谢

这里还有app/views/users/show.html.erb

代码语言:javascript
运行
复制
<% provide(:title, @user.name) %>
<div class="row">
  <aside class="span4">
    <section>
      <h1>
        <%= gravatar_for @user %>
        <%= @user.name %>
      </h1>
    </section>
  </aside>
  <div class="span8">
    <%= render 'follow_form' if signed_in? %>
    <% if @user.microposts.any? %>
      <h3>Microposts (<%= @user.microposts.count %>)</h3>
      <ol class="microposts">
        <%= render @microposts %>
      </ol>
      <%= will_paginate @microposts %>
    <% end %>
  </div>
</div>

下面是创建注释迁移

代码语言:javascript
运行
复制
class CreateComments < ActiveRecord::Migration
  def change
    create_table :comments do |t|
      t.string :user_id
      t.text :body
      t.references :micropost_id

      t.timestamps
    end
    add_index :comments, :micropost_id
  end
end
EN

回答 1

Stack Overflow用户

发布于 2012-05-24 10:36:42

这个错误听起来像是您没有进行迁移以添加micropost_id to comment并迁移了数据库,所以我将从这里开始。

您的迁移显示您正在使用

代码语言:javascript
运行
复制
t.references :micropost_id

但是,t.references接受模型名称,而不是foreign_key,因此请将其更改为

代码语言:javascript
运行
复制
t.references :micropost

或者将引用更改为micropost_id的整数,这两种方法都应该能给出您想要的结果。

您可能需要执行rake db:reset,以便在修复迁移后将所有内容恢复到您想要的位置。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10730366

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档