users@jpa-spec.java.net

[jpa-spec users] [jsr338-experts] Re: CriteriaUpdate/CriteriaDelete questions

From: Linda DeMichiel <linda.demichiel_at_oracle.com>
Date: Mon, 25 Jun 2012 13:29:28 -0700

The problem is the backwards-compatibility.

getRoots would just return a single root, which is ok (although not optimal).

On 6/25/2012 12:51 PM, Steve Ebersole wrote:
> Something like:
>
> public interface Criteria<T> {
> <U> Subquery<U> subquery(Class<U> type);
>
> Criteria<T> where(Expression<Boolean> restriction);
>
> Criteria<T> where(Predicate... restrictions);
>
> Predicate getRestriction();
> }
>
> public interface SelectionCriteria extends Criteria {
> // rest of stuff currently on AbstractQuery,
> // or just redefine AbstractQuery to extend Criteria
> }
>
> public interface Subquery extends SelectionCriteria {
> // not completely backwards compatible, but most correct imo:
> public Criteria getParent();
>
> // rest same
> }
>
> public interface CriteriaQuery extends SelectionCriteria {
> ...
> }
>
> public interface CriteriaUpdate extends Criteria {
> ...
> }
>
> public interface CriteriaDelete extends Criteria {
> ...
> }
>
>
> On Mon 25 Jun 2012 02:41:55 PM CDT, Steve Ebersole wrote:
>> Sorry, that second sentence should have asked whether
>> Subquery#getParent could just return the new "base contract"
>> referenced in the last sentence....
>>
>> On Mon 25 Jun 2012 02:34:09 PM CDT, Steve Ebersole wrote:
>>> I also think Subquery#getParent should work if the parent is a
>>> CriteriaUpdate/CriteriaDelete. Couldn't Subquery#getParent just
>>> return Query?
>>>
>>> Sure, but AbstractQuery also defines `public Set<Root<?>> getRoots()`
>>> which is a total misnomer in the case of CriteriaUpdate/CriteriaDelete.
>>>
>>> I think a new base contract would be better, though not totally
>>> backwards compatible.
>>>
>>> On Mon 25 Jun 2012 02:09:13 PM CDT, Linda DeMichiel wrote:
>>>> Hi Steve, all,
>>>>
>>>> Steve, thanks for pointing this problem out -- good catch.
>>>>
>>>> On 6/24/2012 8:31 AM, Steve Ebersole wrote:
>>>>> In implementing theses, I ran into 2 questions:
>>>>>
>>>>> 1) In terms of a Subquery associated with a
>>>>> CriteriaUpdate/CriteriaDelete, what should be the return for the
>>>>> Subquery#getParent which is defined to return an AbstractQuery which
>>>>> neither CriteriaUpdate/CriteriaDelete implement.
>>>>>
>>>>
>>>> If Subquery#getParent is going to work (which I think it needs to),
>>>> then I think we are
>>>> back to CriteriaUpdate/CriteriaDelete having to extend AbstractQuery.
>>>>
>>>>> 2) Seems to me we duplicate the effort to define the Root here; 2
>>>>> calls when one would suffice. First users pass the
>>>>> entity class to be updated/deleted to the CriteriaBuilder method,
>>>>> then they have to call one of the from() methods on
>>>>> CriteriaUpdate/CriteriaDelete. But unless I miss something the actual
>>>>> "entity type" of the from argument has to be the
>>>>> same as the one passed to CriteriaBuilder. Long story short, seems to
>>>>> me that we could simply do away with the from()
>>>>> methods and remove the need for the user to call the second method.
>>>>
>>>> If CriteriaUpdate/CriteriaDelete need to extend AbstractQuery, then I
>>>> think this becomes a moot point,
>>>> as from() is defined there.
>>>>
>>>> -Linda
>>>>