gpt4 book ai didi

ruby-on-rails - Rails 数据库唯一性验证不起作用

转载 作者:数据小太阳 更新时间:2023-10-29 07:16:45 29 4
gpt4 key购买 nike

我对这个完全不知所措。我有一个 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 验证不适用于此,因此应用程序抛出异常,因为数据库查询失败。异常(exception)情况如下:

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 }

我知道正在运行验证,因为我仍然收到长度和存在检查的表单错误。不确定此时我能做什么。我错过了什么吗?

下面是我的供应商 Controller 代码:

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 %>

最佳答案

该问题实际上与区分大小写有关。解决方案是在供应商模型中的验证行中添加一点点。

上一个验证行:

验证:vendor_name,存在:true,唯一性:true,长度:{最小值:5,最大值:80}

变成:

验证:vendor_name,存在:true,唯一性:{ case_sensitive: false },长度:{最小值:5,最大值:80}

注意 uniqueness 部分的区别。默认情况下,Rails 确实会区分大小写,因此我的验证并不是每次都运行。

希望这对遇到此问题的其他人有所帮助!

关于ruby-on-rails - Rails 数据库唯一性验证不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34076556/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com