gpt4 book ai didi

ruby-on-rails - Rails 和外键

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

我在 Rails 中遇到了愚蠢的魔法问题!

因此,我创建了带有外键的表(我使用的是 sparkfly-foreigner gem)。

class CreateCourses < ActiveRecord::Migration
def change
create_table :courses do |t|
t.string :coursename,
t.integer :subject,
t.integer :theme,
t.integer :hours,
t.decimal :price,
t.foreign_key :subject, :column => :subject, :dependent => :delete
t.foreign_key :theme, :column => :theme, :dependent => :delete
t.timestamps
end
end
end

它在终端和我的 rails webapp 中运行良好。

然后我正在创建另一个表。

class CreateGroupps < ActiveRecord::Migration
def change
create_table :groupps do |t|
t.string :groupname
t.integer :courseid
t.integer :number,
t.foreign_key :course, :column => :courseid, :dependent => :delete
t.timestamps
end
end
end

魔术开始了。我在 Groupps 的 Web 表单中写了不存在的 courseid,它在数据库中创建了记录!!!当我使用终端时,我得到了这个

rails_dev=> select * from groupps
rails_dev-> ;
id | groupname | courseid | number | created_at | updated_at
----+-----------+----------+--------+----------------------------+----------------------------
1 | 12 | | 1 | 2011-12-03 02:51:06.154261 | 2011-12-03 02:51:06.154261
(1 row)

rails_dev=> insert into groupps values (2,12,0,0); ERROR: insert or update on table "groupps" violates foreign key constraint "groupps_courseid_fkey"
DETAIL: Key (courseid)=(0) is not present in table "courses".

这怎么可能?当我错了?我在 rails 和 ruby​​ 方面还是个新手。

最佳答案

这个输出:

 id | groupname | courseid | number |         created_at         |         updated_at         
----+-----------+----------+--------+----------------------------+----------------------------
1 | 12 | | 1 | 2011-12-03 02:51:06.154261 | 2011-12-03 02:51:06.154261
(1 row)

表示您在 courseid 中有一个 NULL,就您的表和外键而言,这很好。您可以在引用列中使用 NULL,您可能希望将 :null => false 添加到您的 courseid:

create_table :groupps do |t|
t.string :groupname
t.integer :courseid, :null => false
t.integer :number,
t.foreign_key :course, :column => :courseid, :dependent => :delete
t.timestamps
end

顺便说一句,因为你已经在 psql 中了,您可以使用 \d groupps 查看表的结构、约束(包括 FK),甚至是哪些 FK 引用了您的表。您可能还对 \pset null 感兴趣:

null
Sets the string to be printed in place of a null value. The default is to print nothing, which can easily be mistaken for an empty string. For example, one might prefer \pset null '(null)'.

关于ruby-on-rails - Rails 和外键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8365283/

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