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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

758閲覧

ActiveRecord::StatementInvalid

mymt658

総合スコア15

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2021/07/05 13:37

編集2021/07/05 13:48

掲示板アプリ開発を行なっており、
やりたかったこととしては、
①親ユーザー(1)と子ユーザー(多数)がいる
②子ユーザーからコメントがあった場合、親ユーザーがコメントが合った順に見られる
ここまで実装確認。

③親ユーザーが見やすいようにコメントをハイライト
④seedファイルにテストデーターを作成して反映 <ー エラー発生

最短距離でしっかり身に付く! Webアプリケーション開発の教科書
~Ruby on Railsで作る本格Webアプリ~ という本を参考に行なっています。

エラー内容

イメージ説明

PG::UndefinedColumn: ERROR: column "updated" does not exist LINE 1: ...users"."role" = $1 AND "users"."id" = $2 ORDER BY updated de... ^ HINT: Perhaps you meant to reference the column "users.updated_at".

イメージ説明

controller

1class UsersController < ApplicationController 2 before_action :authenticate_user! 3 4 def show 5 @user = User.find(params[:id]) 6 # @students = User.where(role: 'student').order('updated_at desc') if @user.role == "teacher" 7 @posts = Post.where(user_id: @user.id).order("created_at desc") 8 9 visit = current_user.visits.find_by(visitee: @user.id) 10 if (visit != nil) 11 visit.touch 12 else 13 current_user.visits << Visit.create(visitee: @user.id) 14 end 15 16 if @user.role == "teacher" 17 @students = User.where(role: "student").order("updated desc") 18 @updated_users = [] 19 current_user.visits.each {|v| 20 st = @students.find_by(id: v.visitee) 21 next if st == nil 22 @updated_users.push(st.id) if (Post.where(user_id: v.visitee).where(updated_at: v.updated_at ... Time.now).size > 0)} 23 end 24 end 25end 26 27

イメージ説明

seed.rb

1names = ["Mr. Teacher","Antonio Banderas","Cynthia Erivo", 2"Scarlett Johansson","Jonathan Pryce","Florence Pugh", 3"Yalitza Aparicio","Olivia Colman","Marina de Tavira", 4"Adam Driver","Sam Elliott","Lady Gaga","Richard E. Grant", 5"Regina King","Rami Malek","Mary J. Blige","Timothee Chalamet", 6"Allison Janney","Daniel Kaluuya","Lesley Manville", 7"Laurie Metcalf","Margot Robbie","Sam Rockwell","Mahershala Ali"] 8 9names.each_with_index {|name, i| 10 uid = sprintf "user%03d", i 11 User.create(username: uid, fullname: name, 12 password: "123456", 13 role: ((i == 0) ? "teacher" : "student")) 14 Visit.create(user_id: 1, visitee: i) 15 16} 17

イメージ説明

viewファイル

1<h1>My page for <%= @user.fullname %> </h1> 2 3<% if @students != nil %> 4 <p> 5 <% @students.each {|st| 6 color = @updated_users.include?(st.id) ? "btn btn-warning" : "btn btn-light" %> 7 <%= link_to st.fullname, user_path(st.id), class: "color" %> 8 <% } %> 9 </p> 10<% end %> 11 12<div class="form-group"> 13 <%= form_with model: Post.new do |f| %> 14 <%= f.text_area :body, placeholder: "Add your coment", class:"form-control", rows: 10 %> 15 <%= f.hidden_field :id, { value: @user.id } %> 16 <%= f.submit "submit" ,class: "btn btn-primary "%> 17 <% end %> 18</div> 19 20<% if @posts != nil %> 21 <% l = @posts.length; @posts.each_with_index {|post, i| 22 submitter = User.find_by(id: post.submitter) 23 sname = (submitter != nil) ? submitter.fullname : "Anonymous" %> 24 <div class="card"> 25 <div class="card-header"> 26 <%= (l-i).to_s + " : " %> 27 <%= (submitter !=nil) ? (link_to sname, user_path(submitter)) : sname %> 28 <%= post.created_at.to_s %></div> 29 <div class= "card-body"> 30 <%= simple_format(h(post.body)) %></div> 31 </div> 32 <% } %> 33<% end %>

イメージ説明

create_table "posts", force: :cascade do |t| t.integer "user_id" t.text "body" t.datetime "created_at", precision: 6, null: false t.datetime "updated_at", precision: 6, null: false t.integer "submitter" end

とりあえずカラムがない?のが原因と考え、Seedファイルの内容を再度確認、dbを再作成を行いましたが、エラーが出たままです。

よろしくお願いします。

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

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

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

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

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

winterboum

2021/07/05 13:42

Postのschema と seedの一例を載せてください
mymt658

2021/07/05 13:51

コメントありがとうございます。 スキーマファイルの内容を追加しました。 postに関してはseedで作成は行なっておらず、簡単に手打ちでコメント程度を入力しています
guest

回答1

0

ベストアンサー

@students = User.where(role: "student").order("updated desc")

.order("updated_at desc")じゃないですか?

投稿2021/07/05 14:17

asm

総合スコア15147

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

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

mymt658

2021/07/05 14:45

コメントありがとうございます。 ご指摘いただいた部分を変更することで解決することができました。 ありがとうございます。 ちなみにご参考までにお尋ねしたのですが、 当方も何度か記述ミスがないか確認した上での質問をしたのですが、 どのようにコメント内容の部分がエラーの原因だと思われましたか?
asm

2021/07/06 00:08

まずエラー内容がupdatedカラムが見つからない、との事でしたので どこでupdatedを参照してるのかを考えながら探したところ見つかったのがorderでした。
mymt658

2021/07/06 12:20

ありがとうございます。 今後似たようなことが起こると思いますので参考にさせていただきます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問