Ruby on rails Rails嵌套有一个:无法删除现有记录
我正在尝试更新“问题”模型中嵌套的问题输出属性。一个问题有一个问题输出。如果数据库中没有现有的问题输出,则一切正常。但是,如果记录已经有疑问输出,我在尝试更新时会得到以下结果: 无法删除现有的关联问题输出。记录 在其外键设置为nil后未能保存 我本以为“允许毁灭”会解决这个问题,但唉——没有乐趣。诚然,我以前很少用过。但如果有人对如何解决这个问题有任何想法,我将不胜感激。相关代码如下: 表格:Ruby on rails Rails嵌套有一个:无法删除现有记录,ruby-on-rails,nested-attributes,has-one,Ruby On Rails,Nested Attributes,Has One,我正在尝试更新“问题”模型中嵌套的问题输出属性。一个问题有一个问题输出。如果数据库中没有现有的问题输出,则一切正常。但是,如果记录已经有疑问输出,我在尝试更新时会得到以下结果: 无法删除现有的关联问题输出。记录 在其外键设置为nil后未能保存 我本以为“允许毁灭”会解决这个问题,但唉——没有乐趣。诚然,我以前很少用过。但如果有人对如何解决这个问题有任何想法,我将不胜感激。相关代码如下: 表格: = form_for [@question.project, @question], :as =>
= form_for [@question.project, @question], :as => :question, :url => admin_project_question_path(@question.project, @question) do |f|
= render '/shared/form_errors', :model => @question
= f.fields_for :question_output_attributes do |qo|
.field
= qo.label :question_type
= qo.select :question_type, QuestionOutput::QUESTION_TYPES
.field
= qo.label :client_format
= qo.select :client_format, QuestionOutput::CLIENT_FORMATS
.field
= qo.label :required
= qo.check_box :required
.field
= qo.label :min_input, 'Length'
= qo.text_field :min_length
= qo.text_field :max_length
= f.submit 'Save Question Formatting'
问题模式:
class Question < ActiveRecord::Base
has_one :question_output
accepts_nested_attributes_for :question_output, :allow_destroy => true
end
类问题true
结束
问题输出模型:
class QuestionOutput < ActiveRecord::Base
belongs_to :question
end
classquestionoutput
问题:
class Admin::QuestionsController < ApplicationController
def show
@question = Question.find(params[:id])
@question.question_output ||= @question.build_question_output
end
def update
@question = Question.find(params[:id])
if @question.update_attributes(params[:question])
flash[:notice] = t('models.update.success', :model => "Question")
redirect_to admin_project_question_path(@question.project, @question)
else
flash[:alert] = t('models.update.failure', :model => "Question")
redirect_to admin_project_question_path(@question.project, @question)
end
end
end
类管理员::问题控制器“问题”)
将\重定向到管理\项目\问题\路径(@question.project,@question)
其他的
flash[:alert]=t('models.update.failure',:model=>“问题”)
将\重定向到管理\项目\问题\路径(@question.project,@question)
结束
结束
结束
在问题模型中,将has\u一行更改为:
has_one :question_output, :dependent => :destroy
上的:allow\u destroy=>true
接受嵌套的属性
允许您通过\u destroy=1
HTML属性删除问题表单中的问题输出
删除问题时,
:dependent=>:destroy
会删除问题输出或者在您的情况下在问题输出被新记录替换时删除它。每次创建新记录都会产生某种开销。
您只需包含带有记录id的隐藏字段,它将被更新而不是销毁
= qo.hidden_field :id
嗨,我现在的情况是这样的,我有一个用户有一个地址,当我尝试更新我的用户时,它会给我与@PlankTon相同的错误,如果我使用:dependent=>:destroy,每次我更新用户信息时,它会销毁关联并创建一个具有不同id的新地址!有一种方法可以直接使用exesting关联而不销毁然后创建it@medBo我正要回答你的问题,但看到它得到了回答。你不认为这是一个巨大的安全风险吗?