mysql - rails 2.3 : Replace record associations instead of delete

标签 mysql ruby-on-rails ruby

所以这是一般问题:

我有 3 个表,为简单起见,我们将它们称为 a、b、c

表a
编号

表b
id
a_id
c_id

表c
编号

因此,b 中的一条记录关联了 a 和 c 中的一条记录。

问题是: 当用户提交表单时,会提交一定数量的哈希值,每个哈希值代表 b 中需要填充的一条记录。现在我只是删除并重新添加,我希望能够迭代现有的关联(这就是棘手的地方)如果数据库(D)中的关联比提交的(S)更多,那么删除D-S条目,如果D-S相等则替换当前条目,如果D-S为负数则添加S-D记录。

然后将它们全部更新为新关联。

我尝试使用循环执行此操作,但问题是事件记录查询返回一个数组,并且我仍然有一个哈希要迭代。由于我不能让两个数组彼此同步循环,所以我不知道从这里去哪里。有什么想法吗?

注意:我可以发布实际代码,但是处理此问题的 Controller 函数非常长。

<小时/> 编辑:我觉得我在这里不够具体,尽管我越来越确定这一切都必须是手动的,这里是我正在寻找的内容的一个粗略示例。

submitted_hash[:whatever].each do |key,value|
    #value.first_submit
    #value.second_submit
end

ModelName.find(:all, :conditions => ["fk_ref = ?", params[:fk_ref]]).each do |model_value|
end

现在,如果“ModelName.find”返回的内容多于当前“subscribed_hash”中的内容,那么我们需要创建更多引用来满足需求。

如果“ModelName.find”返回的值小于“subscribed_hash”,那么我们将在数据库中以行的形式添加差异。

如果它们相等,则不需要对此部分采取任何操作。

最后,我需要使用 ModelName.find(:all, :conditions),它现在应该返回与我们的哈希中相同的数量(我已经得到了这么多)。

现在,我需要同时循环我们的 ModelName.find 和 params[:subbmited_hash],以便记录 1 被提交 1 替换,然后记录 2 被提交 2 替换,等等。

注意:所以我可以表达我的意图,我试图做的是替换记录,而不进行任何不必要的删除,如果有人提交 6 并需要 3,我现在的代码将删除 6,并添加 3 个新的。这可行,但每次更新时都会永久删除 6 行(在本例中)。我希望它删除 3 个(两个值的差值)并将剩余的 3 个更新为新提交的值。

最佳答案

您的文字对我来说不是很清楚,但您可以寻找的最接近的东西是 mysql replace 命令。

如果没有对应的行,它会插入一个新行,否则会进行更新。

像这样:

  REPLACE INTO b (id, a_id, c_id) VALUES (5, 2, 3);

引用:http://dev.mysql.com/doc/refman/5.0/en/replace.html

但它不会删除旧的无效条目。我认为您需要自己/手动完成。数据库不是这样工作的。

使用 ORM 框架可以做到这一点。我对 Rails 一无所知,但也许此页面可以帮助您:

http://blog.gridworlds.com/rails/delete-or-delete-removing-things-in-rails

或者尝试寻找rails“删除孤儿”

关于mysql - rails 2.3 : Replace record associations instead of delete,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11834192/

相关文章:

javascript - 如何避免普通文件中的 key ?

mysql - 如何在 MYSQL 的 COUNT 中使用 SELECT

mysql - 如何在故障转移期间延迟 ActiveRecord MySQL 重新连接

ruby - 如何停止思考 "relationally"

mysql - 在巨大的生产表上创建索引

java - [SQL]如何在一个 SELECT 中填充具有另一个表列表的对象?

ruby-on-rails - 如何在这个 angularjs 设计库身份验证服务上存储和设置用户?还是已经完成了?

ruby-on-rails - Ruby - 获取两个日期之间的月份范围

ruby-on-rails - 如何获得积极的考试心态?

ruby-on-rails - 如何使用 Ruby 客户端为服务器到服务器应用程序设置 Google Calendar API