teratail header banner
teratail header banner
質問するログイン新規登録

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

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

新規登録して質問してみよう
ただいま回答率
85.30%
Visual Studio Code

Visual Studio Codeとは、Microsoft社が開発したマルチプラットフォーム対応のテキストエディタです。Visual Studioファミリーの一員でもあります。拡張性とカスタマイズ性が高く、テキストエディタでありながら、IDEと遜色ない機能を備えることができます。

Ruby

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

Ruby on Rails 6

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

GitHub

GitHubは、Gitバージョン管理システムを利用したソフトウェア開発向けの共有ウェブサービスです。GitHub商用プランおよびオープンソースプロジェクト向けの無料アカウントを提供しています。

Q&A

解決済

1回答

1482閲覧

Renderでデプロイできなくなってしまった

DDT-1129

総合スコア1

Visual Studio Code

Visual Studio Codeとは、Microsoft社が開発したマルチプラットフォーム対応のテキストエディタです。Visual Studioファミリーの一員でもあります。拡張性とカスタマイズ性が高く、テキストエディタでありながら、IDEと遜色ない機能を備えることができます。

Ruby

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

Ruby on Rails 6

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

GitHub

GitHubは、Gitバージョン管理システムを利用したソフトウェア開発向けの共有ウェブサービスです。GitHub商用プランおよびオープンソースプロジェクト向けの無料アカウントを提供しています。

0グッド

0クリップ

投稿2023/07/27 01:50

0

0

Renderにデプロイしたい

ここに実現したいことを箇条書きで書いてください。

  • エラーを解消し、デプロイする

前提

ruby 2.6.5
Rails 6.0.6.1
オリジナルアプリを作っています。
deviseでユーザ管理して外出、帰宅時にチェックして動向確認する機能を実装中に以下のエラーメッセージが発生しました。
途中何度かデプロイし成功していましたが、急にできなくなってしまいました。
ローカル環境では、問題なく動いています。

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

rake aborted! StandardError: An error has occurred, this and all later migrations canceled: PG::DuplicateTable: ERROR: relation "users" already exists

bin/rails

#!/usr/bin/env ruby
begin
load File.expand_path('../spring', FILE)
rescue LoadError => e
raise unless e.message.include?('spring')
end
APP_PATH = File.expand_path('../config/application', dir)
require_relative '../config/boot'
require 'rails/commands'

20230719171121_create_genres.rb

class CreateGenres < ActiveRecord::Migration[6.0]
def change
create_table :genres do |t|

t.timestamps end

end
end

20230712053718_create_situations.rb

class CreateSituations < ActiveRecord::Migration[6.0]
def change
create_table :situations do |t|

t.timestamps #t.boolean :out, null: false, default: false t.string :purpose t.integer :genre_id, null: false t.references :user, null: false , foreign_key: true end

end
end

20230711033212_devise_create_users.rb

frozen_string_literal: true

class DeviseCreateUsers < ActiveRecord::Migration[6.0]
def change
create_table :users do |t|
## Database authenticatable
t.string :email, null: false, default: ""
t.string :encrypted_password, null: false, default: ""

t.string :nickname, null: false ## Recoverable t.string :reset_password_token t.datetime :reset_password_sent_at ## Rememberable t.datetime :remember_created_at ## Trackable # t.integer :sign_in_count, default: 0, null: false # t.datetime :current_sign_in_at # t.datetime :last_sign_in_at # t.string :current_sign_in_ip # t.string :last_sign_in_ip ## Confirmable # t.string :confirmation_token # t.datetime :confirmed_at # t.datetime :confirmation_sent_at # t.string :unconfirmed_email # Only if using reconfirmable ## Lockable # t.integer :failed_attempts, default: 0, null: false # Only if lock strategy is :failed_attempts # t.string :unlock_token # Only if unlock strategy is :email or :both # t.datetime :locked_at t.timestamps null: false end add_index :users, :email, unique: true add_index :users, :reset_password_token, unique: true # add_index :users, :confirmation_token, unique: true # add_index :users, :unlock_token, unique: true

end
end

Gemfile

ruby

1source 'https://rubygems.org' 2git_source(:github) { |repo| "https://github.com/#{repo}.git" } 3 4ruby '2.6.5' 5 6# Bundle edge Rails instead: gem 'rails', github: 'rails/rails' 7gem 'rails', '~> 6.0.0' 8# Use mysql as the database for Active Record 9gem 'mysql2', '>= 0.5.3' 10# Use Puma as the app server 11gem 'puma', '~> 3.11' 12# Use SCSS for stylesheets 13gem 'sass-rails', '~> 5' 14# Transpile app-like JavaScript. Read more: https://github.com/rails/webpacker 15gem 'webpacker', '~> 4.0' 16# Turbolinks makes navigating your web application faster. Read more: https://github.com/turbolinks/turbolinks 17gem 'turbolinks', '~> 5' 18# Build JSON APIs with ease. Read more: https://github.com/rails/jbuilder 19gem 'jbuilder', '~> 2.7' 20# Use Redis adapter to run Action Cable in production 21# gem 'redis', '~> 4.0' 22# Use Active Model has_secure_password 23# gem 'bcrypt', '~> 3.1.7' 24 25# Use Active Storage variant 26# gem 'image_processing', '~> 1.2' 27 28# Reduces boot times through caching; required in config/boot.rb 29gem 'bootsnap', '>= 1.4.2', require: false 30 31group :development, :test do 32 # Call 'byebug' anywhere in the code to stop execution and get a debugger console 33 gem 'byebug', platforms: [:mri, :mingw, :x64_mingw] 34 gem 'rspec-rails' 35 gem 'factory_bot_rails' 36 gem 'faker' 37end 38 39group :development do 40 # Access an interactive console on exception pages or by calling 'console' anywhere in the code. 41 gem 'web-console', '>= 3.3.0' 42 gem 'listen', '>= 3.0.5', '< 3.2' 43 # Spring speeds up development by keeping your application running in the background. Read more: https://github.com/rails/spring 44 gem 'spring' 45 gem 'spring-watcher-listen', '~> 2.0.0' 46 gem 'rubocop', require: false 47end 48 49group :test do 50 # Adds support for Capybara system testing and selenium driver 51 gem 'capybara', '>= 2.15' 52 gem 'selenium-webdriver' 53 # Easy installation and use of web drivers to run system tests with browsers 54 gem 'webdrivers' 55end 56 57# Windows does not include zoneinfo files, so bundle the tzinfo-data gem 58gem 'tzinfo-data', platforms: [:mingw, :mswin, :x64_mingw, :jruby] 59 60gem 'pry-rails' 61 62# 本番環境(Render)のデータベース(PostgreSQL)を使用できるようGemを追加(このGemはデータベースがPostgreSQLの際に必要なGem) 63group :production do 64 gem 'pg' 65end 66 67gem 'devise' 68gem 'active_hash' 69 70gem 'net-http'

試したこと

上記エラー文は、usersというテーブルが既にあるのに、再度生成しようとしているために表示されるとのことから、まずはデータベースを確認しまそたが、一つしかなく重複してはいませんでした。念の為、

ruby

1rails db:migrate:reset

で作成し直しましたが、エラーは解消できませんでした。

上記手順で間違いなくuserテーブルは一つしかなくうまくいかないのは別の問題があるのかもと思いました。そこで、マイグレーションファイルを何度も修正(破棄、カラムの追加、訂正等)し、デプロイが成功したいた時のブランチとは違うブランチで実行しようとしているからエラーが出ると仮説を立てて、PostgreSQLに入って削除後にマイグレーションを実行しようとしましたが、コマンド

ruby

1DROP TABLE IF EXISTS users

を入力しても改行しかされずできませんでした。

必要となる資料があれば、教えていただければありがたいです。
大変わかりづらい説明で申し訳ありませんが、よろしくお願いします。

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

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

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

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

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

guest

回答1

0

自己解決

解決方法

・本番環境のテーブルをリセットする。

既に作成されてある「Users」テーブルを消去するため下記ファイルを修正してコミットプッシュする。

ruby(bin/render

1#!/usr/bin/env bash 2# exit on error 3set -o errexit 4 5 6bundle install 7bundle exec rake assets:precompile 8bundle exec rake assets:clean 9# bundle exec rake db:migrate 10DISABLE_DATABASE_ENVIRONMENT_CHECK=1 bundle exec rake db:migrate:reset

10行目(記述内容は、rails db:migrate:resetと同意です)により、本番環境のデータベースを1度削除して再作成することができる。

投稿2023/07/29 08:42

DDT-1129

総合スコア1

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.30%

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

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

質問する

関連した質問