OPENJPA-967 JPA2 Query support for embeddable MapKey improvement/rework

git-svn-id: https://svn.apache.org/repos/asf/openjpa/trunk@764279 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Catalina Wei 2009-04-12 03:19:46 +00:00
parent 8c31381f18
commit 4da7ad3790
4 changed files with 33 additions and 23 deletions

View File

@ -809,31 +809,18 @@ public class PCPath
LRSMapFieldStrategy strategy = (LRSMapFieldStrategy) LRSMapFieldStrategy strategy = (LRSMapFieldStrategy)
pstate.field.getStrategy(); pstate.field.getStrategy();
ClassMapping mapping = pstate.field.getKeyMapping().getTypeMapping(); ClassMapping mapping = pstate.field.getKeyMapping().getTypeMapping();
if (strategy instanceof HandlerRelationMapTableFieldStrategy)
strategy.selectKey(sel, mapping, null, ctx.store, ctx.fetch, strategy.selectKey(sel, mapping, null, ctx.store, ctx.fetch,
pstate.joins); pstate.joins);
else {
sel.select(_class.getPrimaryKeyColumns(), pstate.joins);
FieldMapping[] fms = mapping.getDefinedFieldMappings();
for (int i = 0; i < fms.length; i++)
sel.select(fms[i].getColumns(), pstate.joins);
}
} }
private Object loadEmbeddedMapKey(ExpContext ctx, ExpState state, private Object loadEmbeddedMapKey(ExpContext ctx, ExpState state,
Result res) throws SQLException { Result res) throws SQLException {
PathExpState pstate = (PathExpState) state; PathExpState pstate = (PathExpState) state;
validateMapStrategy(pstate.field.getStrategy()); validateMapStrategy(pstate.field.getStrategy());
FieldMapping fmd = (FieldMapping) pstate.field.getKey().
getValueMappedByMetaData();
LRSMapFieldStrategy strategy = LRSMapFieldStrategy strategy =
(LRSMapFieldStrategy) pstate.field.getStrategy(); (LRSMapFieldStrategy) pstate.field.getStrategy();
if (strategy instanceof HandlerRelationMapTableFieldStrategy)
return strategy.loadKey(null, ctx.store, ctx.fetch, res, return strategy.loadKey(null, ctx.store, ctx.fetch, res,
pstate.joins); pstate.joins);
else
return fmd.getStrategy().
loadProjection(ctx.store, ctx.fetch, res, pstate.joins);
} }
public void calculateValue(Select sel, ExpContext ctx, ExpState state, public void calculateValue(Select sel, ExpContext ctx, ExpState state,

View File

@ -47,7 +47,11 @@ public class EmbeddedClassStrategy
ClassMappingInfo info = cls.getMappingInfo(); ClassMappingInfo info = cls.getMappingInfo();
info.assertNoSchemaComponents(cls, true); info.assertNoSchemaComponents(cls, true);
ClassMapping owner = vm.getFieldMapping().getDefiningMapping(); ClassMapping owner = null;
if (vm.getValueMappedByMapping() != null)
owner = vm.getValueMappedByMapping().getDefiningMapping();
else
owner = vm.getFieldMapping().getDefiningMapping();
cls.setIdentityType(owner.getIdentityType()); cls.setIdentityType(owner.getIdentityType());
cls.setObjectIdType(owner.getObjectIdType(), cls.setObjectIdType(owner.getObjectIdType(),
owner.isObjectIdTypeShared()); owner.isObjectIdTypeShared());

View File

@ -81,12 +81,22 @@ public class RelationMapInverseKeyFieldStrategy
public void selectKey(Select sel, ClassMapping key, OpenJPAStateManager sm, public void selectKey(Select sel, ClassMapping key, OpenJPAStateManager sm,
JDBCStore store, JDBCFetchConfiguration fetch, Joins joins) { JDBCStore store, JDBCFetchConfiguration fetch, Joins joins) {
ValueMapping vm = field.getKeyMapping();
if (vm.isEmbedded())
sel.select(key, field.getKeyMapping().getSelectSubclasses(),
store, fetch, JDBCFetchConfiguration.EAGER_NONE, joins);
else
throw new InternalException(); throw new InternalException();
} }
public Object loadKey(OpenJPAStateManager sm, JDBCStore store, public Object loadKey(OpenJPAStateManager sm, JDBCStore store,
JDBCFetchConfiguration fetch, Result res, Joins joins) JDBCFetchConfiguration fetch, Result res, Joins joins)
throws SQLException { throws SQLException {
ValueMapping vm = field.getKeyMapping();
if (vm.isEmbedded())
return vm.getValueMappedByMapping().
loadProjection(store, fetch, res, joins);
else
throw new InternalException(); throw new InternalException();
} }

View File

@ -22,7 +22,6 @@ import java.sql.SQLException;
import java.util.Collection; import java.util.Collection;
import java.util.Map; import java.util.Map;
import org.apache.openjpa.conf.OpenJPAConfiguration;
import org.apache.openjpa.jdbc.kernel.JDBCFetchConfiguration; import org.apache.openjpa.jdbc.kernel.JDBCFetchConfiguration;
import org.apache.openjpa.jdbc.kernel.JDBCStore; import org.apache.openjpa.jdbc.kernel.JDBCStore;
import org.apache.openjpa.jdbc.meta.ClassMapping; import org.apache.openjpa.jdbc.meta.ClassMapping;
@ -81,12 +80,22 @@ public class RelationMapTableFieldStrategy
public void selectKey(Select sel, ClassMapping key, OpenJPAStateManager sm, public void selectKey(Select sel, ClassMapping key, OpenJPAStateManager sm,
JDBCStore store, JDBCFetchConfiguration fetch, Joins joins) { JDBCStore store, JDBCFetchConfiguration fetch, Joins joins) {
ValueMapping vm = field.getKeyMapping();
if (vm.isEmbedded())
sel.select(key, field.getKeyMapping().getSelectSubclasses(),
store, fetch, JDBCFetchConfiguration.EAGER_NONE, joins);
else
throw new InternalException(); throw new InternalException();
} }
public Object loadKey(OpenJPAStateManager sm, JDBCStore store, public Object loadKey(OpenJPAStateManager sm, JDBCStore store,
JDBCFetchConfiguration fetch, Result res, Joins joins) JDBCFetchConfiguration fetch, Result res, Joins joins)
throws SQLException { throws SQLException {
ValueMapping vm = field.getKeyMapping();
if (vm.isEmbedded())
return vm.getValueMappedByMapping().
loadProjection(store, fetch, res, joins);
else
throw new InternalException(); throw new InternalException();
} }