has_one 关系下插入数据

简介:
刚刚发现个问题。举例来说明,譬如有两个实体,person和job,如果是多对多的关系
那么可以在插入某个person的工作数据时这么写代码:
@person=People.find(:id)
@job=@person.jobs.build(params[:job])
@job.save
 
------但是如果person和job是一对一的关系呢。
 
就不能这么做了,不能写
@person=People.find(:id)
@job=@person.job.build(params[:job])
@job.save
 
这样会发生错误
You have a nil object when you didn't expect it! 
The error occurred while evaluating nil.build
所以一对一的情况下可以这么写:
@person=People.find(:id)
@person.job=Job.new(params[:job])
@person.job.save
 
-----------------------------------------------------------------------------
原因在于@person.jobs是一个数组。即使为空也是空数组[]
而@person.job不是数组,而是一个job对象,所以会出现空对象调用build方法失败
 
----------
这种情况下还可以适用方法
@job.build_job(params[:job])
来解决




本文转自 fsjoy1983 51CTO博客,原文链接:http://blog.51cto.com/fsjoy/121832,如需转载请自行联系原作者

目录
相关文章
|
7月前
|
关系型数据库 MySQL 数据库
『 MySQL数据库 』表的增删查改(CRUD)之表的数据插入及基本查询(上)
『 MySQL数据库 』表的增删查改(CRUD)之表的数据插入及基本查询(上)
|
7月前
|
关系型数据库 MySQL 数据处理
『 MySQL数据库 』表的增删查改(CRUD)之表的数据插入及基本查询(下)
『 MySQL数据库 』表的增删查改(CRUD)之表的数据插入及基本查询(下)
|
SQL 关系型数据库 MySQL
MySQL数据库操作篇2(表的增删查改&约束)
MySQL数据库操作篇2(表的增删查改&约束)
111 0
|
C语言
一对多表操作
一对多表操作
71 0
|
SQL Oracle 关系型数据库
【SQL开发实战技巧】系列(八):聊聊如何插入数据时比约束更灵活的限制数据插入以及怎么一个insert语句同时插入多张表
插入数据、阻止对某几列插入的实现、复制表的定义和数据以及注意事项、比创建约束功能更强大!用 WITH CHECK OPTION限制数据录入、如何一个insert将数据同时插入多个表【SQL开发实战技巧】这一系列博主当作复习旧知识来进行写作,毕竟SQL开发在数据分析场景非常重要且基础,面试也会经常问SQL开发和调优经验,相信当我写完这一系列文章,也能再有所收获,未来面对SQL面试也能游刃有余~。但是!ORA - 01723 : 不允许长度为 0 的列。
【SQL开发实战技巧】系列(八):聊聊如何插入数据时比约束更灵活的限制数据插入以及怎么一个insert语句同时插入多张表
|
SQL 关系型数据库 MySQL
(解释文)My SQL中主键为0和主键自排约束的关系
  上一篇我们说了关于自排如果主键是0的问题,在这里我搞清楚了原因,导致这种情况是因为在SQL中对自排设置了初始值:      从这里可以看到这两个变量一个是自增的初始值,一个是增量,这里都是1,所以在设置自增的时候会把那个字段原来存在的所有0变成从1开始的步长为1的等差数列。
1009 0
|
SQL MySQL 关系型数据库
(细节)My SQL中主键为0和主键自排约束的关系
开始不设置主键 表的设计如下: 如果id的位置有好几个0的话:设置主键并且自动排序时,0会从1开始递增;   Insert 进去 id = 0的数据,数据会从实际的行数开始增加,和从0变化不一样;   现在主键是没有0的,如果把某个id改成0的话,0不会变!直接会进行排序;   ...
1167 0