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

org.hibernate.dialect.pagination.Informix10LimitHandler Maven / Gradle / Ivy

There is a newer version: 6.5.0.CR2
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.dialect.pagination;

import java.util.Locale;

import org.hibernate.engine.spi.RowSelection;

public class Informix10LimitHandler extends AbstractLimitHandler {

	public static final Informix10LimitHandler INSTANCE = new Informix10LimitHandler();

	private Informix10LimitHandler() {
		// Disallow instantiation
	}

	@Override
	public String processSql(String sql, RowSelection selection) {
		final boolean hasOffset = LimitHelper.hasFirstRow( selection );
		String sqlOffset = hasOffset ? " SKIP " + selection.getFirstRow() : "";
		String sqlLimit = " FIRST " + getMaxOrLimit( selection );
		String sqlOffsetLimit = sqlOffset + sqlLimit;
		String result = new StringBuilder( sql.length() + 10 )
				.append( sql )
				.insert( sql.toLowerCase( Locale.ROOT ).indexOf( "select" ) + 6, sqlOffsetLimit ).toString();
		return result;
	}

	@Override
	public boolean supportsLimit() {
		return true;
	}

	@Override
	public boolean bindLimitParametersFirst() {
		return true;
	}

	@Override
	public boolean useMaxForLimit() {
		return false;
	}

	@Override
	public boolean supportsLimitOffset() {
		return true;
	}

	@Override
	public boolean supportsVariableLimit() {
		return false;
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy