Notice: this Wiki will be going read only early in 2024 and edits will no longer be possible. Please see: https://gitlab.eclipse.org/eclipsefdn/helpdesk/-/wikis/Wiki-shutdown-plan for the plan.
Difference between revisions of "EclipseLink/Development/JPA 2.0/entity type expressions"
(→Work Required) |
|||
Line 9: | Line 9: | ||
==General Solution== | ==General Solution== | ||
Expression Support will be required that can provide a comparison with an extracted discriminator value. | Expression Support will be required that can provide a comparison with an extracted discriminator value. | ||
+ | |||
+ | ==Native Expression Support== | ||
+ | through EclipseLink [http://bugs.eclipse.org/277509 bug 277509] | ||
+ | 1)ReportQuery will need return Class objects that the Type expression correlates to | ||
+ | 2) Type expressions need to be supported that take parameters and constants representing Java Classes that will evaluate to String/Int values used in these class's inheritance policy fields | ||
+ | 3) Type expresions also need to operate on expressions representing relationships and entities, allowing them all to be compared | ||
+ | ===Public API=== | ||
+ | * <source lang="java">public Expression getClassForInheritance()</source> | ||
+ | returns a Type expression operating on the base expression. Examples: | ||
+ | <source lang="java">expressionBuilder.get("project").getClassForInheritance().equals(LargeProject.class);</source> | ||
+ | * <source lang="java">public Expression getClassForInheritance(Class clazz)</source> | ||
+ | This returns a Type expresssion using the clazz argument to form a ConstantExpression as its base expression. Example: | ||
+ | <source lang="java">expressionBuilder.getClassForInheritance().equals( (new ConstantExpression(LargeProject.class)).getClassForInheritance());</source> | ||
+ | |||
+ | * <source lang="java">Static public Expression getClassForInheritance(Expression expression)</source> | ||
+ | This static method follows the form of other functions in Expression, allowing the expression argument passed in to be used as the base expression. Example: | ||
+ | <source lang="java">builder.getTable("PROJECT").getField("TYPE").equal(Expression.getInheritanceType(builder.getParameter("parameter1")));</source> | ||
+ | |||
+ | |||
+ | ==Open Issues== | ||
+ | Method names for the public expression api. The getClassForInheritance() used above was arbitrarily picked because getType() is difficult to interpret when reading expression code. Other options might be getEntityType() or getClassType(). | ||
+ | |||
==Work Required== | ==Work Required== | ||
Line 15: | Line 37: | ||
# Update Processing | # Update Processing | ||
#: approx 6 days - creating expression support. | #: approx 6 days - creating expression support. | ||
+ | - EclipseLink [http://bugs.eclipse.org/277509 bug 277509] | ||
#: approx 3 days - updating Parser | #: approx 3 days - updating Parser |
Revision as of 15:28, 22 May 2009
Contents
Entity Type Expression
JPA 2.0 Root | Enhancement Request
Issue Summary
JPA 2.0 introduces JPQL expressions that allow a query to restrict results based on class types. This feature will require functionality to be added to EclipseLink.
See JPA 2.0 section 4.4.8 and 4.4.9 for details.
General Solution
Expression Support will be required that can provide a comparison with an extracted discriminator value.
Native Expression Support
through EclipseLink bug 277509 1)ReportQuery will need return Class objects that the Type expression correlates to 2) Type expressions need to be supported that take parameters and constants representing Java Classes that will evaluate to String/Int values used in these class's inheritance policy fields 3) Type expresions also need to operate on expressions representing relationships and entities, allowing them all to be compared
Public API
*public Expression getClassForInheritance()
returns a Type expression operating on the base expression. Examples:
expressionBuilder.get("project").getClassForInheritance().equals(LargeProject.class);
public Expression getClassForInheritance(Class clazz)
This returns a Type expresssion using the clazz argument to form a ConstantExpression as its base expression. Example:
expressionBuilder.getClassForInheritance().equals( (new ConstantExpression(LargeProject.class)).getClassForInheritance());
Static public Expression getClassForInheritance(Expression expression)
This static method follows the form of other functions in Expression, allowing the expression argument passed in to be used as the base expression. Example:
builder.getTable("PROJECT").getField("TYPE").equal(Expression.getInheritanceType(builder.getParameter("parameter1")));
Open Issues
Method names for the public expression api. The getClassForInheritance() used above was arbitrarily picked because getType() is difficult to interpret when reading expression code. Other options might be getEntityType() or getClassType().
Work Required
- Develop model for testing
- approx 1 day
- Update Processing
- approx 6 days - creating expression support.
- EclipseLink bug 277509
- approx 3 days - updating Parser