[
https://issues.apache.org/jira/browse/JDO-630?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=12702375#action_12702375
]
Andy Jefferson commented on JDO-630:
------------------------------------
Since in the weekly meeting minutes people were wanting an identity to be
non-mutable from construction and after studying the usage of such identities
I've come to the conclusion that it would probably be better to just add a new
method on the PM (as per the original mailing list request - 22/07/2008). The
only place a SingleFieldIdentity "id" can be considered "not exact" is where
the user has input it into PM.getObject[s]ById(...) AFAICS. All objects
returned by the implementation will have exact ids. All ids returned by
PM.getObjectId() will also be exact.
This would imply adding the following :-
Object getObjectById(String id, boolean validate, boolean checkInheritance);
Object[] getObjectsById(boolean validate, boolean checkInheritance, Object...
ids);
The other benefit of this would be in terms of memory, one boolean less
overhead per object.
Comments ?
> Support specification of exact class in SingleFieldIdentity
> -----------------------------------------------------------
>
> Key: JDO-630
> URL: https://issues.apache.org/jira/browse/JDO-630
> Project: JDO
> Issue Type: Improvement
> Components: api2
> Reporter: Andy Jefferson
> Fix For: JDO 2 maintenance release 3
>
> Attachments: singlefieldidentity_exact.patch
>
>
> When calling PersistenceManager.getObjectById() with a SingleFieldIdentity,
> there seems to be no way of avoiding the following
> (if the implementation decides to do so):
> "It is an implementation decision whether to access the data store, if
> required to determine the exact class. This will be the case of inheritance,
> where multiple <code>PersistenceCapable</code> classes share the same
> ObjectId class."
> Now when I know for sure that the targetClassName of the given
> SingleFieldIdentity already denotes the correct class for the given id, how
> can I avoid that additional roundtrip to the database for finding the exact
> class?
> It would be useful to have a way of specifying a SingleFieldIdentity to be
> for the exact class specified. This could be done by addition of methods
> void setExact(boolean flag);
> boolean getExact();
> to SingleFieldIdentity
--
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.