Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >Rails: PG::NotNullViolation: ERROR:"id“列中的空值违反非空约束

Rails: PG::NotNullViolation: ERROR:"id“列中的空值违反非空约束
EN

Stack Overflow用户
提问于 2014-06-19 03:11:48
回答 2查看 18.7K关注 0票数 8

以下是将记录保存到rails 3.2.12和pg 9.3上的postgres数据库时的错误:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
ActiveRecord::StatementInvalid (PG::NotNullViolation: ERROR:  null value in column "id" violates not-null constraint
: INSERT INTO "sw_module_infox_module_infos" ("about_controller", "about_init", "about_log", "about_misc_def", "about_model", "about_onboard_data", "about_subaction", "about_view", "about_workflow", "active", "api_spec", "category_id", "created_at", "last_updated_by_id", "module_desp", "name", "submit_date", "submitted_by_id", "updated_at", "version", "wf_state") VALUES ($1, $2, $3, $4, $5, $6, $7, $8, $9, $10, $11, $12, $13, $14, $15, $16, $17, $18, $19, $20, $21) RETURNING "id"):
  activerecord (3.2.12) lib/active_record/connection_adapters/postgresql_adapter.rb:1166:in `get_last_result'
  activerecord (3.2.12) lib/active_record/connection_adapters/postgresql_adapter.rb:1166:in `exec_cache'

到目前为止,该表工作正常(在今天的错误发生前保存了大约50条记录)。在pgadmin中打开pg表之后。我们发现桌子上的idinteger。我们还发现其他表上的Idserial。看起来id应该是serial,这样它才能自动递增。如果是,那么如何将id列从integer转换为serial?如果不是,那么如何解决这个问题?

EN

回答 2

Stack Overflow用户

发布于 2020-08-07 09:08:12

在使用Rails6应用程序时,我遇到了类似的问题。

我有一个用于创建studentadmin用户模型

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class User < ApplicationRecord
  belongs_to :role
end

Role模型:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class Role < ApplicationRecord
end

但是,我希望在创建表单时为每个adminstudent分别分配studentadmin角色,而表单中没有roles字段,因此我的模型如下所示:

管理员模型:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class Admin < ApplicationRecord
  before_save :set_admin_role

  belongs_to :user

  private

  def set_admin_role
    # set role_id to '1' except if role_id is not empty
    user.role_id = '1' if user.role_id.nil?
  end
end

学生模型:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class Student < ApplicationRecord
  before_save :set_student_role

  belongs_to :user

  private

  def set_student_role
    # set role_id to '2' except if role_id is not empty
    user.role_id = '2' if user.role_id.nil?
  end
end

因此,每当我尝试创建管理员和学生时,都会抛出错误:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
ActiveRecord::NotNullViolation (PG::NotNullViolation: ERROR:  null value in column "role_id" violates not-null constraint)

这里是我如何解决它的

问题是在我的迁移文件中,users表中的role_id被设置为null: false。我不得不把它改成null: true

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class CreateUsers < ActiveRecord::Migration[6.0]
  def change
    create_table :users do |t|
      t.string :email
      t.string :password_digest
      t.references :role, null: true, foreign_key: true

      t.timestamps
    end
  end
end

然后还更改了用户模型,使role_id成为可选的:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class User < ApplicationRecord
  belongs_to :role, optional: true
end

就这样。

我希望这对有帮助

票数 5
EN

Stack Overflow用户

发布于 2020-08-19 18:35:07

我也遇到过类似的问题。

我会告诉你哪里出了问题,也许有人会发现我的经验很有用

我有ERROR: null value in column "created_at" violates not-null constraint

问题是,我有一个在before_createbefore_save中运行的方法,这些方法试图通过较小的更新来保存。所以它试着节省了几次。

我的建议是检查您的代码在before_savebefore_create中执行的操作

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24298171

复制
相关文章
干货:实时渲染和离线渲染的区别?实时云渲染又是什么?
常见的渲染类型有以下几种:实时渲染、离线渲染、实时云渲染、混合渲染。那么什么是实时渲染?实时渲染和离线渲染有哪些区别?各自有哪些典型应用场景......
点量云木子
2023/02/10
2.3K0
干货:实时渲染和离线渲染的区别?实时云渲染又是什么?
MySQL 中视图和表的区别以及联系是什么?[通俗易懂]
(1)视图是已经编译好的 SQL 语句,是基于 SQL 语句的结果集的可视化的表,而表不是。
全栈程序员站长
2022/07/11
1.9K0
Rails布局和视图渲染
基于“多约定,少配置”原则,在 index 动作末尾并没有指定要渲染的视图,Rails会自动在控制器的视图文件夹中寻找 action_name.html.erb 模板,然后渲染。这里渲染的就是 app/views/books/index.html.erb
用户1515472
2019/07/24
3.4K0
ThinkPHP-视图的使用和渲染(一)
ThinkPHP是一款基于PHP开发的高性能、简洁优雅的Web应用框架,它提供了丰富的功能和灵活的架构,可以帮助我们快速搭建各种类型的Web应用程序。其中,视图(View)是框架中非常重要的一部分,它负责渲染模板和输出内容,让我们可以方便地将数据和界面进行分离。
堕落飞鸟
2023/05/02
8630
ThinkPHP-视图的使用和渲染(二)
在ThinkPHP中,我们可以使用layout方法来设置布局文件。layout方法需要传入布局文件的路径,例如:
堕落飞鸟
2023/05/02
6030
ThinkPHP-视图的使用和渲染(三)
下面是一个简单的示例,演示了如何使用视图类来加载模板文件、传递变量数据、设置布局文件和输出页面内容。
堕落飞鸟
2023/05/02
3780
实时渲染和预渲染有什么区别
詹姆斯·卡梅隆导演的《阿凡达》耗时四年,耗资近5亿美元,为大家打开了一个科幻新世界。电影中的CGI角色,名字,看起来和现实世界中的人一模一样。而且逼真的科幻场景让人震撼。然而,这些精彩的画面离不开CG艺术家和预渲染技术。
3DCAT实时渲染云
2022/06/29
1.5K0
jpg和jpeg的区别是什么_jpeg和jpg的区别是什么
JPG文件的优点是体积小巧,并且兼容性好,因为大部分的程序都能读取这种文件,这是因为JPG格式不仅是一个工业标准格式,而且更是web的标准文件格式。JPG文件如此拥有如此便利的条件,难怪得到了业余玩家的推崇。不过另一方面,JPG之所以很小的原因是:当文件在创建的时候会有一些数据被遗失,即通过“有损”的压缩方式来建立文件,这就是其文件小的原因所在了。 如果数码相机采用了JPG作为照片存储的格式虽然可以节省宝贵空间,但不利的一面也必须看清:凡是可以在相机中调整的诸如色温、色彩平衡、图像锐度等经过相机的处理后都记录在文件内,后期调整只能通过photoshop处理来进行,但是经过调整的图像质量将会有所损失。 JPEG在远程传送上有很好的优势,为了不影响肉眼的观看请不要将压缩比小于8,如果是局域网传送,请你用JPEG的无损压缩(12)或者说直接用TIFF。 JPEG与TIFF转印在最好的铜版纸上,在JPEG压缩指数是12的前提下,二者的区别几乎没有,外行与内行(不用放大镜看印刷点阵)都看不出分别,因为真彩(24位以上)转换成印刷格式的四色模式时,颜色信息的损失比从TIFF到JPEG的过程损失得多得多,所以内、外行单看印刷品几乎不能判断图片有没有经过JPEG格式的转换! 就打印而言,用当今最好的色彩管理软件(德国的BEST COLOE)加上最好的打印机技术(墨滴为4微微升),输出的图面质量也没有印刷品好!特别的暗部的过度!但他可以做到比印刷品质丽!但很硬!JPEG在远程传送上有很好的优势,为了不影响肉眼的观看请不要将压缩比小于8,如果是局域网传送,请你用JPEG的无损压缩(12)或者说直接用TIFF。JPEG与TIFF转印在最好的铜版纸上,在JPEG压缩指数是12的前提下,二者的区别几乎没有,外行与内行(不用放大镜看印刷点阵)都看不出分别,因为真彩(24位以上)转换成印刷格式的四色模式时,颜色信息的损失比从TIFF到JPEG的过程损失得多得多,所以内、外行单看印刷品几乎不能判断图片有没有经过JPEG格式的转换! 就打印而言,用当今最好的色彩管理软件(德国的BEST COLOE)加上最好的打印机技术(墨滴为4微微升),输出的图面质量也没有印刷品好!特别的暗部的过度!但他可以做到比印刷品质丽!但很硬!一般打印机只是有一个很很普通的色彩管理程序!对颜色的解释根本达不到专业要求!因为BEST COLOE软件现在在中国要二万四左右(各位,放弃买盗版的想法,它是硬件加密:))你就别指望你家中几千块的打印机为你安装此软件,当你觉得你打出的东西又艳丽又好看时,不好意思,那是颜色失真了:(,如果你觉得你家的打印机打出的东西就是很优秀时,对不起,那你在图片色彩学方面需要进修了:)相信大家对JPEG这种图像格式都非常熟悉,在我们日常所接触的图像中,绝大多数都是JPEG格式的。JPEG的全称为Joint Photographic Experts Group,它是一个在国际标准组织(ISO)下从事静态图像压缩标准制定的委员会,它制定出了第一套国际静态图像压缩标准:ISO 10918-1,俗称JPEG。由于相对于BMP等格式而言,品质相差无己的JPEG格式能让图像文件“苗条”很多,无论是传送还是保存都非常方便,因此JPEG格式在推出后大受欢迎。随着网络的发展,JPEG的应用更加广泛,目前网站上80%的图像都采用JPEG格式。 但是,随着多媒体应用领域的快速增长,传统JPEG压缩技术已无法满足人们对数字化多媒体图像资料的要求:网上JPEG图像只能一行一行地下载,直到全部下载完毕,才可以看到整个图像,如果只对图像的局部感兴趣也只能将整个图片载下来再处理;JPEG格式的图像文件体积仍然嫌大;JPEG格式属于有损压缩,当被压缩的图像上有大片近似颜色时,会出现马赛克现象;同样由于有损压缩的原因,许多对图像质量要求较高的应用JPEG无法胜任…… 针对这些问题,从1998年开始,专家们开始为下一代JPEG格式出谋划策,希望新标准能具有更高压缩率以及更多新功能,而且更有利于用户对图像进行数字化处理。但这几年间,由于在算法选取问题上耽误了不少时间,直到今年3月的东京会议,彩色静态图像的新一代编码方式“JPEG2000”的编码算法才确定,其最终标准将于今年12月出台。JPEG2000的编码算法一经确定,许多著名的图形图像公司如Corel、Pegasus(美国神马成像公司)等就迫不及待地在新开发的图像工具软件中集成JPEG2000图像压缩技术;而Microsoft、Netscape等在浏览器领域竞争的公司也开始将JPEG2000的新技术集成到其下一个版本的浏览器中——因为相对于JPEG来说,JPEG2000可以说具有革命性的改变!
全栈程序员站长
2022/09/19
2.9K1
mysql和mongodb的区别是什么_mongodb和mysql的区别是什么?区别详细介绍
大家好,又见面了,我是你们的朋友全栈君。 对于mongodb和mysql你应该都很清楚了吧,那么他们两个之间的区别你知道吗?很多人对于mongodb和mysql的区别都不是很清楚,下面一起来了解一下吧
全栈程序员站长
2022/09/10
2.2K0
== 和 equals 的区别是什么?
对于上述第三点理解起来可能有点复杂,因为这里 equals 方法比较需要分两种情况来讨论,一种情况是该方法没有被重写,另外一种是该方法被重写。
Breeze.
2022/04/24
1.5K0
== 和 equals 的区别是什么?
== 和 equals 的区别是什么?
2) 用户自定义类如果没有覆盖equals(),将调用父类的equals (比如是Object),而Object的equals的比较是地址(return (this == obj);)
用户5746037
2022/05/18
4900
== 和 equals 的区别是什么?
在编写代码的时候我们经常会使用 equals 和 == 来判断两个对象是否相等,那么两者有什么区别呢,主要有以下几点区别:
Breeze.
2022/06/05
5.2K0
== 和 equals 的区别是什么?
iOS 视图,动画渲染机制探究
终端的开发,首当其冲的就是视图、动画的渲染,切换等等。用户使用 App 时最直接的体验就是这个界面好不好看,动画炫不炫,滑动流不流畅。UI就是 App 的门面,它的体验伴随着用户使用 App 的整个过程。如果UI失败,用户是不会有打开第二次的欲望的。 iOS 为开发者提供了丰富的 Framework(UIKit,Core Animation,Core Graphic,OpenGL 等等)来满足开发从上层到底层各种各样的需求。不得不说苹果很牛逼,很多接口你根本不需要理解背后的原理就能上手使用并且满足你大部
QQ音乐技术团队
2018/02/01
1.9K0
iOS 视图,动画渲染机制探究
iOS 视图,动画渲染机制探究
终端的开发,首当其冲的就是视图、动画的渲染,切换等等。用户使用 App 时最直接的体验就是这个界面好不好看,动画炫不炫,滑动流不流畅。UI就是 App 的门面,它的体验伴随着用户使用 App 的整个过程。如果UI失败,用户是不会有打开第二次的欲望的。 iOS 为开发者提供了丰富的 Framework(UIKit,Core Animation,Core Graphic,OpenGL 等等)来满足开发从上层到底层各种各样的需求。不得不说苹果很牛逼,很多接口你根本不需要理解背后的原理就能上手使用并且满足你大部
腾讯Bugly
2018/03/23
1.6K0
iOS 视图,动画渲染机制探究
Vue内部是如何渲染视图
vnode其实就是一个描述节点的对象,描述如何创建真实的DOM节点;vnode的作用就是新旧vnode进行对比,只更新发生变化的节点。
用户9700400
2022/11/21
9530
Vue内部是如何渲染视图
通过 PHP 原生代码实现视图模板引擎的解析和渲染
上篇教程学院君给大家简单介绍了什么是 MVC 设计模式,并演示了如何基于原生 PHP 代码编写简单的 HTTP 控制器,控制器对应 MVC 模式中的 C(Controller),今天,我们一起来看下 MVC 模式中另一个模块 —— 视图(View,对应 MVC 模式中的 V),并且基于原生 PHP 代码实现简单的视图模板引擎。
学院君
2020/08/18
2.1K0
Ethernet 和 Internet 的区别是什么?
Internet 将世界各地的计算设备连接起来,其中“连接”需要两部分:物理连接(即硬件连接)和软件连接。
张拭心 shixinzhang
2022/05/10
2.7K0
MongoDB和Redis的区别是什么
MongoDB 更类似 MySQL,支持字段索引、游标操作,其优势在于查询功能比较强大,擅长查询 JSON 数据,能存储海量数据,但是不支持事务。
全栈程序员站长
2022/07/19
1.1K0
MongoDB和Redis的区别是什么
SDK 和 API 的区别是什么
来源:https://www.zhihu.com/question/21691705/answer/770586138 不知道区别的人,大概率是你还没搞懂 API、SDK 是什么。 讲个小故事: 研发人员A开发了软件A,研发人员B正在研发软件B。 有一天,研发人员B想要调用软件A的部分功能来用,但是他又不想从头看一遍软件A的源码和功能实现过程,怎么办呢? 研发人员A想了一个好主意:我把软件A里你需要的功能打包好,写成一个函数。你按照我说的流程,把这个函数放在软件B里,就能直接用我的功能了! 其中,API就是
程序猿DD
2022/03/04
1.1K0
线程和进程的区别是什么
做个简单的比喻:进程=火车,线程=车厢 线程在进程下行进(单纯的车厢无法运行) 一个进程可以包含多个线程(一辆火车可以有多个车厢) 不同进程间数据很难共享(一辆火车上的乘客很难换到另外一辆火车,比如站点换乘) 同一进程下不同线程间数据很易共享(A车厢换到B车厢很容易) 进程要比线程消耗更多的计算机资源(采用多列火车相比多个车厢更耗资源) 进程间不会相互影响,一个线程挂掉将导致整个进程挂掉(一列火车不会影响到另外一列火车,但是如果一列火车上中间的一节车厢着火了,将影响到所有车厢) 进程可以拓展到多机,进程最多
Qwe7
2022/03/07
4850

相似问题

Spring中重定向渲染和视图渲染的区别

38

局部视图和渲染局部视图有什么区别?

20

{{视图}和{{#视图}之间的区别是什么?

11

渲染和再渲染反应的区别?

23

软件渲染与gpu渲染的区别是什么

133
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文