Rails记录不保存

时间:2013-04-26 00:38:17

标签: ruby-on-rails rake

我在尝试保存记录时遇到了非常详细的错误(使用Rails 4,Ruby 2.0.0)。

这就是发生的事情。

2.0.0p0 :001 > Startup
 => Startup(id: integer, name: string, url: string, founded: date, mal: boolean,
            created_at: datetime, updated_at: datetime, creator: string, 
            description: text, category: text) 

2.0.0p0 :002 > @s = Startup.new(:name => "New Startup", 
                                :url =>  "http://newstartup.com", 
                                :founded => Date.today,
                                :mal => false, 
                                :creator => "127.0.0.1", 
                                :description => "This is a description", 
                                :category => ["","Sports"])
 => #<Startup id: nil, name: "New Startup", url: "http://newstartup.com", founded: "2013-04-25", mal: false, created_at: nil, updated_at: nil, creator: "127.0.0.1", description: "This is a description", category: ["", "Sports"]> 

2.0.0p0 :003 > @s.save
   (0.2ms)  BEGIN
   (0.3ms)  ROLLBACK
 => false 

这是我的模特:

class Startup < ActiveRecord::Base
  before_validation(:on => :create) do
    self.mal = false
  end

  attr_accessible :name, :url, :description, :category, :creator, :mal, :founded
end

模式:

create_table "startups", force: true do |t|
  t.string   "name"
  t.string   "url"
  t.date     "founded"
  t.boolean  "mal"
  t.datetime "created_at"
  t.datetime "updated_at"
  t.string   "creator"
  t.text     "description"
  t.text     "category"
end

和控制器:

class StartupsController < ApplicationController
  before_action :set_startup, only: [:show, :edit, :update, :destroy]
  before_create :set_creator

  # GET /startups
  # GET /startups.json
  def index
    @startups = Startup.all
  end

  def land
    @startup = Startup.new
    @resource = User.new
    @devise_mapping = Devise.mappings[:user]
  end

  # GET /startups/1
  # GET /startups/1.json
  def show
  end

  # GET /startups/new
  def new
    @startup = Startup.new
  end

  # GET /startups/1/edit
  def edit
  end

  # POST /startups
  # POST /startups.json
  def create
    @startup = Startup.new(startup_params)

    respond_to do |format|
      if @startup.save
        format.html { redirect_to @startup, notice: 'Startup was successfully created.' }
        format.json { render action: 'show', status: :created, location: @startup }
      else
        format.html { render action: 'new' }
        format.json { render json: @startup.errors, status: :unprocessable_entity }
      end
    end
  end

  # PATCH/PUT /startups/1
  # PATCH/PUT /startups/1.json
  def update
    respond_to do |format|
      if @startup.update(startup_params)
        format.html { redirect_to @startup, notice: 'Startup was successfully updated.' }
        format.json { head :no_content }
      else
        format.html { render action: 'edit' }
        format.json { render json: @startup.errors, status: :unprocessable_entity }
      end
    end
  end

  # DELETE /startups/1
  # DELETE /startups/1.json
  def destroy
    @startup.destroy
    respond_to do |format|
      format.html { redirect_to startups_url }
      format.json { head :no_content }
    end
  end

  private
    # Use callbacks to share common setup or constraints between actions.
    def set_startup
      @startup = Startup.find(params[:id])
    end

    def set_creator
      @startup.creator = request.remote_ip
    end

    # Never trust parameters from the scary internet, only allow the white list through.
    def startup_params
      params.require(:startup).permit(:name, :url, :added, :founded, :mal, :creator, :description, {:category => []})
    end
end

当我想将Startup.category从字符串切换到字符串列表时,我才开始遇到此问题。

我做错了什么或在哪里可以找到更多错误信息?

1 个答案:

答案 0 :(得分:10)

whateverModel.save不会引发任何异常,但会返回true(模型已保存)或false。如果您致电savecreateupdate_attributes(没有爆炸)或valid?您的模型将从控制台中公开errors属性:

puts @s.errors.messages.inspect

更新:

before_validation中的最后一个(也是唯一一个)表达式正在返回false,这意味着交易将被中止,请尝试:

self.mal=false
true