org.datanucleus.store.rdbms.mapping.MappingHelper Maven / Gradle / Ivy
/**********************************************************************
Copyright (c) 2009 Andy Jefferson and others. All rights reserved.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
Contributors:
...
**********************************************************************/
package org.datanucleus.store.rdbms.mapping;
import java.lang.reflect.Field;
import java.math.BigDecimal;
import java.sql.ResultSet;
import org.datanucleus.ClassLoaderResolver;
import org.datanucleus.ExecutionContext;
import org.datanucleus.FetchPlan;
import org.datanucleus.exceptions.NucleusException;
import org.datanucleus.identity.IdentityUtils;
import org.datanucleus.metadata.AbstractClassMetaData;
import org.datanucleus.metadata.AbstractMemberMetaData;
import org.datanucleus.metadata.ClassMetaData;
import org.datanucleus.state.DNStateManager;
import org.datanucleus.store.FieldValues;
import org.datanucleus.store.fieldmanager.FieldManager;
import org.datanucleus.store.rdbms.RDBMSStoreManager;
import org.datanucleus.store.rdbms.fieldmanager.ResultSetGetter;
import org.datanucleus.store.rdbms.mapping.java.JavaTypeMapping;
import org.datanucleus.store.rdbms.query.StatementClassMapping;
import org.datanucleus.store.rdbms.query.StatementMappingIndex;
import org.datanucleus.store.rdbms.table.DatastoreClass;
import org.datanucleus.store.types.converters.TypeConversionHelper;
import org.datanucleus.util.Localiser;
import org.datanucleus.util.NucleusLogger;
/**
* Helper class for handling mappings.
*/
public class MappingHelper
{
private MappingHelper(){}
/**
* Convenience method to return an array of positions for datastore columns for the supplied
* mapping and the initial position value. For example if the mapping has a single datastore
* column and the initial position is 1 then returns the array {1}.
* @param initialPosition the initialPosition
* @param mapping the Mapping
* @return an array containing indexes for parameters
*/
public static int[] getMappingIndices(int initialPosition, JavaTypeMapping mapping)
{
if (mapping.getNumberOfColumnMappings() == 0)
{
return new int[]{initialPosition};
}
int parameter[] = new int[mapping.getNumberOfColumnMappings()];
for (int i=0; i 0)
{
idValue = mapping.getColumnMapping(0).getObject(rs, resultIndexes[0]);
}
else
{
// 1-1 bidirectional "mapped-by" relation, so use ID mappings of related class to retrieve the value
if (mapping.getReferenceMapping() != null) //TODO why is it null for PC concrete classes?
{
return mapping.getReferenceMapping().getObject(ec, rs, resultIndexes);
}
Class fieldType = mapping.getMemberMetaData().getType();
JavaTypeMapping referenceMapping = mapping.getStoreManager().getDatastoreClass(fieldType.getName(), ec.getClassLoaderResolver()).getIdMapping();
idValue = referenceMapping.getColumnMapping(0).getObject(rs, resultIndexes[0]);
}
if (idValue == null)
{
return null;
}
return ec.getNucleusContext().getIdentityManager().getDatastoreId(mapping.getType(), idValue);
}
/**
* Get the application identity for the persistable instance from the passed result set row.
* @param ec ExecutionContext
* @param mapping The Java Type mapping for the instance
* @param rs the ResultSet
* @param resultIndexes indexes of the ResultSet for the PK field(s)
* @param cmd the AbstractClassMetaData
* @return the id
*/
public static Object getApplicationIdentityForResultSetRow(final ExecutionContext ec, JavaTypeMapping mapping, final ResultSet rs, int[] resultIndexes, AbstractClassMetaData cmd)
{
// Check for null FK
if (((RDBMSStoreManager)ec.getStoreManager()).getResultValueAtPosition(rs, mapping, resultIndexes[0]) == null)
{
// Assumption : if the first param is null, then the field is null
return null;
}
// Abstract class
if (((ClassMetaData)cmd).isAbstract() && cmd.getObjectidClass() != null)
{
return getObjectIdentityForAbstractClass(ec, mapping, rs, resultIndexes, cmd);
}
int totalFieldCount = cmd.getNoOfManagedMembers() + cmd.getNoOfInheritedManagedMembers();
final StatementMappingIndex[] statementExpressionIndex = new StatementMappingIndex[totalFieldCount];
ClassLoaderResolver clr = ec.getClassLoaderResolver();
DatastoreClass datastoreClass = mapping.getStoreManager().getDatastoreClass(cmd.getFullClassName(), clr);
final int[] pkFieldNumbers = cmd.getPKMemberPositions();
int paramIndex = 0;
for (int i=0; i