org.hibernate.envers.internal.revisioninfo.RevisionInfoQueryCreator Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of hibernate-envers-jakarta Show documentation
Show all versions of hibernate-envers-jakarta Show documentation
Hibernate's entity version (audit/history) support Jakarta edition
/*
* 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 - 2025 Weber Informatics LLC | Privacy Policy