All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.hibernate.envers.internal.revisioninfo.RevisionInfoQueryCreator Maven / Gradle / Ivy

There is a newer version: 7.0.0.Alpha3
Show newest version
/*
 * 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 .
 */
package org.hibernate.envers.internal.revisioninfo;

import java.util.Date;
import java.util.Set;

import org.hibernate.Session;
import org.hibernate.query.Query;

/**
 * @author Adam Warski (adam at warski dot org)
 * @author Lukasz Antoniak (lukasz dot antoniak at gmail dot com)
 * @author Chris Cranford
 */
public class RevisionInfoQueryCreator {
	private static final String REVISION_DATE_QUERY = "SELECT %s FROM %s WHERE %s = :revision";
	private static final String REVISION_DATE_QUERY_PARAMETER = "revision";
	private static final String REVISION_NUMBER_FOR_DATE_QUERY = "SELECT MAX(%s) FROM %s WHERE %s <= :date";
	private static final String REVISION_NUMBER_FOR_DATE_QUERY_PARAMETER = "date";
	private static final String REVISIONS_QUERY = "FROM %s WHERE %s IN (:revisions)";
	private static final String REVISIONS_QUERY_PARAMETER = "revisions";

	private final String revisionInfoEntityName;
	private final String revisionInfoIdName;
	private final String revisionInfoTimestampName;
	private final boolean timestampAsDate;

	public RevisionInfoQueryCreator(
			String revisionInfoEntityName, String revisionInfoIdName,
			String revisionInfoTimestampName, boolean timestampAsDate) {
		this.revisionInfoEntityName = revisionInfoEntityName;
		this.revisionInfoIdName = revisionInfoIdName;
		this.revisionInfoTimestampName = revisionInfoTimestampName;
		this.timestampAsDate = timestampAsDate;
	}

	public Query getRevisionDateQuery(Session session, Number revision) {
		return session.createQuery(
				String.format(
						REVISION_DATE_QUERY,
						revisionInfoTimestampName,
						revisionInfoEntityName,
						revisionInfoIdName
				)
		).setParameter( REVISION_DATE_QUERY_PARAMETER, revision );
	}

	public Query getRevisionNumberForDateQuery(Session session, Date date) {
		return session.createQuery(
				String.format(
						REVISION_NUMBER_FOR_DATE_QUERY,
						revisionInfoIdName,
						revisionInfoEntityName,
						revisionInfoTimestampName
				)
		).setParameter( REVISION_NUMBER_FOR_DATE_QUERY_PARAMETER, timestampAsDate ? date : date.getTime() );
	}

	public Query getRevisionsQuery(Session session, Set revisions) {
		return session.createQuery(
				String.format( REVISIONS_QUERY, revisionInfoEntityName, revisionInfoIdName )
		).setParameter( REVISIONS_QUERY_PARAMETER, revisions );
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy