I'm working with the
org.hibernate.id.enhanced.TableGenerator class and I've noticed a couple of
shortcomings (imho). First and foremost, it creates one row in the
hibernate_sequences table for each configured segment_value (as opposed to one
row for each "target_table" as implemented within the
MultipleHiLoPerTableGenerator). Given the fact that my id column is defined in
an abstract BaseEntity class, I can't use the enhanced TableGenerator class as
is (since one sequence for all of my entities is not viable for my application).
Which leads
me to my second point. All of the member variables are declared as private,
instead of protected, which makes extending the class for the purpose of
overriding the configure method impossible.
For what it's worth,
here's the change that I had planned to make (in the configure method)
...
Change the setting
of the segmentValue from ...
segmentValue = params.getProperty( SEGMENT_VALUE_PARAM );
...
to
segmentValue =
params.getProperty(TABLE);
Of course, such a
change would change the class behavior significantly - using targetTable instead
of segmentValue as the variable name would probably make sense.
So, with that said,
is another class worth-while (assuming that such a change to the existing class
would break backwards compatability)?
And, on a
related note, the enhanced TableGenerator is cluster safe, right?
Thoughts?
PS. I entered a jira
improvement yesterday - here's the link ...