2015-12-03 22 views
4

我完全喪失了這個功能。我有一個Rails應用程序,用戶可以在這個應用程序中創建一個供系統使用的新供應商。該供應商必須具有唯一的名稱。因此,我們有數據庫這一領域上的唯一索引看到如下:Rails數據庫唯一性驗證不起作用

create_table "vendors", force: :cascade do |t| 
    t.string "vendor_name", limit: 80, null: false 
    t.datetime "updated_at",    null: false 
end 

add_index "vendors", ["vendor_name"], name: "vendor_name_UNIQUE", unique: true, using: :btree 

我的問題是,由於某種原因Rails的驗證是不是跟這個工作,因此應用程序拋出異常,因爲數據庫查詢失敗。唯一的例外是如下:

ActiveRecord::RecordNotUnique in VendorsController#create 

Mysql2::Error: Duplicate entry '3 logiq' for key 'vendor_name_UNIQUE': INSERT INTO `vendors` (`vendor_name`, `updated_at`) VALUES ('3 logiq', '2015-12-03 21:14:12') 

我在vendor.rb模型文件的Rails驗證如下:

validates :vendor_name, presence: true, uniqueness: true, length: { minimum: 5, maximum: 80 } 

我知道驗證正在運行,因爲我仍然收到形狀誤差的長度和存在檢查。不確定我現在可以做什麼。我錯過了什麼嗎?

下面是我的供應商控制器代碼:

def create 
    @vendor = Vendor.new(vendor_params) 
    @vendor.comments.build(user_comment: comment_params[:new_comment], system_note: 'Created Vendor', user: current_user, user_agent: request.user_agent, resolution: comment_params[:screen_resolution]) 

    respond_to do |format| 
    if @vendor.save 
     format.html { redirect_to vendors_path, notice: 'Vendor was successfully created.' } 
     format.json { render :show, status: :created, location: @vendor } 
    else 
     format.html { @new_item = true; render :new } 
     format.json { render json: @vendor.errors, status: :unprocessable_entity } 
    end 
    end 
end 

賣方形式視圖代碼:

<% if @vendor.errors.any? %> 
    <div> 
     <div class="alert alert-danger" role="alert" id="error_explanation"> 
     <h4><strong><%= pluralize(@vendor.errors.count, "error") %></strong> prohibited this vendor from being saved:</h4> 

     <ul> 
      <% @vendor.errors.full_messages.each do |message| %> 
       <li><%= message %></li> 
      <% end %> 
     </ul> 
     </div> 
    </div> 
<% end %> 
+0

不是'ActiveRecord :: RecordNotUnique in VendorsController#create' ActiveRecord告訴你它不是唯一的嗎?它可以在不詢問數據庫的情況下檢查長度和存在,但必須要求數據庫進行唯一性檢查。 – Beartech

+0

這就是我瞭解驗證的唯一性:真正處理檢查數據庫的問題,根據我的日誌,數據庫正在執行。但我永遠不會因爲常規的表單錯誤而反彈。它只是拋出異常。 – SDee

+0

看看http://stackoverflow.com/questions/4982371/handling-unique-record-exceptions-in-a-controller – Beartech

回答

3

問題被實際上到外殼靈敏度有關。解決方案是在供應商模型的驗證線上添加一點點。

先前驗證行:

validates :vendor_name, presence: true, uniqueness: true, length: { minimum: 5, maximum: 80 }

變爲:

validates :vendor_name, presence: true, uniqueness: { case_sensitive: false }, length: { minimum: 5, maximum: 80 }

通知在uniqueness部分的差異。 Rails在默認情況下關心區分大小寫,因此我的驗證並不是每次都在我的情況下運行。

希望這可以幫助其他任何碰到此問題的人!