/*
 * Hibernate, Relational Persistence for Idiomatic Java
 *
 * Copyright (c) 2008, 2013, Red Hat Inc. or third-party contributors as
 * indicated by the @author tags or express copyright attribution
 * statements applied by the authors.  All third-party contributions are
 * distributed under license by Red Hat Inc.
 *
 * This copyrighted material is made available to anyone wishing to use, modify,
 * copy, or redistribute it subject to the terms and conditions of the GNU
 * Lesser General Public License, as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
 * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public License
 * for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this distribution; if not, write to:
 * Free Software Foundation, Inc.
 * 51 Franklin Street, Fifth Floor
 * Boston, MA  02110-1301  USA
 */
package org.hibernate.engine.query.spi;

import java.io.Serializable;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;

import org.hibernate.QueryParameterException;
import org.hibernate.type.Type;

Encapsulates metadata about parameters encountered within a query.
Author:Steve Ebersole
/** * Encapsulates metadata about parameters encountered within a query. * * @author Steve Ebersole */
public class ParameterMetadata implements Serializable { private static final OrdinalParameterDescriptor[] EMPTY_ORDINALS = new OrdinalParameterDescriptor[0]; private final OrdinalParameterDescriptor[] ordinalDescriptors; private final Map<String,NamedParameterDescriptor> namedDescriptorMap;
Instantiates a ParameterMetadata container.
Params:
  • ordinalDescriptors – Descriptors of the ordinal parameters
  • namedDescriptorMap – Descriptors of the named parameters
/** * Instantiates a ParameterMetadata container. * * @param ordinalDescriptors Descriptors of the ordinal parameters * @param namedDescriptorMap Descriptors of the named parameters */
public ParameterMetadata( OrdinalParameterDescriptor[] ordinalDescriptors, Map<String,NamedParameterDescriptor> namedDescriptorMap) { if ( ordinalDescriptors == null ) { this.ordinalDescriptors = EMPTY_ORDINALS; } else { final OrdinalParameterDescriptor[] copy = new OrdinalParameterDescriptor[ ordinalDescriptors.length ]; System.arraycopy( ordinalDescriptors, 0, copy, 0, ordinalDescriptors.length ); this.ordinalDescriptors = copy; } if ( namedDescriptorMap == null ) { this.namedDescriptorMap = java.util.Collections.emptyMap(); } else { final int size = (int) ( ( namedDescriptorMap.size() / .75 ) + 1 ); final Map<String,NamedParameterDescriptor> copy = new HashMap<String,NamedParameterDescriptor>( size ); copy.putAll( namedDescriptorMap ); this.namedDescriptorMap = java.util.Collections.unmodifiableMap( copy ); } } public int getOrdinalParameterCount() { return ordinalDescriptors.length; }
Get the descriptor for an ordinal parameter given its position
Params:
  • position – The position (1 based)
Throws:
Returns:The ordinal parameter descriptor
/** * Get the descriptor for an ordinal parameter given its position * * @param position The position (1 based) * * @return The ordinal parameter descriptor * * @throws QueryParameterException If the position is out of range */
public OrdinalParameterDescriptor getOrdinalParameterDescriptor(int position) { if ( position < 1 || position > ordinalDescriptors.length ) { throw new QueryParameterException( "Position beyond number of declared ordinal parameters. " + "Remember that ordinal parameters are 1-based! Position: " + position ); } return ordinalDescriptors[position - 1]; }
Deprecated.
Params:
  • position – The position
Returns:The type
Deprecated:Use OrdinalParameterDescriptor.getExpectedType() from the getOrdinalParameterDescriptor return instead
/** * Deprecated. * * @param position The position * * @return The type * * @deprecated Use {@link OrdinalParameterDescriptor#getExpectedType()} from the * {@link #getOrdinalParameterDescriptor} return instead */
@Deprecated public Type getOrdinalParameterExpectedType(int position) { return getOrdinalParameterDescriptor( position ).getExpectedType(); }
Deprecated.
Params:
  • position – The position
Returns:The source location
Deprecated:Use OrdinalParameterDescriptor.getSourceLocation() from the getOrdinalParameterDescriptor return instead
/** * Deprecated. * * @param position The position * * @return The source location * * @deprecated Use {@link OrdinalParameterDescriptor#getSourceLocation()} from the * {@link #getOrdinalParameterDescriptor} return instead */
@Deprecated public int getOrdinalParameterSourceLocation(int position) { return getOrdinalParameterDescriptor( position ).getSourceLocation(); }
Access to the names of all named parameters
Returns:The named parameter names
/** * Access to the names of all named parameters * * @return The named parameter names */
public Set<String> getNamedParameterNames() { return namedDescriptorMap.keySet(); }
Get the descriptor for a named parameter given the name
Params:
  • name – The name of the parameter to locate
Throws:
Returns:The named parameter descriptor
/** * Get the descriptor for a named parameter given the name * * @param name The name of the parameter to locate * * @return The named parameter descriptor * * @throws QueryParameterException If the name could not be resolved to a named parameter */
public NamedParameterDescriptor getNamedParameterDescriptor(String name) { final NamedParameterDescriptor meta = namedDescriptorMap.get( name ); if ( meta == null ) { throw new QueryParameterException( "could not locate named parameter [" + name + "]" ); } return meta; }
Deprecated.
Params:
  • name – The name of the parameter
Returns:The type
Deprecated:Use NamedParameterDescriptor.getExpectedType() from the getNamedParameterDescriptor return instead
/** * Deprecated. * * @param name The name of the parameter * * @return The type * * @deprecated Use {@link NamedParameterDescriptor#getExpectedType()} from the * {@link #getNamedParameterDescriptor} return instead */
@Deprecated public Type getNamedParameterExpectedType(String name) { return getNamedParameterDescriptor( name ).getExpectedType(); }
Deprecated.
Params:
  • name – The name of the parameter
Returns:The type
Deprecated:Use NamedParameterDescriptor.getSourceLocations() from the getNamedParameterDescriptor return instead
/** * Deprecated. * * @param name The name of the parameter * * @return The type * * @deprecated Use {@link NamedParameterDescriptor#getSourceLocations()} from the * {@link #getNamedParameterDescriptor} return instead */
@Deprecated public int[] getNamedParameterSourceLocations(String name) { return getNamedParameterDescriptor( name ).getSourceLocations(); } }