Enumerated types is one of the best thing in Java as in any programming language in general.
The problem is that is not supported by all databases. PostgreSQL and MySQL has support Oracle and a few others don't.
This creates a problem especially for those who want to build portable systems.
(Even though many are against portability in RDBMS)
The solution is to define the type as Enumerated Type in the Java part of your system but as VARCHAR or CHARACTER VARYING etc. That is saved in db as string/text and you can enforce control through type checking in the Java side of your system. If the Java side is not the only entry point of your system, then one solution is to add CHECK CONSTRAINT on the field in question and even use exclusively Stored Procedures where you make sure no illegal values found their way into the db.
Now if you are using JPA and especially if you e.g. are using NetBeans which automatically generates classes for all tables then just replace the type String with the ENUM_TYPE you have already defined.
One example: In my schema I have a principal table with a PRINCIPAL_STATUS
the generated code for the field was
I changed the above code to the following
@Basic(optional = false)
@NotNull
@Size(min = 1, max = 20)
@Column(name = "principal_status")
@Enumerated(EnumType.STRING)
private PRINCIPAL_STATUS principalStatus;
don't forget to import
import javax.persistence.Enumerated;
Of course you must change accordingly the get and set methods.
The problem is that is not supported by all databases. PostgreSQL and MySQL has support Oracle and a few others don't.
This creates a problem especially for those who want to build portable systems.
(Even though many are against portability in RDBMS)
The solution is to define the type as Enumerated Type in the Java part of your system but as VARCHAR or CHARACTER VARYING etc. That is saved in db as string/text and you can enforce control through type checking in the Java side of your system. If the Java side is not the only entry point of your system, then one solution is to add CHECK CONSTRAINT on the field in question and even use exclusively Stored Procedures where you make sure no illegal values found their way into the db.
Now if you are using JPA and especially if you e.g. are using NetBeans which automatically generates classes for all tables then just replace the type String with the ENUM_TYPE you have already defined.
One example: In my schema I have a principal table with a PRINCIPAL_STATUS
the generated code for the field was
@Basic(optional = false)
@NotNull
@Size(min = 1, max = 20)
@Column(name = "principal_status")
private String principalStatus;
@NotNull
@Size(min = 1, max = 20)
@Column(name = "principal_status")
private String principalStatus;
I changed the above code to the following
@NotNull
@Size(min = 1, max = 20)
@Column(name = "principal_status")
@Enumerated(EnumType.STRING)
private PRINCIPAL_STATUS principalStatus;
don't forget to import
import eu.minipay.entities.types.PRINCIPAL_STATUS;
import javax.persistence.EnumType;import javax.persistence.Enumerated;
Of course you must change accordingly the get and set methods.
No comments:
Post a Comment