|
Hibernate example source code file (AggregationFunction.java)
The Hibernate AggregationFunction.java source code/* * Hibernate, Relational Persistence for Idiomatic Java * * Copyright (c) 2009 by Red Hat Inc and/or its affiliates or by * third-party contributors as indicated by either @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.ejb.criteria.expression.function; import java.io.Serializable; import javax.persistence.criteria.Expression; import org.hibernate.ejb.criteria.CriteriaBuilderImpl; import org.hibernate.ejb.criteria.CriteriaQueryCompiler; import org.hibernate.ejb.criteria.expression.LiteralExpression; /** * Models SQL aggregation functions (<tt>MIN, MAX, COUNT, etc). * * @author Steve Ebersole */ public class AggregationFunction<T> extends ParameterizedFunctionExpression<T> implements Serializable { /** * Constructs an aggregation function with a single literal argument. * * @param criteriaBuilder The query builder instance. * @param returnType The function return type. * @param functionName The name of the function. * @param argument The literal argument */ @SuppressWarnings({ "unchecked" }) public AggregationFunction( CriteriaBuilderImpl criteriaBuilder, Class<T> returnType, String functionName, Object argument) { this( criteriaBuilder, returnType, functionName, new LiteralExpression( criteriaBuilder, argument ) ); } /** * Constructs an aggregation function with a single literal argument. * * @param criteriaBuilder The query builder instance. * @param returnType The function return type. * @param functionName The name of the function. * @param argument The argument */ public AggregationFunction( CriteriaBuilderImpl criteriaBuilder, Class<T> returnType, String functionName, Expression<?> argument) { super( criteriaBuilder, returnType, functionName, argument ); } @Override public boolean isAggregation() { return true; } /** * Implementation of a <tt>COUNT function providing convenience in construction. * <p/> * Parameterized as {@link Long} because thats what JPA states * that the return from <tt>COUNT should be. */ public static class COUNT extends AggregationFunction<Long> { public static final String NAME = "count"; private final boolean distinct; public COUNT(CriteriaBuilderImpl criteriaBuilder, Expression<?> expression, boolean distinct) { super( criteriaBuilder, Long.class, NAME , expression ); this.distinct = distinct; } @Override protected void renderArguments(StringBuilder buffer, CriteriaQueryCompiler.RenderingContext renderingContext) { if ( isDistinct() ) { buffer.append( "distinct " ); } super.renderArguments( buffer, renderingContext ); } public boolean isDistinct() { return distinct; } } /** * Implementation of a <tt>AVG function providing convenience in construction. * <p/> * Parameterized as {@link Double} because thats what JPA states that the return from <tt>AVG should be. */ public static class AVG extends AggregationFunction<Double> { public static final String NAME = "avg"; public AVG(CriteriaBuilderImpl criteriaBuilder, Expression<? extends Number> expression) { super( criteriaBuilder, Double.class, NAME, expression ); } } /** * Implementation of a <tt>SUM function providing convenience in construction. * <p/> * Parameterized as {@link Number N extends Number} because thats what JPA states * that the return from <tt>SUM should be. */ public static class SUM<N extends Number> extends AggregationFunction Other Hibernate examples (source code examples)Here is a short list of links related to this Hibernate AggregationFunction.java source code file: |
... this post is sponsored by my books ... | |
#1 New Release! |
FP Best Seller |
Copyright 1998-2021 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.