org.tentackle.sql.AbstractSql2003Backend Maven / Gradle / Ivy
/*
* Tentackle - http://www.tentackle.org.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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 library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package org.tentackle.sql;
import java.util.Arrays;
import java.util.HashSet;
import java.util.Set;
/**
* Common to all SQL2003 backends.
*
* @author harald
*/
public abstract class AbstractSql2003Backend extends AbstractSql92Backend {
/** window function part 1. */
public static final String SQL_WINDOW_1 = "* FROM (SELECT F_O_O.*, ROW_NUMBER() OVER() AS R_O_W FROM (SELECT ";
/** window function part 2. */
public static final String SQL_WINDOW_2 = ") AS F_O_O) AS B_A_R WHERE ";
/** condition for limit and offset. */
public static final String SQL_WINDOW_LIMIT = "R_O_W <= ?";
/** condition for limit and offset. */
public static final String SQL_WINDOW_OFFSET = "R_O_W > ?";
/** set of reserved words (built only once). */
private static Set reservedWords;
@Override
public Set getReservedWords() {
if (reservedWords == null) {
reservedWords = new HashSet<>(super.getReservedWords());
reservedWords.addAll(Arrays.asList("ARRAY", "ASENSITIVE", "ATOMIC", "BIGINT", "BLOB", "BOOLEAN", "CALLED",
"CLOB", "CUBE", "CYCLE", "DEREF", "DYNAMIC", "EACH", "ELEMENT", "FILTER", "ITERATE", "LARGE",
"LATERAL", "LOCALTIME", "LOCALTIMESTAMP", "MEMBER", "MERGE", "MULTISET", "NCLOB", "NEW",
"NONE", "OVER", "PARTITION", "RANGE", "RECURSIVE", "REF", "REFERENCING", "RELEASE", "RESULT",
"ROLLUP", "ROW", "SAVEPOINT", "SCOPE", "SEARCH", "SENSITIVE", "SIMILAR", "SPECIFICTYPE",
"START", "SYMMETRIC", "SYSTEM", "TABLESAMPLE", "TREAT", "TRIGGER", "UNNEST", "WINDOW", "WITHOUT"));
}
return reservedWords;
}
@Override
public void buildSelectSql(StringBuilder sqlBuilder, boolean writeLock, int limit, int offset) {
if (limit > 0 || offset > 0) {
sqlBuilder.insert(0, SQL_WINDOW_1);
}
sqlBuilder.insert(0, SQL_SELECT);
if (writeLock) {
sqlBuilder.append(SQL_FOR_UPDATE);
}
if (limit > 0 || offset > 0) {
sqlBuilder.append(SQL_WINDOW_2);
if (offset > 0) {
sqlBuilder.append(SQL_WINDOW_OFFSET);
}
if (limit > 0) {
if (offset > 0) {
sqlBuilder.append(SQL_AND);
}
sqlBuilder.append(SQL_WINDOW_LIMIT);
}
}
}
@Override
public int setLeadingSelectParameters(BackendPreparedStatement stmt, int limit, int offset) {
return 1;
}
@Override
public int setTrailingSelectParameters(BackendPreparedStatement stmt, int index, int limit, int offset) {
if (offset > 0) {
stmt.setInt(index++, offset);
}
if (limit > 0) {
stmt.setInt(index++, limit);
}
return index;
}
@Override
public boolean supportsSequences() {
return true;
}
@Override
public String sqlNextFromSequene(String name) {
return "SELECT NEXT VALUE FOR " + name;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy