OPENJPA-851: enhanced bi-directional map support in

update operation

git-svn-id: https://svn.apache.org/repos/asf/openjpa/trunk@734617 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Fay Wang 2009-01-15 07:05:13 +00:00
parent 388c56f05f
commit 88f288b47a
3 changed files with 54 additions and 35 deletions

View File

@ -201,6 +201,9 @@ public class HandlerRelationMapTableFieldStrategy
public void update(OpenJPAStateManager sm, JDBCStore store, RowManager rm) public void update(OpenJPAStateManager sm, JDBCStore store, RowManager rm)
throws SQLException { throws SQLException {
if (field.getMappedBy() != null)
return;
Map map = (Map) sm.fetchObject(field.getIndex()); Map map = (Map) sm.fetchObject(field.getIndex());
ChangeTracker ct = null; ChangeTracker ct = null;
if (map instanceof Proxy) { if (map instanceof Proxy) {

View File

@ -230,43 +230,49 @@ public class RelationFieldStrategy
if (rel == null) if (rel == null)
return; return;
ClassMetaData meta = rel.getMetaData(); ClassMetaData meta = rel.getMetaData();
FieldMapping mapField = getMapField(meta);
// there is no bi-directional map field
if (mapField == null)
return;
Map mapObj = (Map)rel.fetchObjectField(mapField.getIndex());
Object keyObj = getMapKeyObj(mapObj, sm.getPersistenceCapable());
ValueMapping key = mapField.getKeyMapping();
if (!key.isEmbedded()) {
if (keyObj instanceof PersistenceCapable) {
OpenJPAStateManager keySm = RelationStrategies.
getStateManager(keyObj, store.getContext());
// key is an entity
ForeignKey fk = mapField.getKeyMapping().
getForeignKey();
ColumnIO io = new ColumnIO();
row.setForeignKey(fk, io, keySm);
}
} else {
// key is an embeddable or basic type
FieldStrategy strategy = mapField.getStrategy();
if (strategy instanceof
HandlerRelationMapTableFieldStrategy) {
HandlerRelationMapTableFieldStrategy strat =
(HandlerRelationMapTableFieldStrategy) strategy;
Column[] kcols = strat.getKeyColumns((ClassMapping)meta);
ColumnIO kio = strat.getKeyColumnIO();
HandlerStrategies.set(key, keyObj, store, row, kcols,
kio, true);
}
}
}
private FieldMapping getMapField(ClassMetaData meta) {
FieldMapping[] fields = ((ClassMapping)meta).getFieldMappings(); FieldMapping[] fields = ((ClassMapping)meta).getFieldMappings();
for (int i = 0; i < fields.length; i++) { for (int i = 0; i < fields.length; i++) {
FieldMetaData mappedBy = fields[i].getMappedByMetaData(); FieldMetaData mappedBy = fields[i].getMappedByMetaData();
if (mappedBy == field) { if (fields[i].getDeclaredTypeCode() == JavaTypes.MAP &&
if (fields[i].getDeclaredTypeCode() == JavaTypes.MAP) { mappedBy == field)
Map mapObj = (Map)rel.fetchObjectField( return fields[i];
fields[i].getIndex());
Object keyObj = getMapKeyObj(mapObj,
sm.getPersistenceCapable());
ValueMapping key = fields[i].getKeyMapping();
if (!key.isEmbedded()) {
if (keyObj instanceof PersistenceCapable) {
OpenJPAStateManager keySm = RelationStrategies.
getStateManager(keyObj, store.getContext());
// key is an entity
ForeignKey fk = fields[i].getKeyMapping().
getForeignKey();
ColumnIO io = new ColumnIO();
row.setForeignKey(fk, io, keySm);
}
} else {
// key is an embeddable or basic type
FieldStrategy strategy = fields[i].getStrategy();
if (strategy instanceof
HandlerRelationMapTableFieldStrategy) {
HandlerRelationMapTableFieldStrategy strat =
(HandlerRelationMapTableFieldStrategy) strategy;
Column[] kcols = strat.getKeyColumns((ClassMapping)meta);
ColumnIO kio = strat.getKeyColumnIO();
HandlerStrategies.set(key, keyObj, store, row, kcols,
kio, true);
}
}
break;
}
}
} }
return null;
} }
private Object getMapKeyObj(Map mapObj, Object value) { private Object getMapKeyObj(Map mapObj, Object value) {
@ -294,8 +300,12 @@ public class RelationFieldStrategy
&& field.isBidirectionalJoinTableMappingNonOwner()) ? && field.isBidirectionalJoinTableMappingNonOwner()) ?
Row.ACTION_DELETE : Row.ACTION_UPDATE; Row.ACTION_DELETE : Row.ACTION_UPDATE;
Row row = field.getRow(sm, store, rm, action); Row row = field.getRow(sm, store, rm, action);
if (row != null) if (row != null) {
field.setForeignKey(row, rel); field.setForeignKey(row, rel);
// this is for bi-directional maps, the key and value of the
// map are stored in the table of the mapped-by entity
setMapKey(sm, rel, store, row);
}
} }
} }
@ -325,6 +335,9 @@ public class RelationFieldStrategy
fk.getDeleteAction() == ForeignKey.ACTION_CASCADE) { fk.getDeleteAction() == ForeignKey.ACTION_CASCADE) {
Row row = field.getRow(sm, store, rm, Row.ACTION_DELETE); Row row = field.getRow(sm, store, rm, Row.ACTION_DELETE);
row.setForeignKey(fk, null, rel); row.setForeignKey(fk, null, rel);
// this is for bi-directional maps, the key and value of the
// map are stored in the table of the mapped-by entity
setMapKey(sm, rel, store, row);
} }
} }
} }

View File

@ -243,6 +243,9 @@ public class RelationRelationMapTableFieldStrategy
public void update(OpenJPAStateManager sm, JDBCStore store, RowManager rm) public void update(OpenJPAStateManager sm, JDBCStore store, RowManager rm)
throws SQLException { throws SQLException {
if (field.getMappedBy() != null)
return;
Map map = (Map) sm.fetchObject(field.getIndex()); Map map = (Map) sm.fetchObject(field.getIndex());
ChangeTracker ct = null; ChangeTracker ct = null;
if (map instanceof Proxy) { if (map instanceof Proxy) {