/*
* Hibernate, Relational Persistence for Idiomatic Java
*
* License: GNU Lesser General Public License (LGPL), version 2.1 or later.
* See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>.
*/
package org.hibernate.mapping;
import org.hibernate.MappingException;
import org.hibernate.boot.registry.classloading.spi.ClassLoaderService;
import org.hibernate.boot.registry.classloading.spi.ClassLoadingException;
import org.hibernate.boot.spi.MetadataBuildingContext;
import org.hibernate.boot.spi.MetadataImplementor;
import org.hibernate.type.CollectionType;
import org.hibernate.type.PrimitiveType;
An array mapping has a primary key consisting of the key columns + index column.
Author: Gavin King
/**
* An array mapping has a primary key consisting of the key columns + index column.
*
* @author Gavin King
*/
public class Array extends List {
private String elementClassName;
Deprecated: Use Array(MetadataBuildingContext, PersistentClass)
instead.
/**
* @deprecated Use {@link Array#Array(MetadataBuildingContext, PersistentClass)} instead.
*/
@Deprecated
public Array(MetadataImplementor metadata, PersistentClass owner) {
super( metadata, owner );
}
public Array(MetadataBuildingContext buildingContext, PersistentClass owner) {
super( buildingContext, owner );
}
public Class getElementClass() throws MappingException {
if ( elementClassName == null ) {
org.hibernate.type.Type elementType = getElement().getType();
return isPrimitiveArray()
? ( (PrimitiveType) elementType ).getPrimitiveClass()
: elementType.getReturnedClass();
}
else {
try {
return getMetadata().getMetadataBuildingOptions()
.getServiceRegistry()
.getService( ClassLoaderService.class )
.classForName( elementClassName );
}
catch (ClassLoadingException e) {
throw new MappingException( e );
}
}
}
@Override
public CollectionType getDefaultCollectionType() throws MappingException {
return getMetadata().getTypeResolver()
.getTypeFactory()
.array( getRole(), getReferencedPropertyName(), getElementClass() );
}
@Override
public boolean isArray() {
return true;
}
Returns: Returns the elementClassName.
/**
* @return Returns the elementClassName.
*/
public String getElementClassName() {
return elementClassName;
}
Params: - elementClassName – The elementClassName to set.
/**
* @param elementClassName The elementClassName to set.
*/
public void setElementClassName(String elementClassName) {
this.elementClassName = elementClassName;
}
@Override
public Object accept(ValueVisitor visitor) {
return visitor.accept( this );
}
}