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

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

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

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Symfony

Symfony はPHPで記述されたWebアプリケーションフレームワークです。よく利用するコーディングをテンプレーティングするなど、Webアプリケーション開発の効率化を目的として設計されています。

Q&A

解決済

1回答

1133閲覧

【Symfony5のチュートリアル】データベースにうまく保存ができない(not-null制約に違反)

cherry2020

総合スコア10

PostgreSQL

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Symfony

Symfony はPHPで記述されたWebアプリケーションフレームワークです。よく利用するコーディングをテンプレーティングするなど、Webアプリケーション開発の効率化を目的として設計されています。

0グッド

0クリップ

投稿2021/07/31 15:24

編集2021/07/31 15:29

エラー内容

入力フォームは、以下のように表示されるのですが、
イメージ説明
入力後、submitボタンを押すをエラーになってしまいます。
イメージ説明

現在の状況

データベースに関するエンティティの状況

Conferenceクラス

  • city, string, 255, no;
  • year, string, 4, no;
  • isInternational, boolean, no.

Commentクラス

  • author, string, 255, no;
  • text, text, no;
  • email, string, 255, no;
  • createdAt, datetime, no.
  • photoFilename, string, yes

エンティティの関連づけ

terminal

1 New property name (press <return> to stop adding fields): 2 > comments 3 4 Field type (enter ? to see all types) [string]: 5 > OneToMany 6 7 What class should this entity be related to?: 8 > Comment 9 10 A new property will also be added to the Comment class... 11 12 New field name inside Comment [conference]: 13 > 14 15 Is the Comment.conference property allowed to be null (nullable)? (yes/no) [yes]: 16 > no 17 18 Do you want to activate orphanRemoval on your relationship? 19 A Comment is "orphaned" when it is removed from its related Conference. 20 e.g. $conference->removeComment($comment) 21 22 NOTE: If a Comment may *change* from one Conference to another, answer "no". 23 24 Do you want to automatically delete orphaned App\Entity\Comment objects (orphanRemoval)? (yes/no) [no]: 25 > yes 26

教えて欲しいこと

  • エラー内容について、conference_idが生成されず、非null制約に引っかかっているという意味だと認識しております。(そもそもこの認識があっていますでしょうか????)
  • その場合、前章8-4にあるように、idについては自動生成されると思うのですが、なぜnullと認識され、null制約にひっかかってしまうのでしょうか?

Doctrine は、データベースのテーブルのプライマリーキーとして使用する id プロパティを追加します。 このキー(@ORM\Id()) は、データベースエンジンによって自動的に生成されます(@ORM\GeneratedValue())。

  • phpやSymfony、PostgreSQLが初めてでエラーが起こっている状況と、どのあたりをみたら良いのか、正直デバッグ方法がよくわかりません。ヒントでも教えていただけると嬉しいです。

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

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

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

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

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

guest

回答1

0

ベストアンサー

Conferenceのidは自動生成されますがCommentのconference_idはCommentとConferenceを関連づけるもので自動生成されるものではない認識です。
先にConferenceのデータを作成しCommentのconference_idに作成したConferenceのidを指定してデータを作成してみてください

投稿2021/07/31 19:19

holy_

総合スコア364

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

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

cherry2020

2021/07/31 22:56

回答ありがとうございます。 holyさんのおっしゃる通り、conferenceを作成してからcommentを作成したら無事に両方とも作成できました!!!!!! 会議がなければそれに対してコメントができないという意味だったのですね。 本当にありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問