簡體   English   中英

在Rails中添加外鍵

[英]Add foreign key in Rails

我有兩個表, casino_usersaccounts

我想打casino_users.username一個外鍵引用accounts.email

我嘗試了這個:

class AddForeignKeyToCASinoUsers < ActiveRecord::Migration[5.2]
  def up
    add_foreign_key :casino_users, :accounts, column: :username, primary_key: "email"
  end 

  def down
    remove_foreign_key :casino_users, column: :username
  end 
end

但它給我一個錯誤Cannot add or update a child row: a foreign key constraint fails

我使用的語法有問題嗎?

首先猜測是您現有表中的數據與您現在添加的約束不兼容。 如果那似乎不是問題,那么最好提供更多有關此錯誤發生時間的上下文。 當您嘗試運行遷移時,這就是我的假設。

PS:嘗試使用一個主鍵在語法上有意義並且也可能會發生變化,因此您可能會遇到麻煩。 如果您將主鍵設置為id,並通過id將用戶鏈接到帳戶,那么您將有一個更輕松的時間,例如,某天您希望允許用戶更改其電子郵件地址。 如果要確保有一個與電子郵件地址關聯的帳戶,該帳戶很容易實現,並且在電子郵件字段上具有唯一約束。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM