Can a @ManyToOne JPA relation be null?
Asked Answered
S

3

33

I have a table that has foreign key of another table (many to one relationship) but i want it to be nullable.

Something like this:

public class SubType() {

    @Id
    @GeneratedValue(generator = "system-uuid")
    @GenericGenerator(name = "system-uuid", strategy = "uuid")
    private String id;

}

public class TopUp {

    @Column(nullable = true)
    @ManyToOne(optional = false, fetch = FetchType.LAZY)
    private SubType subType;

}

But @Column(nullable = true) throws the NullPointerException and says subtype can not be null. Is there any way to get the ManyToOne accept null?

Sensual answered 8/9, 2014 at 6:2 Comment(0)
C
77

The @ManyToOne associations are optional by default, so you don't need to set anything if you want them to be nullable.

However, because you set the optional=false attribute, you made it mandatory.

So instead of:

@ManyToOne(optional = false, fetch = FetchType.LAZY)

Set it like this:

@ManyToOne(fetch = FetchType.LAZY)

The optional is true by default.

On the other hand, the @Column(nullable=true) is to instruct the DDL generation tool to include a NULL SQL column type constraint.

Corona answered 8/9, 2014 at 6:11 Comment(1)
That's a terrific solution, hence the number of upvotes.Corona
C
5

try this:

@JoinColumn(name = "subType_id", nullable = true)
Colecolectomy answered 8/9, 2014 at 6:25 Comment(1)
nullable is true by default.Endogenous
F
0

Only this helped me:

public class TopUp {
    @ManyToOne
    @JoinColumn(columnDefinition="integer", name="subtype_id")
    private SubType subType;
}

columnDefinition is a solution!

Finecut answered 22/11, 2018 at 2:24 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.