質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby on Rails 7

Ruby on Rails 7は、2021年12月に正式リリースされました。Ruby on Railsのバージョン7であり、フロントエンド開発環境を大幅に刷新。Node.jsを用いない構成がデフォルトになっています。

Q&A

解決済

1回答

409閲覧

railsのAPIモードで、ID以外のカラムで削除したい。

gomes_2222

総合スコア90

Ruby on Rails 7

Ruby on Rails 7は、2021年12月に正式リリースされました。Ruby on Railsのバージョン7であり、フロントエンド開発環境を大幅に刷新。Node.jsを用いない構成がデフォルトになっています。

0グッド

0クリップ

投稿2023/01/26 07:36

前提

railsのAPIモードです。
dbのレコードをidで削除する方法はわかるのですが、id以外のカラムの条件を付けて削除したい場合、どうしたらいいでしょうか?

実現したいこと

railsで下記のSQL文を実行する。

delete from sample where user_id=1 and post_id=1;

発生している問題・エラーメッセージ

エラーメッセージ

該当のソースコード

sample_controller

1class SampleController < ApplicationController 2 before_action :set_param, only: %i[destroy] 3 4 def destroy 5 if @sample.destroy 6 render json: @sample 7 else 8 render json: @sample.errors 9 end 10 end 11 12 private 13 14 def set_param 15 @sample = Sample.find_by(user_id: params[:id], post_id: params[:id]) 16 end 17 18end

route.rb

1Rails.application.routes.draw do 2 #mount_devise_token_auth_for ‘User’, at: ‘auth’ 3 # For details on the DSL available within this file, see https://guides.rubyonrails.org/routing.html 4 #root to: ‘posts#index’ 5 6 resources :samples 7 8 delete ‘samples/delete/:user_id/:post_id’, to:‘samples#destroy’ 9 10end

これだとエラーが出て失敗します。

`undefined method `destroy' for nil:NilClass`

試したこと

名前を変えればよいと思い、一度名前をdestroy=>deleteにしても変化がなかったです。
調べても情報がありません。idでの削除しかできない仕様なんでしょうか?

補足情報(FW/ツールのバージョンなど)

なお、user_idとpost_idの組み合合わせが一致するレコードは1しかありません。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

find_by の結果が空の場合にエラーが起きてるだけじゃないでしょうか
nilガードしないといけないかなと

rb

1def destroy 2 if @sample.nil? 3 render json: { "message" => "Error" } 4 elsif @sample.destroy 5 render json: @sample 6 else 7 render json: @sample.errors 8 end 9end

投稿2023/01/26 08:37

編集2023/01/26 08:37
yuma.inaura

総合スコア1453

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

gomes_2222

2023/01/26 09:32

できました! ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問