JPA @ManyToOne時の@JoinColumnのパラメータ、insertable = false,updatable = falseについて

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 3,809

rabi0615

score 5

よろしくお願いします。

SpringでJPA以下のようなプログラムを実行したのですが、結果が想定と異なります。ご教授いただけますでしょうか。

テーブル:w_m

x(PK) a

テーブルw_n

a(PK) y

M.java

@Entity
@Table(name = "w_m")
public class M implements Serializable{

    private static final long serialVersionUID = 1L;

    public M(){}

    @Id
    @Column
    private String x;

    @Column
    private String a;

    @ManyToOne(cascade = CascadeType.ALL)
    @JoinColumn(referencedColumnName = "a",name = "a",
                insertable = false,updatable = false)
    private N nn;

    //getter、setter


N,java

@Entity
@Table(name = "w_n")
public class N implements Serializable{

    private static final long serialVersionUID = 1L;

    public N(){}

    @Id
    @Column
    private String a;

    @Column            //カラム
    private String y;


ServiceImp.java

@Service
public class ServiceImp {

    //エントリーマネージャーのインジェクション
    @PersistenceContext
    EntityManager entityManager;

    @Transactional
    public void createM(M m){
        entityManager.persist(m);
    }
}


Main.java

    public static void main(String[] args) {

        //コンテキストからバインド
        @SuppressWarnings("resource")
        ApplicationContext context = new ClassPathXmlApplicationContext("./spring/application-config.xml");
        ServiceImp bhs = context.getBean(ServiceImp.class);

        //データ登録
        M cm = new M();
        N cn = new N();

        cm.setX("99999");
        cm.setA("aaaaa");

        cn.setA("aaaaa");
        cn.setY("zzzzz");

        cm.setNn(cn);

        //更新処理
        bhs.createM(cm);
    }

結果としては、w_mとw_nに登録されました。


 質問

@Many@Oneの際に@JoinColumnに追加しなければエラーとなる(と認識しています)「insertble」と「updateble」は、どういった意味のあるパラメータなのでしょうか。

私はw_mには更新(insert)されるが、w_nには更新されないものと思っていましたが、結果はすべてに更新が行われたことで、「insertable = false,updatable = false」の部分は"何がfalse"となるのか教えて頂けますでしょうか。

よろしくお願いします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+1

@Column と @JoinColumn 両方定義した場合にどっちから更新したらいいかわからないから参照のみの設定にしてください

ということ

 設定値の意味

insertable = false はインサートしないデータ
updatable = false はアップデートしないデータ
insertable = true はインサートするデータ
updatable = true はアップデートするデータ

 アノテーションの補足

 users

 column    type        
 id        int         
 name      varchar(255)
 role_id   int         
 実装のケース
@Column
int id

@Column
String name

@Column(name="role_id")
int roleId

@Column
int id

@Column
String name

@JoinColumn(name="role_id")
Role role

は作成されたテーブルの構造(FK 除く)は同一になります。
なので

@Column
int id

@Column
String name

@Column
int roleId

@JoinColumn(name="role_id")
Role role

と実装すると

CREATE TABLE users (
   int id primary key
   name text,
   role_id int,
   role_id int
)

の解釈になってしまうため、この項目は参照用だよって明示してあげる必要があります。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/02/17 18:22

    早速のご回答ありがとうございます。
    自分の技術力のなさを棚に上げて言うのは申し訳ないのですが、
    なんとなく、言っている意味は分かる気がするのですが、すっきりしていません。

    よろしければ、もう少し詳細にご説明していただくことは可能でしょうか?

    【すっきりしないこと・・】
    ・@Columnとは、どのクラスのどのカラムのことを指していますでしょうか。
    ・どっちから更新すればいいか・・ということは、場合によっては@Columnを削除するような記述もあるという事でしょうか。

    キャンセル

  • 2018/02/18 11:27

    詳細なご説明有難うございました。

    ご説明の内容で「@Column int roleId」を削除した状態でも更新がされることも確認できました。質問の内容以外にもご認識していた部分があったことが分かり、大変助かりました。

    有難うございます。

    キャンセル

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

  • ただいまの回答率 90.22%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る