ActiveRecord::NotNullViolation in ReviewsController#create

如何解决ActiveRecord::NotNullViolation in ReviewsController#create

在 Rails 中收到此错误: PG::NotNullViolation:错误:“reviewer_id”列中的空值违反非空约束详细信息:失败的行包含 (26,2222,8,null,2021-01-30 19:26:03.354983,2021-01-) 30 19:26:03.354983)。

此应用试图让用户给其他用户评价。 我是新手,所以错误可能很明显,但对于未经训练的人来说不会。经过数小时的研究,这是我最后的选择。 我很感激帮助解决这个问题。上帝保佑。

routes.rb

resources :users do
    resources :reviews,only: [ :new,:create ]
  end

reviews_controller.rb

 def create
    @review = Review.new(review_params)
    @review.user_id = current_user.id

    if @review.save
      redirect_to user_path(current_user),notice: 'Review added!'
    else
      render :new
    end
  end

  private

  def review_params
    params.require(:review).permit(:rating,:content)
  end

schema.rb

create_table "reviews",force: :cascade do |t|
    t.text "content"
    t.integer "rating"
    t.bigint "user_id",null: false
    t.bigint "reviewer_id",null: false
    t.datetime "created_at",precision: 6,null: false
    t.datetime "updated_at",null: false
    t.index ["reviewer_id"],name: "index_reviews_on_reviewer_id"
    t.index ["user_id"],name: "index_reviews_on_user_id"
  end

  create_table "users",force: :cascade do |t|
    t.string "email",default: "",null: false
    t.string "encrypted_password",null: false
    t.string "reset_password_token"
    t.datetime "reset_password_sent_at"
    t.datetime "remember_created_at"
    t.integer "sign_in_count",default: 0,null: false
    t.datetime "current_sign_in_at"
    t.datetime "last_sign_in_at"
    t.inet "current_sign_in_ip"
    t.inet "last_sign_in_ip"
    t.datetime "created_at",null: false
    t.string "username"
    t.index ["email"],name: "index_users_on_email",unique: true
    t.index ["reset_password_token"],name: "index_users_on_reset_password_token",unique: true
    t.index ["username"],name: "index_users_on_username",unique: true
  end

  add_foreign_key "offers","games"
  add_foreign_key "offers","users"
  add_foreign_key "rentals","offers"
  add_foreign_key "rentals","users"
  add_foreign_key "reviews","users",column: "reviewer_id"

user.rb

  has_many :reviews,dependent: :destroy
  has_many :given_reviews,source: :reviews,foreign_key: :reviewer_id
  has_many :received_reviews,foreign_key: :user_id

review.rb

  belongs_to :user
  validates :content,presence: true
  validates :rating,presence: true

解决方法

您有一个关于 Review 的数据库约束,对于 reviewer_id 字段,在您的架构中定义:

t.bigint "reviewer_id",null: false

在您的 controller#create 操作中,您定义了一个 user_id,但我没有看到您在哪里传递 reviewer_id 或设置它。如果表单中有一个字段,则需要将该参数添加到 review_params 以便它可以从表单传递到控制器操作。或者您需要在 create 操作中定义它,类似于您定义 user_id 的方式。

由于您的评论者是留下评论的人,而用户正在接受评论,我会这样做:

在您留下评论的视图中(我假设这是 User#show),您正在查看特定用户。您知道这是哪个用户,并且最有可能在该视图中将其定义为 @user,因此您最有可能在表单中使用 <%= hidden_field_tag :user_id,@user.id %> 进行评论。这会将 user_id 传递给参数中的 Reviews#create 操作。您还需要将 user_id 添加到 review_params 以便可以在 #create 操作中访问它。

然后在您的 Reviews#create 操作中,分配 @review.reviewer_id = current_user.id@review.user_id 将在您调用 Review.create(review_params) 时分配,假设您已按照上述建议将其添加到表单和 review_params

尝试在 create 操作中添加断点并查看从审核表单发送的 params 对象,这可能有助于您了解发生了什么。

典型的 Rails 实践也是使用模型验证。这样,您就会在请求到达数据库之前收到应用错误。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)&gt; insert overwrite table dwd_trade_cart_add_inc &gt; select data.id, &gt; data.user_id, &gt; data.course_id, &gt; date_format(
错误1 hive (edu)&gt; insert into huanhuan values(1,&#39;haoge&#39;); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive&gt; show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 &lt;configuration&gt; &lt;property&gt; &lt;name&gt;yarn.nodemanager.res