Java tutorial
/* * 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 <http://www.gnu.org/licenses/lgpl-2.1.html>. */ package org.hibernate.dialect; import org.hibernate.dialect.function.StandardSQLFunction; import org.hibernate.dialect.pagination.AbstractLimitHandler; import org.hibernate.dialect.pagination.LimitHandler; import org.hibernate.dialect.pagination.LimitHelper; import org.hibernate.engine.spi.RowSelection; import org.hibernate.type.StandardBasicTypes; /** * An SQL dialect for Firebird. * * @author Reha CENANI */ public class FirebirdDialect extends InterbaseDialect { private static final AbstractLimitHandler LIMIT_HANDLER = new AbstractLimitHandler() { @Override public String processSql(String sql, RowSelection selection) { final boolean hasOffset = LimitHelper.hasFirstRow(selection); return new StringBuilder(sql.length() + 20).append(sql) .insert(6, hasOffset ? " first ? skip ?" : " first ?").toString(); } @Override public boolean supportsLimit() { return true; } @Override public boolean bindLimitParametersFirst() { return true; } @Override public boolean bindLimitParametersInReverseOrder() { return true; } }; public FirebirdDialect() { super(); registerFunction("replace", new StandardSQLFunction("replace", StandardBasicTypes.STRING)); } @Override public String getDropSequenceString(String sequenceName) { return "drop generator " + sequenceName; } @Override public String getLimitString(String sql, boolean hasOffset) { return new StringBuilder(sql.length() + 20).append(sql) .insert(6, hasOffset ? " first ? skip ?" : " first ?").toString(); } @Override public boolean bindLimitParametersFirst() { return true; } @Override public boolean bindLimitParametersInReverseOrder() { return true; } @Override public LimitHandler getLimitHandler() { return LIMIT_HANDLER; } }