gpt4 book ai didi

ruby-on-rails - HABTM 避免在连接表中重复

转载 作者:太空宇宙 更新时间:2023-11-03 15:59:41 24 4
gpt4 key购买 nike

我读过这个问题:has_and_belongs_to_many, avoiding dupes in the join table但我无法解决我的问题;

我有一个 TypeProduit 类,它有很多 ExtensionFichier :

class TypeProduit < ActiveRecord::Base
has_and_belongs_to_many :extension_fichiers
end

和:

class ExtensionFichier < ActiveRecord::Base
has_and_belongs_to_many :type_produits
end

他们是相关的感谢

class LinkExtensionFichiers < ActiveRecord::Migration
def change
create_join_table :extension_fichiers, :type_produits
end
end

编辑:

这是[正确的] Controller :

class TypeProduitsController < ApplicationController
before_action :set_type_produit, only: [:show, :edit, :update, :destroy]

# GET /type_produits
# GET /type_produits.json
def index
@type_produits = TypeProduit.all
end

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

# GET /type_produits/new
def new
@type_produit = TypeProduit.new
end

# GET /type_produits/1/edit
def edit
end

# POST /type_produits
# POST /type_produits.json
def create
@type_produit = TypeProduit.new(type_produit_params)

puts "------extension_fichier_params------"
puts extension_fichier_params

#@type_produit.extension_fichier_ids = extension_fichier_params

@type_produit.extension_fichiers << ExtensionFichier.find_by(:id => extension_fichier_params)

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

# PATCH/PUT /type_produits/1
# PATCH/PUT /type_produits/1.json
def update
respond_to do |format|
if @type_produit.update(type_produit_params)
format.html { redirect_to @type_produit, notice: 'Type produit was successfully updated.' }
format.json { render :show, status: :ok, location: @type_produit }
else
format.html { render :edit }
format.json { render json: @type_produit.errors, status: :unprocessable_entity }
end
end
end

# DELETE /type_produits/1
# DELETE /type_produits/1.json
def destroy
@type_produit.destroy
respond_to do |format|
format.html { redirect_to type_produits_url, notice: 'Type produit was successfully destroyed.' }
format.json { head :no_content }
end
end

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

def extension_fichier_params
@type_produit.extension_fichier_ids
end

# Never trust parameters from the scary internet, only allow the white list through.
def type_produit_params
params.require(:type_produit).permit(:nom, :extension_fichier_ids => [])
end
end

这是 Rails 服务器的输出:

Started POST "/type_produits" for 127.0.0.1 at 2015-01-27 17:55:15 +0100
Processing by TypeProduitsController#create as HTML
Parameters: {"utf8"=>"✓", "authenticity_token"=>"4LBhwTvGjXOq+3qzO+loGUV/oBCYjW66aVDeE1Zj/AM=", "type_produit"=>{"nom"=>"qsdfqsdf", "extension_fichier_ids"=>["1", "2", ""]}, "commit"=>"Create Type produit"}
ExtensionFichier Load (0.4ms) SELECT "extension_fichiers".* FROM "extension_fichiers" WHERE "extension_fichiers"."id" IN (1, 2)
------extension_fichier_params------
1
2
ExtensionFichier Load (0.2ms) SELECT "extension_fichiers".* FROM "extension_fichiers" WHERE "extension_fichiers"."id" IN (1, 2) LIMIT 1
(0.1ms) begin transaction
TypeProduit Exists (0.1ms) SELECT 1 AS one FROM "type_produits" WHERE "type_produits"."nom" = 'qsdfqsdf' LIMIT 1
SQL (0.4ms) INSERT INTO "type_produits" ("created_at", "nom", "updated_at") VALUES (?, ?, ?) [["created_at", "2015-01-27 16:55:15.923132"], ["nom", "qsdfqsdf"], ["updated_at", "2015-01-27 16:55:15.923132"]]
SQL (0.1ms) INSERT INTO "extension_fichiers_type_produits" ("extension_fichier_id", "type_produit_id") VALUES (?, ?) [["extension_fichier_id", 1], ["type_produit_id", 8]]
SQL (0.1ms) INSERT INTO "extension_fichiers_type_produits" ("extension_fichier_id", "type_produit_id") VALUES (?, ?) [["extension_fichier_id", 2], ["type_produit_id", 8]]
SQL (0.0ms) INSERT INTO "extension_fichiers_type_produits" ("extension_fichier_id", "type_produit_id") VALUES (?, ?) [["extension_fichier_id", 1], ["type_produit_id", 8]]
(0.5ms) commit transaction

为什么 rails 在只有 2 个对象时进行 3 个插入

最佳答案

您的 Controller 代码中有一个非常明显的错误。让我们逐步了解您的 create行动。

您创建一个新的 TypeProduit来自 type_produit_params其中包括 :nom :extension_fichier_ids .然后输出 extension_fichier_params 的值它本身是 @type_produit.extension_fichier_ids然后你得到 "1\n2\n"所以你的@type_produit已经有了这两个 extension_fichier附在上面。

然后您附加 ExtensionFichier.find_by(:id => extension_fichier_params)@type_produit.extension_fichier_ids .现在一个find_by基本上是一个 where().first所以它只得到第一个,即。 id=1。所以现在在你的@type_produit.extension_fichiers数组,您的 ID 又是 1、2 和 1。 IE。三个对象。

然后你保存 TypeProduit所有这三个关联都与三个 INSERT 一起保存

是的,整体解决方案(除了修复不必要的 << 代码或添加 1 和 2 的模型或 View )是添加 -> { uniq }根据 https://stackoverflow.com/a/20226630/152786,您的 habtm 协会的范围

关于ruby-on-rails - HABTM 避免在连接表中重复,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28176158/

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