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

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

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

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Ruby on Rails

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

Q&A

解決済

1回答

3762閲覧

Rails db:createでエラーになる

pyon_kiti_jp

総合スコア251

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Ruby on Rails

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

0グッド

0クリップ

投稿2019/08/26 05:20

rails new posgre_tst -d postgresql

をやった後、database.ymlファイルを触って、

rails db:create

をしたところ、下記のエラーが出てきております。

Created database 'eigyou_db_test4' FATAL: role "soft" does not exist Couldn't create '' database. Please check your configuration. rails aborted! PG::ConnectionBad: FATAL: role "soft" does not exist /home/tanaka/posgre_tst/bin/rails:9:in `<top (required)>' /home/tanaka/posgre_tst/bin/spring:15:in `<top (required)>' bin/rails:3:in `load' bin/rails:3:in `<main>' Tasks: TOP => db:create (See full trace by running task with --trace)

Create databaseと出てきているので、確かに、データベースは作成されてはいるのですが、エラーが出てきております。softというロールがないと言われておりますが、確かにないのですが、database.ymdでロールは指定していません。
どこに原因があるものなのでしょうか?

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2019/08/26 05:34

> 確かに、データベースは作成されてはいる データベースが作成されていることはどのようにして分かりましたか? > FATAL: role "soft" does not exist ユーザ名が soft ではないですか?
pyon_kiti_jp

2019/08/26 05:46

database.ymlでは、username: postgresを指定しています。softというユーザ名はdatabase.ymlでは指定していないのですが、何故それがエラーでひっかかったのかが分からずにいてます。 データベースの作成は、pgAdminというGUIツールから見て確かに作成された事を確認しています。
退会済みユーザー

退会済みユーザー

2019/08/26 05:50

> FATAL: role "soft" does not exist ユーザ名が soft ではないですか? そして、ログを見る限り、データベースは作成されていないように見えます。
pyon_kiti_jp

2019/08/26 05:55

username: postgresで、password: softではあります。 データベースは確かに作成されています。一旦データベースを削除して、db:createを流しても、やはり同じエラーになります。
退会済みユーザー

退会済みユーザー

2019/08/26 05:57

コマンドを実行しているユーザ名が soft ではないですか? データベースが作成されたのは db:create をしたからではなく、他の手段で作成したからではないでしょうか。
pyon_kiti_jp

2019/08/26 06:15

?少し、分からなくなってきました。
退会済みユーザー

退会済みユーザー

2019/08/26 06:22

それでは、「データベースが作成された〜」の部分はいったん置いておきましょうか。 $ whoami というコマンドを実行すると、今操作しているユーザ名が出てきます。それは何でしょうか。
pyon_kiti_jp

2019/08/26 06:28

確かに、softがでてきました。
退会済みユーザー

退会済みユーザー

2019/08/26 06:30

PostgreSQL では「データベースの」ユーザ名を指定していない場合は「コマンドを操作している」ユーザ名が暗黙で使われます。したがって、エラーメッセージはその内容を表示しています。 これを解決するには、PostgreSQL に soft というロール(ユーザ)を作るか、Railsアプリ専用に任意のロール(ユーザ)を作るか、ということになります。要件に合わせて選んでみてください。 その後、database.yml にロールの情報を書けば db:migrate が正常に実行できるでしょう。
guest

回答1

0

ベストアンサー

エラーに表示されていた「rails FATAL: role does not exist」というキーワードで検索したところ、
「Railsで指定しているロール(DBのユーザー)がない場合」で解決できそうです。
https://www.inodev.jp/entry/mac-rails-postgresql

投稿2019/08/26 06:27

no1knows

総合スコア3365

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

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

pyon_kiti_jp

2019/08/26 06:58

また、別のエラーが・・・ う~ん。なんだろう? Database 'eigyou_db_test4' already exists no implicit conversion of nil into String Couldn't create '' database. Please check your configuration. rails aborted! TypeError: no implicit conversion of nil into String /home/tanaka/posgre_tst/bin/rails:9:in `<top (required)>' /home/tanaka/posgre_tst/bin/spring:15:in `<top (required)>' bin/rails:3:in `load' bin/rails:3:in `<main>' Tasks: TOP => db:create (See full trace by running task with --trace)
pyon_kiti_jp

2019/08/26 07:20

データベースが作成されていたら、それでOKなのかも知れない
pyon_kiti_jp

2019/08/26 07:35

rails db:migrateもいちおうできているし
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問