Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
com.landawn.abacus.util.CQLBuilder Maven / Gradle / Ivy
/*
* Copyright (c) 2016, Haiyang Li.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.landawn.abacus.util;
import static com.landawn.abacus.util.SQLBuilder._COMMA_SPACE;
import static com.landawn.abacus.util.SQLBuilder._DELETE;
import static com.landawn.abacus.util.SQLBuilder._INSERT;
import static com.landawn.abacus.util.SQLBuilder._SELECT;
import static com.landawn.abacus.util.SQLBuilder._SPACE_AND_SPACE;
import static com.landawn.abacus.util.SQLBuilder._SPACE_AS_SPACE;
import static com.landawn.abacus.util.SQLBuilder._SPACE_EQUAL_SPACE;
import static com.landawn.abacus.util.SQLBuilder._SPACE_FROM_SPACE;
import static com.landawn.abacus.util.SQLBuilder._SPACE_INTO_SPACE;
import static com.landawn.abacus.util.SQLBuilder._SPACE_LIMIT_SPACE;
import static com.landawn.abacus.util.SQLBuilder._SPACE_ORDER_BY_SPACE;
import static com.landawn.abacus.util.SQLBuilder._SPACE_SET_SPACE;
import static com.landawn.abacus.util.SQLBuilder._SPACE_USING_SPACE;
import static com.landawn.abacus.util.SQLBuilder._SPACE_VALUES_SPACE;
import static com.landawn.abacus.util.SQLBuilder._SPACE_WHERE_SPACE;
import static com.landawn.abacus.util.SQLBuilder._UPDATE;
import static com.landawn.abacus.util.WD._PARENTHESES_L;
import static com.landawn.abacus.util.WD._PARENTHESES_R;
import static com.landawn.abacus.util.WD._SPACE;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Date;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.atomic.AtomicInteger;
import com.landawn.abacus.DirtyMarker;
import com.landawn.abacus.annotation.Beta;
import com.landawn.abacus.condition.Between;
import com.landawn.abacus.condition.Binary;
import com.landawn.abacus.condition.Cell;
import com.landawn.abacus.condition.Condition;
import com.landawn.abacus.condition.ConditionFactory.L;
import com.landawn.abacus.condition.Expression;
import com.landawn.abacus.condition.In;
import com.landawn.abacus.condition.Junction;
import com.landawn.abacus.condition.SubQuery;
import com.landawn.abacus.exception.AbacusException;
import com.landawn.abacus.logging.Logger;
import com.landawn.abacus.logging.LoggerFactory;
/**
* It's easier to write/maintain the CQL by CQLBuilder
and more efficient, comparing to write Cassandra CQL in plain text.
* The cql()
or pair()
method must be called to release resources.
* Here is a sample:
*
* String cql = NE.insert("gui", "firstName", "lastName").into("account").cql();
* // CQL: INSERT INTO account (gui, first_name, last_name) VALUES (:gui, :firstName, :lastName)
*
*
* @since 0.8
*
* @author Haiyang Li
*/
public abstract class CQLBuilder {
private static final Logger logger = LoggerFactory.getLogger(CQLBuilder.class);
public static final String DISTINCT = WD.DISTINCT;
public static final String COUNT_ALL = "count(*)";
private static final Map> entityTablePropColumnNameMap = new ObjectPool<>(1024);
private static final Map tableDeleteFrom = new ConcurrentHashMap<>();
private static final Map, List> classPropNameListPool = new ConcurrentHashMap<>();
// private static final Map, Set> classPropNameSetPool = new ConcurrentHashMap<>();
private static final AtomicInteger activeStringBuilderCounter = new AtomicInteger();
static final char[] _SPACE_USING_TIMESTAMP_SPACE = " USING TIMESTAMP ".toCharArray();
static final char[] _SPACE_USING_TTL_SPACE = " USING TTL ".toCharArray();
static final char[] _SPACE_IF_SPACE = " IF ".toCharArray();
static final char[] _SPACE_IF_EXISTS = " IF EXISTS".toCharArray();
static final char[] _SPACE_IF_NOT_EXISTS = " IF NOT EXISTS".toCharArray();
static final char[] _SPACE_ALLOW_FILTERING = " ALLOW FILTERING".toCharArray();
private final NamingPolicy namingPolicy;
private final CQLPolicy cqlPolicy;
private final List parameters = new ArrayList<>();
private StringBuilder sb;
private OperationType op;
private String tableName;
private String predicates;
private String[] columnNames;
private Collection columnNameList;
private Map columnAliases;
private Map props;
private Collection> propsList;
CQLBuilder(final NamingPolicy namingPolicy, final CQLPolicy cqlPolicy) {
if (activeStringBuilderCounter.incrementAndGet() > 1024) {
logger.error("Too many(" + activeStringBuilderCounter.get()
+ ") StringBuilder instances are created in CQLBuilder. The method cql()/pair() must be called to release resources and close CQLBuilder");
}
this.sb = ObjectFactory.createStringBuilder();
this.namingPolicy = namingPolicy == null ? NamingPolicy.LOWER_CASE_WITH_UNDERSCORE : namingPolicy;
this.cqlPolicy = cqlPolicy == null ? CQLPolicy.CQL : cqlPolicy;
}
/**
* Register the irregular column names which can not be converted from property name by naming policy.
*
* @param entityTableName
* @param propColumnNameMap
*/
public static void registerColumnName(final String entityTableName, final Map propColumnNameMap) {
final Map m = new HashMap<>(propColumnNameMap);
entityTablePropColumnNameMap.put(entityTableName, m);
entityTablePropColumnNameMap.put(entityTableName.toLowerCase(), m);
entityTablePropColumnNameMap.put(entityTableName.toUpperCase(), m);
entityTablePropColumnNameMap.put(ClassUtil.toLowerCaseWithUnderscore(entityTableName), m);
entityTablePropColumnNameMap.put(ClassUtil.toUpperCaseWithUnderscore(entityTableName), m);
}
// /**
// * Register the irregular column names which can not be converted from property name by naming policy.
// *
// * @param propNameTableInterface the interface generated by com.landawn.abacus.util.CodeGenerator
// */
// public static void registerColumnName(final Class> propNameTableInterface) {
// final String PCM = "_PCM";
//
// try {
// final Map _pcm = (Map) propNameTableInterface.getField(PCM).get(null);
//
// for (Class> cls : propNameTableInterface.getDeclaredClasses()) {
// final String entityName = (String) cls.getField(D.UNDERSCORE).get(null);
// final Map entityPCM = (Map) cls.getField(PCM).get(null);
//
// final Map propColumnNameMap = new HashMap<>(_pcm);
// propColumnNameMap.putAll(entityPCM);
//
// registerColumnName(entityName, propColumnNameMap);
// }
// } catch (Exception e) {
// throw new AbacusException(e);
// }
// }
// /**
// * Returns an immutable list of the property name by the specified entity class.
// *
// * @param entityClass
// * @return
// */
// public static List propNameList(final Class> entityClass) {
// List propNameList = classPropNameListPool.get(entityClass);
//
// if (propNameList == null) {
// synchronized (classPropNameListPool) {
// propNameList = classPropNameListPool.get(entityClass);
//
// if (propNameList == null) {
// propNameList = N.asImmutableList(new ArrayList<>(N.getPropGetMethodList(entityClass).keySet()));
// classPropNameListPool.put(entityClass, propNameList);
// }
// }
// }
//
// return propNameList;
// }
// /**
// * Returns an immutable set of the property name by the specified entity class.
// *
// * @param entityClass
// * @return
// */
// public static Set propNameSet(final Class> entityClass) {
// Set propNameSet = classPropNameSetPool.get(entityClass);
//
// if (propNameSet == null) {
// synchronized (classPropNameSetPool) {
// propNameSet = classPropNameSetPool.get(entityClass);
//
// if (propNameSet == null) {
// propNameSet = N.asImmutableSet(new LinkedHashSet<>(N.getPropGetMethodList(entityClass).keySet()));
// classPropNameSetPool.put(entityClass, propNameSet);
// }
// }
// }
//
// return propNameSet;
// }
@Beta
static Map named(final String... propNames) {
final Map m = new LinkedHashMap<>(N.initHashCapacity(propNames.length));
for (String propName : propNames) {
m.put(propName, L.QME);
}
return m;
}
@Beta
static Map named(final Collection propNames) {
final Map m = new LinkedHashMap<>(N.initHashCapacity(propNames.size()));
for (String propName : propNames) {
m.put(propName, L.QME);
}
return m;
}
public CQLBuilder into(final String tableName) {
if (op != OperationType.ADD) {
throw new AbacusException("Invalid operation: " + op);
}
if (N.isNullOrEmpty(columnNames) && N.isNullOrEmpty(columnNameList) && N.isNullOrEmpty(props) && N.isNullOrEmpty(propsList)) {
throw new AbacusException("Column names or props must be set first by insert");
}
this.tableName = tableName;
sb.append(_INSERT);
sb.append(_SPACE_INTO_SPACE);
sb.append(formalizeName(tableName));
sb.append(WD._SPACE);
sb.append(WD._PARENTHESES_L);
final Map propColumnNameMap = entityTablePropColumnNameMap.get(tableName);
if (N.notNullOrEmpty(columnNames)) {
if (columnNames.length == 1 && columnNames[0].indexOf(WD._SPACE) > 0) {
sb.append(columnNames[0]);
} else {
for (int i = 0, len = columnNames.length; i < len; i++) {
if (i > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(formalizeName(propColumnNameMap, columnNames[i]));
}
}
} else if (N.notNullOrEmpty(columnNameList)) {
int i = 0;
for (String columnName : columnNameList) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(formalizeName(propColumnNameMap, columnName));
}
} else {
final Map props = N.isNullOrEmpty(this.props) ? propsList.iterator().next() : this.props;
int i = 0;
for (String columnName : props.keySet()) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(formalizeName(propColumnNameMap, columnName));
}
}
sb.append(WD._PARENTHESES_R);
sb.append(_SPACE_VALUES_SPACE);
sb.append(WD._PARENTHESES_L);
if (N.notNullOrEmpty(columnNames)) {
switch (cqlPolicy) {
case CQL:
case RAW_CQL: {
for (int i = 0, len = columnNames.length; i < len; i++) {
if (i > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(WD._QUESTION_MARK);
}
break;
}
case NAMED_CQL: {
for (int i = 0, len = columnNames.length; i < len; i++) {
if (i > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(":");
sb.append(columnNames[i]);
}
break;
}
case IBATIS_CQL: {
for (int i = 0, len = columnNames.length; i < len; i++) {
if (i > 0) {
sb.append(_COMMA_SPACE);
}
sb.append("#{");
sb.append(columnNames[i]);
sb.append('}');
}
break;
}
default:
throw new AbacusException("Not supported CQL policy: " + cqlPolicy);
}
} else if (N.notNullOrEmpty(columnNameList)) {
switch (cqlPolicy) {
case CQL:
case RAW_CQL: {
for (int i = 0, size = columnNameList.size(); i < size; i++) {
if (i > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(WD._QUESTION_MARK);
}
break;
}
case NAMED_CQL: {
int i = 0;
for (String columnName : columnNameList) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(":");
sb.append(columnName);
}
break;
}
case IBATIS_CQL: {
int i = 0;
for (String columnName : columnNameList) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
sb.append("#{");
sb.append(columnName);
sb.append('}');
}
break;
}
default:
throw new AbacusException("Not supported CQL policy: " + cqlPolicy);
}
} else if (N.notNullOrEmpty(props)) {
appendInsertProps(props);
} else {
int i = 0;
for (Map props : propsList) {
if (i++ > 0) {
sb.append(WD._PARENTHESES_R);
sb.append(_COMMA_SPACE);
sb.append(WD._PARENTHESES_L);
}
appendInsertProps(props);
}
}
sb.append(WD._PARENTHESES_R);
return this;
}
public CQLBuilder into(final Class> entityClass) {
return into(ClassUtil.getSimpleClassName(entityClass));
}
public CQLBuilder from(String expr) {
expr = expr.trim();
String tableName = expr.indexOf(WD._COMMA) > 0 ? N.split(expr, WD._COMMA, true)[0] : expr;
if (tableName.indexOf(WD.SPACE) > 0) {
tableName = N.split(tableName, WD._SPACE, true)[0];
}
return from(tableName, expr);
}
@SafeVarargs
public final CQLBuilder from(final String... tableNames) {
if (tableNames.length == 1) {
return from(tableNames[0]);
} else {
String tableName = tableNames[0].trim();
if (tableName.indexOf(WD.SPACE) > 0) {
tableName = N.split(tableName, WD._SPACE, true)[0];
}
return from(tableName, N.join(tableNames, WD.COMMA_SPACE));
}
}
public CQLBuilder from(final Collection tableNames) {
String tableName = tableNames.iterator().next().trim();
if (tableName.indexOf(WD.SPACE) > 0) {
tableName = N.split(tableName, WD._SPACE, true)[0];
}
return from(tableName, N.join(tableNames, WD.SPACE));
}
public CQLBuilder from(final Map tableAliases) {
String tableName = tableAliases.keySet().iterator().next().trim();
if (tableName.indexOf(WD.SPACE) > 0) {
tableName = N.split(tableName, WD._SPACE, true)[0];
}
String expr = "";
int i = 0;
for (Map.Entry entry : tableAliases.entrySet()) {
if (i++ > 0) {
expr += WD.COMMA_SPACE;
}
expr += (entry.getKey() + " " + entry.getValue());
}
return from(tableName, expr);
}
private CQLBuilder from(final String tableName, final String fromCause) {
if (op != OperationType.QUERY && op != OperationType.DELETE) {
throw new AbacusException("Invalid operation: " + op);
}
if (N.isNullOrEmpty(columnNames) && N.isNullOrEmpty(columnNameList) && N.isNullOrEmpty(columnAliases)) {
throw new AbacusException("Column names or props must be set first by select");
}
this.tableName = tableName;
sb.append(op == OperationType.QUERY ? _SELECT : _DELETE);
sb.append(WD._SPACE);
if (N.notNullOrEmpty(predicates)) {
sb.append(predicates);
sb.append(WD._SPACE);
}
final Map propColumnNameMap = entityTablePropColumnNameMap.get(tableName);
if (N.notNullOrEmpty(columnNames)) {
if (columnNames.length == 1) {
final String columnName = N.trim(columnNames[0]);
int idx = columnName.indexOf(' ');
if (idx < 0) {
idx = columnName.indexOf(',');
}
if (idx > 0) {
sb.append(columnName);
} else {
sb.append(formalizeName(propColumnNameMap, columnName));
if (namingPolicy != NamingPolicy.LOWER_CAMEL_CASE && !WD.ASTERISK.equals(columnName)) {
sb.append(_SPACE_AS_SPACE);
sb.append(WD._QUOTATION_D);
sb.append(columnName);
sb.append(WD._QUOTATION_D);
}
}
} else {
String columnName = null;
for (int i = 0, len = columnNames.length; i < len; i++) {
columnName = N.trim(columnNames[i]);
if (i > 0) {
sb.append(_COMMA_SPACE);
}
int idx = columnName.indexOf(' ');
if (idx > 0) {
int idx2 = columnName.indexOf(" AS ", idx);
if (idx2 < 0) {
idx2 = columnName.indexOf(" as ", idx);
}
sb.append(formalizeName(propColumnNameMap, columnName.substring(0, idx).trim()));
sb.append(_SPACE_AS_SPACE);
sb.append(WD._QUOTATION_D);
sb.append(columnName.substring(idx2 > 0 ? idx2 + 4 : idx + 1).trim());
sb.append(WD._QUOTATION_D);
} else {
sb.append(formalizeName(propColumnNameMap, columnName));
if (namingPolicy != NamingPolicy.LOWER_CAMEL_CASE && !WD.ASTERISK.equals(columnName)) {
sb.append(_SPACE_AS_SPACE);
sb.append(WD._QUOTATION_D);
sb.append(columnName);
sb.append(WD._QUOTATION_D);
}
}
}
}
} else if (N.notNullOrEmpty(columnNameList)) {
int i = 0;
for (String columnName : columnNameList) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(formalizeName(propColumnNameMap, columnName));
if (op == OperationType.QUERY && namingPolicy != NamingPolicy.LOWER_CAMEL_CASE && !WD.ASTERISK.equals(columnName)) {
sb.append(_SPACE_AS_SPACE);
sb.append(WD._QUOTATION_D);
sb.append(columnName);
sb.append(WD._QUOTATION_D);
}
}
} else {
int i = 0;
for (Map.Entry entry : columnAliases.entrySet()) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(formalizeName(propColumnNameMap, entry.getKey()));
if (N.notNullOrEmpty(entry.getValue())) {
sb.append(_SPACE_AS_SPACE);
sb.append(WD._QUOTATION_D);
sb.append(entry.getValue());
sb.append(WD._QUOTATION_D);
}
}
}
sb.append(_SPACE_FROM_SPACE);
sb.append(formalizeName(fromCause));
return this;
}
public CQLBuilder from(final Class> entityClass) {
return from(ClassUtil.getSimpleClassName(entityClass));
}
public CQLBuilder where(final String expr) {
init(true);
sb.append(_SPACE_WHERE_SPACE);
appendStringExpr(expr);
return this;
}
/**
*
* @param cond any literal written in Expression
condition won't be formalized
* @return
*/
public CQLBuilder where(final Condition cond) {
init(true);
sb.append(_SPACE_WHERE_SPACE);
appendCondition(cond);
return this;
}
private void appendStringExpr(final String expr) {
final Map propColumnNameMap = entityTablePropColumnNameMap.get(tableName);
final List words = SQLParser.parse(expr);
String word = null;
for (int i = 0, len = words.size(); i < len; i++) {
word = words.get(i);
if (!N.isAsciiAlpha(word.charAt(0))) {
sb.append(word);
} else if (i < len - 1 && words.get(i + 1).charAt(0) == WD._PARENTHESES_L) {
sb.append(word);
} else {
sb.append(formalizeName(propColumnNameMap, word));
}
}
}
public CQLBuilder orderBy(final String expr) {
sb.append(_SPACE_ORDER_BY_SPACE);
if (expr.indexOf(WD._SPACE) > 0) {
// sb.append(columnNames[0]);
appendStringExpr(expr);
} else {
sb.append(formalizeName(tableName, expr));
}
return this;
}
@SafeVarargs
public final CQLBuilder orderBy(final String... columnNames) {
sb.append(_SPACE_ORDER_BY_SPACE);
if (columnNames.length == 1) {
if (columnNames[0].indexOf(WD._SPACE) > 0) {
// sb.append(columnNames[0]);
appendStringExpr(columnNames[0]);
} else {
sb.append(formalizeName(tableName, columnNames[0]));
}
} else {
final Map propColumnNameMap = entityTablePropColumnNameMap.get(tableName);
for (int i = 0, len = columnNames.length; i < len; i++) {
if (i > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(formalizeName(propColumnNameMap, columnNames[i]));
}
}
return this;
}
public CQLBuilder orderBy(final String columnName, final SortDirection direction) {
orderBy(columnName);
sb.append(WD._SPACE);
sb.append(direction.toString());
return this;
}
public CQLBuilder orderBy(final Collection columnNames) {
sb.append(_SPACE_ORDER_BY_SPACE);
final Map propColumnNameMap = entityTablePropColumnNameMap.get(tableName);
int i = 0;
for (String columnName : columnNames) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(formalizeName(propColumnNameMap, columnName));
}
return this;
}
public CQLBuilder orderBy(final Collection columnNames, final SortDirection direction) {
orderBy(columnNames);
sb.append(WD._SPACE);
sb.append(direction.toString());
return this;
}
public CQLBuilder orderBy(final Map orders) {
sb.append(_SPACE_ORDER_BY_SPACE);
final Map propColumnNameMap = entityTablePropColumnNameMap.get(tableName);
int i = 0;
for (Map.Entry entry : orders.entrySet()) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(formalizeName(propColumnNameMap, entry.getKey()));
sb.append(WD._SPACE);
sb.append(entry.getValue().toString());
}
return this;
}
public CQLBuilder limit(final int count) {
sb.append(_SPACE_LIMIT_SPACE);
sb.append(count);
return this;
}
public CQLBuilder set(final String expr) {
return set(N.asArray(expr));
}
@SafeVarargs
public final CQLBuilder set(final String... columnNames) {
init(false);
sb.append(_SPACE_SET_SPACE);
if (columnNames.length == 1 && SQLParser.parse(columnNames[0]).contains(WD.EQUAL)) {
sb.append(columnNames[0]);
} else {
final Map propColumnNameMap = entityTablePropColumnNameMap.get(tableName);
switch (cqlPolicy) {
case CQL:
case RAW_CQL: {
for (int i = 0, len = columnNames.length; i < len; i++) {
if (i > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(formalizeName(propColumnNameMap, columnNames[i]));
sb.append(_SPACE_EQUAL_SPACE);
sb.append(WD._QUESTION_MARK);
}
break;
}
case NAMED_CQL: {
for (int i = 0, len = columnNames.length; i < len; i++) {
if (i > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(formalizeName(propColumnNameMap, columnNames[i]));
sb.append(_SPACE_EQUAL_SPACE);
sb.append(":");
sb.append(columnNames[i]);
}
break;
}
case IBATIS_CQL: {
for (int i = 0, len = columnNames.length; i < len; i++) {
if (i > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(formalizeName(propColumnNameMap, columnNames[i]));
sb.append(_SPACE_EQUAL_SPACE);
sb.append("#{");
sb.append(columnNames[i]);
sb.append('}');
}
break;
}
default:
throw new AbacusException("Not supported CQL policy: " + cqlPolicy);
}
}
this.columnNameList = null;
return this;
}
public CQLBuilder set(final Collection columnNames) {
init(false);
sb.append(_SPACE_SET_SPACE);
final Map propColumnNameMap = entityTablePropColumnNameMap.get(tableName);
switch (cqlPolicy) {
case CQL:
case RAW_CQL: {
int i = 0;
for (String columnName : columnNames) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(formalizeName(propColumnNameMap, columnName));
sb.append(_SPACE_EQUAL_SPACE);
sb.append(WD._QUESTION_MARK);
}
break;
}
case NAMED_CQL: {
int i = 0;
for (String columnName : columnNames) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(formalizeName(propColumnNameMap, columnName));
sb.append(_SPACE_EQUAL_SPACE);
sb.append(":");
sb.append(columnName);
}
break;
}
case IBATIS_CQL: {
int i = 0;
for (String columnName : columnNames) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(formalizeName(propColumnNameMap, columnName));
sb.append(_SPACE_EQUAL_SPACE);
sb.append("#{");
sb.append(columnName);
sb.append('}');
}
break;
}
default:
throw new AbacusException("Not supported CQL policy: " + cqlPolicy);
}
this.columnNameList = null;
return this;
}
public CQLBuilder set(final Map props) {
init(false);
sb.append(_SPACE_SET_SPACE);
final Map propColumnNameMap = entityTablePropColumnNameMap.get(tableName);
switch (cqlPolicy) {
case CQL: {
int i = 0;
for (Map.Entry entry : props.entrySet()) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(formalizeName(propColumnNameMap, entry.getKey()));
sb.append(_SPACE_EQUAL_SPACE);
setParameterForCQL(entry.getValue());
}
break;
}
case RAW_CQL: {
int i = 0;
for (Map.Entry entry : props.entrySet()) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(formalizeName(propColumnNameMap, entry.getKey()));
sb.append(_SPACE_EQUAL_SPACE);
setParameterForRawCQL(entry.getValue());
}
break;
}
case NAMED_CQL: {
int i = 0;
for (Map.Entry entry : props.entrySet()) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(formalizeName(propColumnNameMap, entry.getKey()));
sb.append(_SPACE_EQUAL_SPACE);
setParameterForNamedCQL(entry.getKey(), entry.getValue());
}
break;
}
case IBATIS_CQL: {
int i = 0;
for (Map.Entry entry : props.entrySet()) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
sb.append(formalizeName(propColumnNameMap, entry.getKey()));
sb.append(_SPACE_EQUAL_SPACE);
setParameterForIbatisNamedCQL(entry.getKey(), entry.getValue());
}
break;
}
default:
throw new AbacusException("Not supported CQL policy: " + cqlPolicy);
}
this.columnNameList = null;
return this;
}
/**
* Only the dirty properties will be set into the result CQL if the specified entity is a dirty marker entity.
*
* @param entity
* @return
*/
@SuppressWarnings("deprecation")
public CQLBuilder set(final Object entity) {
if (entity instanceof String) {
return set(N.asArray((String) entity));
} else if (entity instanceof Map) {
return set((Map) entity);
} else {
if (N.isDirtyMarker(entity.getClass())) {
final DirtyMarker dirtyMarkerEntity = ((DirtyMarker) entity);
final Set updatedPropNames = dirtyMarkerEntity.dirtyPropNames();
final Map updateProps = new HashMap<>();
for (String propName : updatedPropNames) {
updateProps.put(propName, ClassUtil.getPropValue(dirtyMarkerEntity, propName));
}
return set(updateProps);
} else {
return set(Maps.entity2Map(entity));
}
}
}
/**
* Only the dirty properties will be set into the result SQL if the specified entity is a dirty marker entity.
*
* @param entity
* @param excludedPropNames
* @return
*/
@SuppressWarnings("deprecation")
public CQLBuilder set(final Object entity, final Set excludedPropNames) {
if (entity instanceof String) {
return set(N.asArray((String) entity));
} else if (entity instanceof Map) {
if (N.isNullOrEmpty(excludedPropNames)) {
return set((Map) entity);
} else {
final Map props = new LinkedHashMap<>((Map) entity);
Maps.removeKeys(props, excludedPropNames);
return set(props);
}
} else {
if (N.isDirtyMarker(entity.getClass())) {
final Map props = new HashMap<>();
for (String propName : ((DirtyMarker) entity).dirtyPropNames()) {
props.put(propName, ClassUtil.getPropValue(entity, propName));
}
Maps.removeKeys(props, excludedPropNames);
return set(props);
} else {
return set(N.isNullOrEmpty(excludedPropNames) ? Maps.entity2Map(entity) : Maps.entity2Map(entity, excludedPropNames));
}
}
}
public CQLBuilder set(Class> entityClass) {
return set(entityClass, null);
}
public CQLBuilder set(Class> entityClass, final Set excludedPropNames) {
return set(getPropNamesByClass(entityClass, excludedPropNames));
}
CQLBuilder using(String... options) {
init(false);
sb.append(_SPACE_USING_SPACE);
for (int i = 0, len = options.length; i < len; i++) {
if (i > 0) {
sb.append(_SPACE_AND_SPACE);
}
sb.append(options[i]);
}
return this;
}
public CQLBuilder usingTTL(long timestamp) {
return usingTTL(String.valueOf(timestamp));
}
public CQLBuilder usingTTL(String timestamp) {
init(false);
sb.append(_SPACE_USING_TTL_SPACE);
sb.append(timestamp);
return this;
}
public CQLBuilder usingTimestamp(Date timestamp) {
return usingTimestamp(timestamp.getTime());
}
public CQLBuilder usingTimestamp(long timestamp) {
return usingTimestamp(String.valueOf(timestamp));
}
public CQLBuilder usingTimestamp(String timestamp) {
init(false);
sb.append(_SPACE_USING_TIMESTAMP_SPACE);
sb.append(timestamp);
return this;
}
public CQLBuilder iff(final String expr) {
init(true);
sb.append(_SPACE_IF_SPACE);
appendStringExpr(expr);
return this;
}
/**
*
* @param cond any literal written in Expression
condition won't be formalized
* @return
*/
public CQLBuilder iff(final Condition cond) {
init(true);
sb.append(_SPACE_IF_SPACE);
appendCondition(cond);
return this;
}
public CQLBuilder ifExists() {
init(true);
sb.append(_SPACE_IF_EXISTS);
return this;
}
public CQLBuilder ifNotExists() {
init(true);
sb.append(_SPACE_IF_NOT_EXISTS);
return this;
}
public CQLBuilder allowFiltering() {
init(true);
sb.append(_SPACE_ALLOW_FILTERING);
return this;
}
public T apply(final Try.Function super CP, T, EX> func) throws EX {
return func.apply(this.pair());
}
/**
* This CQLBuilder will be closed after cql()
is called.
*
* @return
*/
public String cql() {
if (sb == null) {
throw new AbacusException("This CQLBuilder has been closed after cql() was called previously");
}
init(true);
try {
return sb.toString();
} finally {
ObjectFactory.recycle(sb);
sb = null;
activeStringBuilderCounter.decrementAndGet();
}
}
public List parameters() {
return parameters;
}
/**
* This CQLBuilder will be closed after pair()
is called.
*
* @return the pair of cql and parameters.
*/
public CP pair() {
return new CP(cql(), parameters);
}
// /**
// *
// * @param cassandraExecutor
// * @return
// */
// @Beta
// public boolean exists(final CassandraExecutor cassandraExecutor) {
// if (op != OperationType.QUERY) {
// throw new IllegalArgumentException("Only SELECT statement is supported");
// }
//
// return cassandraExecutor.exists(cql(), this.parameters);
// }
//
// /**
// *
// * @param cassandraExecutor
// * @return
// */
// @Beta
// public boolean exists(final CassandraExecutor cassandraExecutor, final Object... parameters) {
// if (op != OperationType.QUERY) {
// throw new IllegalArgumentException("Only SELECT statement is supported");
// }
//
// if (N.isNullOrEmpty(parameters)) {
// return cassandraExecutor.exists(cql(), this.parameters);
// } else {
// return cassandraExecutor.exists(cql(), parameters);
// }
// }
//
// /**
// *
// * @param cassandraExecutor
// * @return DataSet
if it's a SELECT
statement, otherwise, ResultSet
is returned.
// */
// @Beta
// public T execute(final CassandraExecutor cassandraExecutor) {
// if (op == OperationType.QUERY) {
// return (T) cassandraExecutor.query(cql(), this.parameters);
// } else {
// return (T) cassandraExecutor.execute(cql(), this.parameters);
// }
// }
//
// /**
// *
// * @param cassandraExecutor
// * @param parameters
// * @return DataSet
if it's a SELECT
statement, otherwise, ResultSet
is returned.
// */
// @Beta
// public T execute(final CassandraExecutor cassandraExecutor, final Object... parameters) {
// if (N.isNullOrEmpty(parameters)) {
// if (op == OperationType.QUERY) {
// return (T) cassandraExecutor.query(cql(), this.parameters);
// } else {
// return (T) cassandraExecutor.execute(cql(), this.parameters);
// }
// } else {
// if (op == OperationType.QUERY) {
// return (T) cassandraExecutor.query(cql(), parameters);
// } else {
// return (T) cassandraExecutor.execute(cql(), parameters);
// }
// }
// }
//
// /**
// * Returns the target result executed by calling queryForEntity
if the target class is entity or map, otherwise queryForSingleResult
// *
// * @param targetClass
// * @param cassandraExecutor
// * @return
// */
// @Beta
// public Nullable execute(final Class targetClass, final CassandraExecutor cassandraExecutor) {
// if (op != OperationType.QUERY) {
// throw new IllegalArgumentException("Only SELECT statement is supported");
// }
//
// if (N.isEntity(targetClass) || Map.class.isAssignableFrom(targetClass)) {
// return Nullable.from(cassandraExecutor.queryForEntity(targetClass, cql(), this.parameters));
// } else {
// return cassandraExecutor.queryForSingleResult(targetClass, cql(), this.parameters);
// }
// }
//
// /**
// * Returns the target result executed by calling queryForEntity
if the target class is entity or map, otherwise queryForSingleResult
// *
// * @param targetClass
// * @param cassandraExecutor
// * @param parameters
// * @return
// */
// @Beta
// public Nullable execute(final Class targetClass, final CassandraExecutor cassandraExecutor, final Object... parameters) {
// if (op != OperationType.QUERY) {
// throw new IllegalArgumentException("Only SELECT statement is supported");
// }
//
// if (N.isNullOrEmpty(parameters)) {
// if (N.isEntity(targetClass) || Map.class.isAssignableFrom(targetClass)) {
// return Nullable.from(cassandraExecutor.queryForEntity(targetClass, cql(), this.parameters));
// } else {
// return cassandraExecutor.queryForSingleResult(targetClass, cql(), this.parameters);
// }
// } else {
// if (N.isEntity(targetClass) || Map.class.isAssignableFrom(targetClass)) {
// return Nullable.from(cassandraExecutor.queryForEntity(targetClass, cql(), parameters));
// } else {
// return cassandraExecutor.queryForSingleResult(targetClass, cql(), parameters);
// }
// }
// }
//
// @Beta
// public CompletableFuture asyncExecute(final CassandraExecutor cassandraExecutor) {
// if (op == OperationType.QUERY) {
// return (CompletableFuture) cassandraExecutor.asyncQuery(cql(), this.parameters);
// } else {
// return (CompletableFuture) cassandraExecutor.asyncExecute(cql(), this.parameters);
// }
// }
//
// @Beta
// public CompletableFuture asyncExecute(final CassandraExecutor cassandraExecutor, final Object... parameters) {
// if (N.isNullOrEmpty(parameters)) {
// if (op == OperationType.QUERY) {
// return (CompletableFuture) cassandraExecutor.asyncQuery(cql(), this.parameters);
// } else {
// return (CompletableFuture) cassandraExecutor.asyncExecute(cql(), this.parameters);
// }
// } else {
// if (op == OperationType.QUERY) {
// return (CompletableFuture) cassandraExecutor.asyncQuery(cql(), parameters);
// } else {
// return (CompletableFuture) cassandraExecutor.asyncExecute(cql(), parameters);
// }
// }
// }
//
// @Beta
// public CompletableFuture> asyncExecute(final Class targetClass, final CassandraExecutor cassandraExecutor) {
// if (op != OperationType.QUERY) {
// throw new IllegalArgumentException("Only SELECT statement is supported");
// }
//
// return cassandraExecutor.asyncExecutor().execute(new Callable>() {
// @Override
// public Nullable call() throws Exception {
// return execute(targetClass, cassandraExecutor);
// }
// });
// }
//
// @Beta
// public CompletableFuture> asyncExecute(final Class targetClass, final CassandraExecutor cassandraExecutor,
// final Object... parameters) {
// if (op != OperationType.QUERY) {
// throw new IllegalArgumentException("Only SELECT statement is supported");
// }
//
// return cassandraExecutor.asyncExecutor().execute(new Callable>() {
// @Override
// public Nullable call() throws Exception {
// return execute(targetClass, cassandraExecutor, parameters);
// }
// });
// }
void init(boolean setForUpdate) {
if (sb.length() > 0) {
if (op == OperationType.UPDATE && setForUpdate && N.notNullOrEmpty(columnNameList)) {
set(columnNameList);
}
return;
}
if (op == OperationType.UPDATE) {
sb.append(_UPDATE);
sb.append(WD._SPACE);
sb.append(formalizeName(tableName));
if (setForUpdate && N.notNullOrEmpty(columnNameList)) {
set(columnNameList);
}
} else if (op == OperationType.DELETE) {
final String newTableName = formalizeName(tableName);
char[] deleteFromTableChars = tableDeleteFrom.get(newTableName);
if (deleteFromTableChars == null) {
deleteFromTableChars = (WD.DELETE + WD.SPACE + WD.FROM + WD.SPACE + newTableName).toCharArray();
tableDeleteFrom.put(newTableName, deleteFromTableChars);
}
sb.append(deleteFromTableChars);
}
}
private void setParameterForCQL(final Object propValue) {
if (L.QME.equals(propValue)) {
sb.append(WD._QUESTION_MARK);
} else if (propValue instanceof Condition) {
appendCondition((Condition) propValue);
} else {
sb.append(Expression.formalize(propValue));
}
}
private void setParameterForRawCQL(final Object propValue) {
if (L.QME.equals(propValue)) {
sb.append(WD._QUESTION_MARK);
} else if (propValue instanceof Condition) {
appendCondition((Condition) propValue);
} else {
sb.append(WD._QUESTION_MARK);
parameters.add(propValue);
}
}
private void setParameterForIbatisNamedCQL(final String propName, final Object propValue) {
if (L.QME.equals(propValue)) {
sb.append("#{");
sb.append(propName);
sb.append('}');
} else if (propValue instanceof Condition) {
appendCondition((Condition) propValue);
} else {
sb.append("#{");
sb.append(propName);
sb.append('}');
parameters.add(propValue);
}
}
private void setParameterForNamedCQL(final String propName, final Object propValue) {
if (L.QME.equals(propValue)) {
sb.append(":");
sb.append(propName);
} else if (propValue instanceof Condition) {
appendCondition((Condition) propValue);
} else {
sb.append(":");
sb.append(propName);
parameters.add(propValue);
}
}
private void setParameter(final String propName, final Object propValue) {
switch (cqlPolicy) {
case CQL: {
setParameterForCQL(propValue);
break;
}
case RAW_CQL: {
setParameterForRawCQL(propValue);
break;
}
case NAMED_CQL: {
setParameterForNamedCQL(propName, propValue);
break;
}
case IBATIS_CQL: {
setParameterForIbatisNamedCQL(propName, propValue);
break;
}
default:
throw new AbacusException("Not supported CQL policy: " + cqlPolicy);
}
}
private void appendInsertProps(final Map props) {
switch (cqlPolicy) {
case CQL: {
int i = 0;
Object propValue = null;
for (String propName : props.keySet()) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
propValue = props.get(propName);
setParameterForCQL(propValue);
}
break;
}
case RAW_CQL: {
int i = 0;
Object propValue = null;
for (String propName : props.keySet()) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
propValue = props.get(propName);
setParameterForRawCQL(propValue);
}
break;
}
case NAMED_CQL: {
int i = 0;
Object propValue = null;
for (String propName : props.keySet()) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
propValue = props.get(propName);
setParameterForNamedCQL(propName, propValue);
}
break;
}
case IBATIS_CQL: {
int i = 0;
Object propValue = null;
for (String propName : props.keySet()) {
if (i++ > 0) {
sb.append(_COMMA_SPACE);
}
propValue = props.get(propName);
setParameterForIbatisNamedCQL(propName, propValue);
}
break;
}
default:
throw new AbacusException("Not supported CQL policy: " + cqlPolicy);
}
}
private void appendCondition(final Condition cond) {
if (cond instanceof Binary) {
final Binary binary = (Binary) cond;
final String propName = binary.getPropName();
sb.append(formalizeName(tableName, propName));
sb.append(WD._SPACE);
sb.append(binary.getOperator().toString());
sb.append(WD._SPACE);
Object propValue = binary.getPropValue();
setParameter(propName, propValue);
} else if (cond instanceof Between) {
final Between bt = (Between) cond;
final String propName = bt.getPropName();
sb.append(formalizeName(tableName, propName));
sb.append(WD._SPACE);
sb.append(bt.getOperator().toString());
sb.append(WD._SPACE);
Object minValue = bt.getMinValue();
if (cqlPolicy == CQLPolicy.NAMED_CQL || cqlPolicy == CQLPolicy.IBATIS_CQL) {
setParameter("min" + N.capitalize(propName), minValue);
} else {
setParameter(propName, minValue);
}
sb.append(WD._SPACE);
sb.append(WD.AND);
sb.append(WD._SPACE);
Object maxValue = bt.getMaxValue();
if (cqlPolicy == CQLPolicy.NAMED_CQL || cqlPolicy == CQLPolicy.IBATIS_CQL) {
setParameter("max" + N.capitalize(propName), maxValue);
} else {
setParameter(propName, maxValue);
}
} else if (cond instanceof In) {
final In in = (In) cond;
final String propName = in.getPropName();
final List parameters = in.getParameters();
sb.append(formalizeName(tableName, propName));
sb.append(WD._SPACE);
sb.append(in.getOperator().toString());
sb.append(WD.SPACE_PARENTHESES_L);
for (int i = 0, len = parameters.size(); i < len; i++) {
if (i > 0) {
sb.append(WD.COMMA_SPACE);
}
if (cqlPolicy == CQLPolicy.NAMED_CQL || cqlPolicy == CQLPolicy.IBATIS_CQL) {
setParameter(propName + (i + 1), parameters.get(i));
} else {
setParameter(propName, parameters.get(i));
}
}
sb.append(WD._PARENTHESES_R);
} else if (cond instanceof Cell) {
final Cell cell = (Cell) cond;
sb.append(WD._SPACE);
sb.append(cell.getOperator().toString());
sb.append(WD._SPACE);
sb.append(_PARENTHESES_L);
appendCondition(cell.getCondition());
sb.append(_PARENTHESES_R);
} else if (cond instanceof Junction) {
final Junction junction = (Junction) cond;
final List conditionList = junction.getConditions();
if (N.isNullOrEmpty(conditionList)) {
throw new IllegalArgumentException("The junction condition(" + junction.getOperator().toString() + ") doesn't include any element.");
}
if (conditionList.size() == 1) {
appendCondition(conditionList.get(0));
} else {
// TODO ((id = :id) AND (gui = :gui)) is not support.
// only (id = :id) AND (gui = :gui) works.
// sb.append(_PARENTHESES_L);
for (int i = 0, size = conditionList.size(); i < size; i++) {
if (i > 0) {
sb.append(_SPACE);
sb.append(junction.getOperator().toString());
sb.append(_SPACE);
}
sb.append(_PARENTHESES_L);
appendCondition(conditionList.get(i));
sb.append(_PARENTHESES_R);
}
// sb.append(_PARENTHESES_R);
}
} else if (cond instanceof SubQuery) {
final SubQuery subQuery = (SubQuery) cond;
if (N.notNullOrEmpty(subQuery.getSql())) {
sb.append(subQuery.getSql());
} else {
if (this instanceof E) {
sb.append(E.select(subQuery.getSelectPropNames()).from(subQuery.getEntityName()).where(subQuery.getCondition()).cql());
} else if (this instanceof RE) {
sb.append(RE.select(subQuery.getSelectPropNames()).from(subQuery.getEntityName()).where(subQuery.getCondition()).cql());
} else if (this instanceof SE) {
sb.append(SE.select(subQuery.getSelectPropNames()).from(subQuery.getEntityName()).where(subQuery.getCondition()).cql());
} else if (this instanceof NE) {
sb.append(NE.select(subQuery.getSelectPropNames()).from(subQuery.getEntityName()).where(subQuery.getCondition()).cql());
} else if (this instanceof E2) {
sb.append(E2.select(subQuery.getSelectPropNames()).from(subQuery.getEntityName()).where(subQuery.getCondition()).cql());
} else if (this instanceof RE2) {
sb.append(RE2.select(subQuery.getSelectPropNames()).from(subQuery.getEntityName()).where(subQuery.getCondition()).cql());
} else if (this instanceof SE2) {
sb.append(SE2.select(subQuery.getSelectPropNames()).from(subQuery.getEntityName()).where(subQuery.getCondition()).cql());
} else if (this instanceof NE2) {
sb.append(NE2.select(subQuery.getSelectPropNames()).from(subQuery.getEntityName()).where(subQuery.getCondition()).cql());
} else if (this instanceof E3) {
sb.append(E3.select(subQuery.getSelectPropNames()).from(subQuery.getEntityName()).where(subQuery.getCondition()).cql());
} else if (this instanceof RE3) {
sb.append(RE3.select(subQuery.getSelectPropNames()).from(subQuery.getEntityName()).where(subQuery.getCondition()).cql());
} else if (this instanceof SE3) {
sb.append(SE3.select(subQuery.getSelectPropNames()).from(subQuery.getEntityName()).where(subQuery.getCondition()).cql());
} else if (this instanceof NE3) {
sb.append(NE3.select(subQuery.getSelectPropNames()).from(subQuery.getEntityName()).where(subQuery.getCondition()).cql());
} else {
throw new AbacusException("Unsupproted subQuery condition: " + cond);
}
}
} else if (cond instanceof Expression) {
sb.append(cond.toString());
} else {
throw new AbacusException("Unsupported condtion: " + cond.toString());
}
}
private String formalizeName(final String entityPropName) {
switch (namingPolicy) {
case LOWER_CASE_WITH_UNDERSCORE:
return ClassUtil.toLowerCaseWithUnderscore(entityPropName);
case UPPER_CASE_WITH_UNDERSCORE:
return ClassUtil.toUpperCaseWithUnderscore(entityPropName);
default:
return entityPropName;
}
}
private String formalizeName(final String entityTableName, final String propName) {
if (entityTablePropColumnNameMap.size() == 0) {
return formalizeName(propName);
} else {
return formalizeName(entityTablePropColumnNameMap.get(entityTableName), propName);
}
}
private String formalizeName(final Map propColumnNameMap, final String propName) {
String columnName = propColumnNameMap == null ? null : propColumnNameMap.get(propName);
if (columnName != null) {
return columnName;
}
switch (namingPolicy) {
case LOWER_CASE_WITH_UNDERSCORE:
return ClassUtil.toLowerCaseWithUnderscore(propName);
case UPPER_CASE_WITH_UNDERSCORE:
return ClassUtil.toUpperCaseWithUnderscore(propName);
default:
return propName;
}
}
// @Override
// public int hashCode() {
// return sb.hashCode();
// }
//
// @Override
// public boolean equals(Object obj) {
// if (obj == this) {
// return true;
// }
//
// if (obj instanceof CQLBuilder) {
// final CQLBuilder other = (CQLBuilder) obj;
//
// return N.equals(this.sb, other.sb) && N.equals(this.parameters, other.parameters);
// }
//
// return false;
// }
@Override
public String toString() {
return sb.toString();
}
private static void parseInsertEntity(final CQLBuilder instance, final Object entity, final Set excludedPropNames) {
if (entity instanceof String) {
instance.columnNames = N.asArray((String) entity);
} else if (entity instanceof Map) {
if (N.isNullOrEmpty(excludedPropNames)) {
instance.props = (Map) entity;
} else {
instance.props = new LinkedHashMap<>((Map) entity);
for (String propName : excludedPropNames) {
instance.props.remove(propName);
}
}
} else {
instance.props = N.isNullOrEmpty(excludedPropNames) ? Maps.entity2Map(entity) : Maps.entity2Map(entity, excludedPropNames);
}
}
private static Collection getPropNamesByClass(final Class> entityClass, final Set excludedPropNames) {
if (N.isNullOrEmpty(excludedPropNames)) {
return propNameList(entityClass);
} else {
final Set entityPropNameSet = new LinkedHashSet<>(ClassUtil.getPropGetMethodList(entityClass).keySet());
Method propGetMethod = null;
for (String propName : excludedPropNames) {
if (!entityPropNameSet.remove(propName)) {
propGetMethod = ClassUtil.getPropGetMethod(entityClass, propName);
if (propGetMethod != null) {
entityPropNameSet.remove(ClassUtil.getPropNameByMethod(propGetMethod));
}
}
}
return entityPropNameSet;
}
}
/**
* Returns an immutable list of the property name by the specified entity class.
*
* @param entityClass
* @return
*/
private static List propNameList(final Class> entityClass) {
List propNameList = classPropNameListPool.get(entityClass);
if (propNameList == null) {
synchronized (classPropNameListPool) {
propNameList = classPropNameListPool.get(entityClass);
if (propNameList == null) {
propNameList = ImmutableList.of(new ArrayList<>(ClassUtil.getPropGetMethodList(entityClass).keySet()));
classPropNameListPool.put(entityClass, propNameList);
}
}
}
return propNameList;
}
static enum CQLPolicy {
CQL, RAW_CQL, IBATIS_CQL, NAMED_CQL;
}
/**
* All the property/column names in collection/map/entity/condition will be converted to lower case with underscore.
*
* @author haiyang li
*
*/
public static final class E extends CQLBuilder {
E() {
super(NamingPolicy.LOWER_CASE_WITH_UNDERSCORE, CQLPolicy.CQL);
}
static E createInstance() {
return new E();
}
public static CQLBuilder insert(final String expr) {
return insert(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder insert(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder insert(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder insert(final Map props) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.props = props;
return instance;
}
public static CQLBuilder insert(final Object entity) {
return insert(entity, null);
}
public static CQLBuilder insert(final Object entity, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
parseInsertEntity(instance, entity, excludedPropNames);
return instance;
}
public static CQLBuilder insert(final Class> entityClass) {
return insert(entityClass, null);
}
public static CQLBuilder insert(final Class> entityClass, final Set excludedPropNames) {
return insert(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder insertInto(final Class> entityClass) {
return insertInto(entityClass, null);
}
public static CQLBuilder insertInto(final Class> entityClass, final Set excludedPropNames) {
return insert(entityClass, excludedPropNames).into(entityClass);
}
public static CQLBuilder select(final String expr) {
return select(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder select(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder select(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNameList = columnNames;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnNames
* @return
*/
public static CQLBuilder select(final String expr, final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder select(final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnAliases = columnAliases;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnAliases
* @return
*/
public static CQLBuilder select(final String expr, final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnAliases = columnAliases;
return instance;
}
public static CQLBuilder select(final Class> entityClass) {
return select(entityClass, null);
}
public static CQLBuilder select(final Class> entityClass, final Set excludedPropNames) {
return select(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder selectFrom(final Class> entityClass) {
return selectFrom(entityClass, null);
}
public static CQLBuilder selectFrom(final Class> entityClass, final Set excludedPropNames) {
return select(entityClass, excludedPropNames).from(entityClass);
}
public static CQLBuilder update(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.UPDATE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder update(final Class> entityClass) {
return update(entityClass, null);
}
public static CQLBuilder update(final Class> entityClass, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.UPDATE;
instance.tableName = ClassUtil.getSimpleClassName(entityClass);
instance.columnNameList = getPropNamesByClass(entityClass, excludedPropNames);
return instance;
}
public static CQLBuilder delete(final String expr) {
return delete(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder delete(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder delete(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder delete(final Class> entityClass) {
return delete(entityClass, null);
}
public static CQLBuilder delete(final Class> entityClass, final Set excludedPropNames) {
return delete(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder deleteFrom(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder deleteFrom(final Class> entityClass) {
return deleteFrom(ClassUtil.getSimpleClassName(entityClass));
}
public static CQLBuilder deleteFrom(final Class> entityClass, final Set excludedPropNames) {
return delete(entityClass, excludedPropNames).from(entityClass);
}
}
/**
* All the property/column names in collection/map/entity/condition will be converted to lower case with underscore and the cql will be parameterized with question mark.
*
* @author haiyang li
*
*/
public static final class RE extends CQLBuilder {
RE() {
super(NamingPolicy.LOWER_CASE_WITH_UNDERSCORE, CQLPolicy.RAW_CQL);
}
static RE createInstance() {
return new RE();
}
public static CQLBuilder insert(final String expr) {
return insert(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder insert(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder insert(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder insert(final Map props) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.props = props;
return instance;
}
public static CQLBuilder insert(final Object entity) {
return insert(entity, null);
}
public static CQLBuilder insert(final Object entity, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
parseInsertEntity(instance, entity, excludedPropNames);
return instance;
}
public static CQLBuilder insert(final Class> entityClass) {
return insert(entityClass, null);
}
public static CQLBuilder insert(final Class> entityClass, final Set excludedPropNames) {
return insert(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder insertInto(final Class> entityClass) {
return insertInto(entityClass, null);
}
public static CQLBuilder insertInto(final Class> entityClass, final Set excludedPropNames) {
return insert(entityClass, excludedPropNames).into(entityClass);
}
public static CQLBuilder select(final String expr) {
return select(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder select(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder select(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNameList = columnNames;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnNames
* @return
*/
public static CQLBuilder select(final String expr, final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder select(final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnAliases = columnAliases;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnAliases
* @return
*/
public static CQLBuilder select(final String expr, final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnAliases = columnAliases;
return instance;
}
public static CQLBuilder select(final Class> entityClass) {
return select(entityClass, null);
}
public static CQLBuilder select(final Class> entityClass, final Set excludedPropNames) {
return select(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder selectFrom(final Class> entityClass) {
return selectFrom(entityClass, null);
}
public static CQLBuilder selectFrom(final Class> entityClass, final Set excludedPropNames) {
return select(entityClass, excludedPropNames).from(entityClass);
}
public static CQLBuilder update(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.UPDATE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder update(final Class> entityClass) {
return update(entityClass, null);
}
public static CQLBuilder update(final Class> entityClass, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.UPDATE;
instance.tableName = ClassUtil.getSimpleClassName(entityClass);
instance.columnNameList = getPropNamesByClass(entityClass, excludedPropNames);
return instance;
}
public static CQLBuilder delete(final String expr) {
return delete(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder delete(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder delete(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder delete(final Class> entityClass) {
return delete(entityClass, null);
}
public static CQLBuilder delete(final Class> entityClass, final Set excludedPropNames) {
return delete(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder deleteFrom(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder deleteFrom(final Class> entityClass) {
return deleteFrom(ClassUtil.getSimpleClassName(entityClass));
}
public static CQLBuilder deleteFrom(final Class> entityClass, final Set excludedPropNames) {
return delete(entityClass, excludedPropNames).from(entityClass);
}
}
/**
* All the property/column names in collection/map/entity/condition will be converted to lower case with underscore and the cql will be parameterized with named parameter with Hibernate/JPA format :parameterName
* @author haiyang li
*
*/
public static final class NE extends CQLBuilder {
NE() {
super(NamingPolicy.LOWER_CASE_WITH_UNDERSCORE, CQLPolicy.NAMED_CQL);
}
static NE createInstance() {
return new NE();
}
public static CQLBuilder insert(final String expr) {
return insert(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder insert(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder insert(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder insert(final Map props) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.props = props;
return instance;
}
public static CQLBuilder insert(final Object entity) {
return insert(entity, null);
}
public static CQLBuilder insert(final Object entity, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
parseInsertEntity(instance, entity, excludedPropNames);
return instance;
}
public static CQLBuilder insert(final Class> entityClass) {
return insert(entityClass, null);
}
public static CQLBuilder insert(final Class> entityClass, final Set excludedPropNames) {
return insert(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder insertInto(final Class> entityClass) {
return insertInto(entityClass, null);
}
public static CQLBuilder insertInto(final Class> entityClass, final Set excludedPropNames) {
return insert(entityClass, excludedPropNames).into(entityClass);
}
public static CQLBuilder select(final String expr) {
return select(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder select(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder select(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNameList = columnNames;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnNames
* @return
*/
public static CQLBuilder select(final String expr, final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder select(final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnAliases = columnAliases;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnAliases
* @return
*/
public static CQLBuilder select(final String expr, final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnAliases = columnAliases;
return instance;
}
public static CQLBuilder select(final Class> entityClass) {
return select(entityClass, null);
}
public static CQLBuilder select(final Class> entityClass, final Set excludedPropNames) {
return select(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder selectFrom(final Class> entityClass) {
return selectFrom(entityClass, null);
}
public static CQLBuilder selectFrom(final Class> entityClass, final Set excludedPropNames) {
return select(entityClass, excludedPropNames).from(entityClass);
}
public static CQLBuilder update(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.UPDATE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder update(final Class> entityClass) {
return update(entityClass, null);
}
public static CQLBuilder update(final Class> entityClass, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.UPDATE;
instance.tableName = ClassUtil.getSimpleClassName(entityClass);
instance.columnNameList = getPropNamesByClass(entityClass, excludedPropNames);
return instance;
}
public static CQLBuilder delete(final String expr) {
return delete(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder delete(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder delete(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder delete(final Class> entityClass) {
return delete(entityClass, null);
}
public static CQLBuilder delete(final Class> entityClass, final Set excludedPropNames) {
return delete(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder deleteFrom(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder deleteFrom(final Class> entityClass) {
return deleteFrom(ClassUtil.getSimpleClassName(entityClass));
}
public static CQLBuilder deleteFrom(final Class> entityClass, final Set excludedPropNames) {
return delete(entityClass, excludedPropNames).from(entityClass);
}
}
/**
* All the property/column names in collection/map/entity/condition will be converted to lower case with underscore and the cql will be parameterized with named parameter with Ibatis format #{parameterName}
.
*
* @author haiyang li
*
*/
static final class SE extends CQLBuilder {
SE() {
super(NamingPolicy.LOWER_CASE_WITH_UNDERSCORE, CQLPolicy.IBATIS_CQL);
}
static SE createInstance() {
return new SE();
}
public static CQLBuilder insert(final String expr) {
return insert(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder insert(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder insert(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder insert(final Map props) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.props = props;
return instance;
}
public static CQLBuilder insert(final Object entity) {
return insert(entity, null);
}
public static CQLBuilder insert(final Object entity, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
parseInsertEntity(instance, entity, excludedPropNames);
return instance;
}
public static CQLBuilder insert(final Class> entityClass) {
return insert(entityClass, null);
}
public static CQLBuilder insert(final Class> entityClass, final Set excludedPropNames) {
return insert(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder insertInto(final Class> entityClass) {
return insertInto(entityClass, null);
}
public static CQLBuilder insertInto(final Class> entityClass, final Set excludedPropNames) {
return insert(entityClass, excludedPropNames).into(entityClass);
}
public static CQLBuilder select(final String expr) {
return select(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder select(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder select(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNameList = columnNames;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnNames
* @return
*/
public static CQLBuilder select(final String expr, final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder select(final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnAliases = columnAliases;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnAliases
* @return
*/
public static CQLBuilder select(final String expr, final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnAliases = columnAliases;
return instance;
}
public static CQLBuilder select(final Class> entityClass) {
return select(entityClass, null);
}
public static CQLBuilder select(final Class> entityClass, final Set excludedPropNames) {
return select(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder selectFrom(final Class> entityClass) {
return selectFrom(entityClass, null);
}
public static CQLBuilder selectFrom(final Class> entityClass, final Set excludedPropNames) {
return select(entityClass, excludedPropNames).from(entityClass);
}
public static CQLBuilder update(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.UPDATE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder update(final Class> entityClass) {
return update(ClassUtil.getSimpleClassName(entityClass));
}
public static CQLBuilder delete(final String expr) {
return delete(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder delete(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder delete(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder delete(final Class> entityClass) {
return delete(entityClass, null);
}
public static CQLBuilder delete(final Class> entityClass, final Set excludedPropNames) {
return delete(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder deleteFrom(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder deleteFrom(final Class> entityClass) {
return deleteFrom(ClassUtil.getSimpleClassName(entityClass));
}
public static CQLBuilder deleteFrom(final Class> entityClass, final Set excludedPropNames) {
return delete(entityClass, excludedPropNames).from(entityClass);
}
}
/**
* All the property/column names in collection/map/entity/condition will be converted to upper case with underscore.
*
* @author haiyang li
*
*/
public static final class E2 extends CQLBuilder {
E2() {
super(NamingPolicy.UPPER_CASE_WITH_UNDERSCORE, CQLPolicy.CQL);
}
static E2 createInstance() {
return new E2();
}
public static CQLBuilder insert(final String expr) {
return insert(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder insert(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder insert(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder insert(final Map props) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.props = props;
return instance;
}
public static CQLBuilder insert(final Object entity) {
return insert(entity, null);
}
public static CQLBuilder insert(final Object entity, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
parseInsertEntity(instance, entity, excludedPropNames);
return instance;
}
public static CQLBuilder insert(final Class> entityClass) {
return insert(entityClass, null);
}
public static CQLBuilder insert(final Class> entityClass, final Set excludedPropNames) {
return insert(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder insertInto(final Class> entityClass) {
return insertInto(entityClass, null);
}
public static CQLBuilder insertInto(final Class> entityClass, final Set excludedPropNames) {
return insert(entityClass, excludedPropNames).into(entityClass);
}
public static CQLBuilder select(final String expr) {
return select(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder select(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder select(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNameList = columnNames;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnNames
* @return
*/
public static CQLBuilder select(final String expr, final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder select(final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnAliases = columnAliases;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnAliases
* @return
*/
public static CQLBuilder select(final String expr, final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnAliases = columnAliases;
return instance;
}
public static CQLBuilder select(final Class> entityClass) {
return select(entityClass, null);
}
public static CQLBuilder select(final Class> entityClass, final Set excludedPropNames) {
return select(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder selectFrom(final Class> entityClass) {
return selectFrom(entityClass, null);
}
public static CQLBuilder selectFrom(final Class> entityClass, final Set excludedPropNames) {
return select(entityClass, excludedPropNames).from(entityClass);
}
public static CQLBuilder update(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.UPDATE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder update(final Class> entityClass) {
return update(entityClass, null);
}
public static CQLBuilder update(final Class> entityClass, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.UPDATE;
instance.tableName = ClassUtil.getSimpleClassName(entityClass);
instance.columnNameList = getPropNamesByClass(entityClass, excludedPropNames);
return instance;
}
public static CQLBuilder delete(final String expr) {
return delete(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder delete(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder delete(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder delete(final Class> entityClass) {
return delete(entityClass, null);
}
public static CQLBuilder delete(final Class> entityClass, final Set excludedPropNames) {
return delete(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder deleteFrom(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder deleteFrom(final Class> entityClass) {
return deleteFrom(ClassUtil.getSimpleClassName(entityClass));
}
public static CQLBuilder deleteFrom(final Class> entityClass, final Set excludedPropNames) {
return delete(entityClass, excludedPropNames).from(entityClass);
}
}
/**
* All the property/column names in collection/map/entity/condition will be converted to upper case with underscore and the cql will be parameterized with question mark.
*
* @author haiyang li
*
*/
public static final class RE2 extends CQLBuilder {
RE2() {
super(NamingPolicy.UPPER_CASE_WITH_UNDERSCORE, CQLPolicy.RAW_CQL);
}
static RE2 createInstance() {
return new RE2();
}
public static CQLBuilder insert(final String expr) {
return insert(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder insert(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder insert(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder insert(final Map props) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.props = props;
return instance;
}
public static CQLBuilder insert(final Object entity) {
return insert(entity, null);
}
public static CQLBuilder insert(final Object entity, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
parseInsertEntity(instance, entity, excludedPropNames);
return instance;
}
public static CQLBuilder insert(final Class> entityClass) {
return insert(entityClass, null);
}
public static CQLBuilder insert(final Class> entityClass, final Set excludedPropNames) {
return insert(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder insertInto(final Class> entityClass) {
return insertInto(entityClass, null);
}
public static CQLBuilder insertInto(final Class> entityClass, final Set excludedPropNames) {
return insert(entityClass, excludedPropNames).into(entityClass);
}
public static CQLBuilder select(final String expr) {
return select(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder select(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder select(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNameList = columnNames;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnNames
* @return
*/
public static CQLBuilder select(final String expr, final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder select(final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnAliases = columnAliases;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnAliases
* @return
*/
public static CQLBuilder select(final String expr, final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnAliases = columnAliases;
return instance;
}
public static CQLBuilder select(final Class> entityClass) {
return select(entityClass, null);
}
public static CQLBuilder select(final Class> entityClass, final Set excludedPropNames) {
return select(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder selectFrom(final Class> entityClass) {
return selectFrom(entityClass, null);
}
public static CQLBuilder selectFrom(final Class> entityClass, final Set excludedPropNames) {
return select(entityClass, excludedPropNames).from(entityClass);
}
public static CQLBuilder update(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.UPDATE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder update(final Class> entityClass) {
return update(entityClass, null);
}
public static CQLBuilder update(final Class> entityClass, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.UPDATE;
instance.tableName = ClassUtil.getSimpleClassName(entityClass);
instance.columnNameList = getPropNamesByClass(entityClass, excludedPropNames);
return instance;
}
public static CQLBuilder delete(final String expr) {
return delete(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder delete(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder delete(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder delete(final Class> entityClass) {
return delete(entityClass, null);
}
public static CQLBuilder delete(final Class> entityClass, final Set excludedPropNames) {
return delete(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder deleteFrom(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder deleteFrom(final Class> entityClass) {
return deleteFrom(ClassUtil.getSimpleClassName(entityClass));
}
public static CQLBuilder deleteFrom(final Class> entityClass, final Set excludedPropNames) {
return delete(entityClass, excludedPropNames).from(entityClass);
}
}
/**
* All the property/column names in collection/map/entity/condition will be converted to upper case with underscore and the cql will be parameterized with named parameter with Hibernate/JPA format :parameterName
*
* @author haiyang li
*
*/
public static final class NE2 extends CQLBuilder {
NE2() {
super(NamingPolicy.UPPER_CASE_WITH_UNDERSCORE, CQLPolicy.NAMED_CQL);
}
static NE2 createInstance() {
return new NE2();
}
public static CQLBuilder insert(final String expr) {
return insert(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder insert(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder insert(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder insert(final Map props) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.props = props;
return instance;
}
public static CQLBuilder insert(final Object entity) {
return insert(entity, null);
}
public static CQLBuilder insert(final Object entity, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
parseInsertEntity(instance, entity, excludedPropNames);
return instance;
}
public static CQLBuilder insert(final Class> entityClass) {
return insert(entityClass, null);
}
public static CQLBuilder insert(final Class> entityClass, final Set excludedPropNames) {
return insert(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder insertInto(final Class> entityClass) {
return insertInto(entityClass, null);
}
public static CQLBuilder insertInto(final Class> entityClass, final Set excludedPropNames) {
return insert(entityClass, excludedPropNames).into(entityClass);
}
public static CQLBuilder select(final String expr) {
return select(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder select(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder select(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNameList = columnNames;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnNames
* @return
*/
public static CQLBuilder select(final String expr, final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder select(final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnAliases = columnAliases;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnAliases
* @return
*/
public static CQLBuilder select(final String expr, final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnAliases = columnAliases;
return instance;
}
public static CQLBuilder select(final Class> entityClass) {
return select(entityClass, null);
}
public static CQLBuilder select(final Class> entityClass, final Set excludedPropNames) {
return select(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder selectFrom(final Class> entityClass) {
return selectFrom(entityClass, null);
}
public static CQLBuilder selectFrom(final Class> entityClass, final Set excludedPropNames) {
return select(entityClass, excludedPropNames).from(entityClass);
}
public static CQLBuilder update(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.UPDATE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder update(final Class> entityClass) {
return update(entityClass, null);
}
public static CQLBuilder update(final Class> entityClass, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.UPDATE;
instance.tableName = ClassUtil.getSimpleClassName(entityClass);
instance.columnNameList = getPropNamesByClass(entityClass, excludedPropNames);
return instance;
}
public static CQLBuilder delete(final String expr) {
return delete(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder delete(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder delete(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder delete(final Class> entityClass) {
return delete(entityClass, null);
}
public static CQLBuilder delete(final Class> entityClass, final Set excludedPropNames) {
return delete(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder deleteFrom(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder deleteFrom(final Class> entityClass) {
return deleteFrom(ClassUtil.getSimpleClassName(entityClass));
}
public static CQLBuilder deleteFrom(final Class> entityClass, final Set excludedPropNames) {
return delete(entityClass, excludedPropNames).from(entityClass);
}
}
/**
* All the property/column names in collection/map/entity/condition will be converted to upper case with underscore and the cql will be parameterized with named parameter with Ibatis format #{parameterName}
.
*
* @author haiyang li
*
*/
static final class SE2 extends CQLBuilder {
SE2() {
super(NamingPolicy.UPPER_CASE_WITH_UNDERSCORE, CQLPolicy.IBATIS_CQL);
}
static SE2 createInstance() {
return new SE2();
}
public static CQLBuilder insert(final String expr) {
return insert(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder insert(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder insert(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder insert(final Map props) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.props = props;
return instance;
}
public static CQLBuilder insert(final Object entity) {
return insert(entity, null);
}
public static CQLBuilder insert(final Object entity, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
parseInsertEntity(instance, entity, excludedPropNames);
return instance;
}
public static CQLBuilder insert(final Class> entityClass) {
return insert(entityClass, null);
}
public static CQLBuilder insert(final Class> entityClass, final Set excludedPropNames) {
return insert(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder insertInto(final Class> entityClass) {
return insertInto(entityClass, null);
}
public static CQLBuilder insertInto(final Class> entityClass, final Set excludedPropNames) {
return insert(entityClass, excludedPropNames).into(entityClass);
}
public static CQLBuilder select(final String expr) {
return select(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder select(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder select(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNameList = columnNames;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnNames
* @return
*/
public static CQLBuilder select(final String expr, final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder select(final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnAliases = columnAliases;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnAliases
* @return
*/
public static CQLBuilder select(final String expr, final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnAliases = columnAliases;
return instance;
}
public static CQLBuilder select(final Class> entityClass) {
return select(entityClass, null);
}
public static CQLBuilder select(final Class> entityClass, final Set excludedPropNames) {
return select(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder selectFrom(final Class> entityClass) {
return selectFrom(entityClass, null);
}
public static CQLBuilder selectFrom(final Class> entityClass, final Set excludedPropNames) {
return select(entityClass, excludedPropNames).from(entityClass);
}
public static CQLBuilder update(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.UPDATE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder update(final Class> entityClass) {
return update(ClassUtil.getSimpleClassName(entityClass));
}
public static CQLBuilder delete(final String expr) {
return delete(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder delete(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder delete(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder delete(final Class> entityClass) {
return delete(entityClass, null);
}
public static CQLBuilder delete(final Class> entityClass, final Set excludedPropNames) {
return delete(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder deleteFrom(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder deleteFrom(final Class> entityClass) {
return deleteFrom(ClassUtil.getSimpleClassName(entityClass));
}
public static CQLBuilder deleteFrom(final Class> entityClass, final Set excludedPropNames) {
return delete(entityClass, excludedPropNames).from(entityClass);
}
}
/**
* All the property/column names in collection/map/entity/condition will be kept without any change.
*
* @author haiyang li
*
*/
public static final class E3 extends CQLBuilder {
E3() {
super(NamingPolicy.LOWER_CAMEL_CASE, CQLPolicy.CQL);
}
static E3 createInstance() {
return new E3();
}
public static CQLBuilder insert(final String expr) {
return insert(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder insert(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder insert(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder insert(final Map props) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.props = props;
return instance;
}
public static CQLBuilder insert(final Object entity) {
return insert(entity, null);
}
public static CQLBuilder insert(final Object entity, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
parseInsertEntity(instance, entity, excludedPropNames);
return instance;
}
public static CQLBuilder insert(final Class> entityClass) {
return insert(entityClass, null);
}
public static CQLBuilder insert(final Class> entityClass, final Set excludedPropNames) {
return insert(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder insertInto(final Class> entityClass) {
return insertInto(entityClass, null);
}
public static CQLBuilder insertInto(final Class> entityClass, final Set excludedPropNames) {
return insert(entityClass, excludedPropNames).into(entityClass);
}
public static CQLBuilder select(final String expr) {
return select(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder select(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder select(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNameList = columnNames;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnNames
* @return
*/
public static CQLBuilder select(final String expr, final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder select(final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnAliases = columnAliases;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnAliases
* @return
*/
public static CQLBuilder select(final String expr, final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnAliases = columnAliases;
return instance;
}
public static CQLBuilder select(final Class> entityClass) {
return select(entityClass, null);
}
public static CQLBuilder select(final Class> entityClass, final Set excludedPropNames) {
return select(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder selectFrom(final Class> entityClass) {
return selectFrom(entityClass, null);
}
public static CQLBuilder selectFrom(final Class> entityClass, final Set excludedPropNames) {
return select(entityClass, excludedPropNames).from(entityClass);
}
public static CQLBuilder update(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.UPDATE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder update(final Class> entityClass) {
return update(entityClass, null);
}
public static CQLBuilder update(final Class> entityClass, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.UPDATE;
instance.tableName = ClassUtil.getSimpleClassName(entityClass);
instance.columnNameList = getPropNamesByClass(entityClass, excludedPropNames);
return instance;
}
public static CQLBuilder delete(final String expr) {
return delete(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder delete(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder delete(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder delete(final Class> entityClass) {
return delete(entityClass, null);
}
public static CQLBuilder delete(final Class> entityClass, final Set excludedPropNames) {
return delete(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder deleteFrom(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder deleteFrom(final Class> entityClass) {
return deleteFrom(ClassUtil.getSimpleClassName(entityClass));
}
public static CQLBuilder deleteFrom(final Class> entityClass, final Set excludedPropNames) {
return delete(entityClass, excludedPropNames).from(entityClass);
}
}
/**
* All the property/column names in collection/map/entity/condition will be kept without any change and the cql will be parameterized with question mark.
*
* @author haiyang li
*
*/
public static final class RE3 extends CQLBuilder {
RE3() {
super(NamingPolicy.LOWER_CAMEL_CASE, CQLPolicy.RAW_CQL);
}
static RE3 createInstance() {
return new RE3();
}
public static CQLBuilder insert(final String expr) {
return insert(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder insert(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder insert(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder insert(final Map props) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.props = props;
return instance;
}
public static CQLBuilder insert(final Object entity) {
return insert(entity, null);
}
public static CQLBuilder insert(final Object entity, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
parseInsertEntity(instance, entity, excludedPropNames);
return instance;
}
public static CQLBuilder insert(final Class> entityClass) {
return insert(entityClass, null);
}
public static CQLBuilder insert(final Class> entityClass, final Set excludedPropNames) {
return insert(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder insertInto(final Class> entityClass) {
return insertInto(entityClass, null);
}
public static CQLBuilder insertInto(final Class> entityClass, final Set excludedPropNames) {
return insert(entityClass, excludedPropNames).into(entityClass);
}
public static CQLBuilder select(final String expr) {
return select(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder select(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder select(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNameList = columnNames;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnNames
* @return
*/
public static CQLBuilder select(final String expr, final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder select(final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnAliases = columnAliases;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnAliases
* @return
*/
public static CQLBuilder select(final String expr, final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnAliases = columnAliases;
return instance;
}
public static CQLBuilder select(final Class> entityClass) {
return select(entityClass, null);
}
public static CQLBuilder select(final Class> entityClass, final Set excludedPropNames) {
return select(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder selectFrom(final Class> entityClass) {
return selectFrom(entityClass, null);
}
public static CQLBuilder selectFrom(final Class> entityClass, final Set excludedPropNames) {
return select(entityClass, excludedPropNames).from(entityClass);
}
public static CQLBuilder update(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.UPDATE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder update(final Class> entityClass) {
return update(entityClass, null);
}
public static CQLBuilder update(final Class> entityClass, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.UPDATE;
instance.tableName = ClassUtil.getSimpleClassName(entityClass);
instance.columnNameList = getPropNamesByClass(entityClass, excludedPropNames);
return instance;
}
public static CQLBuilder delete(final String expr) {
return delete(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder delete(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder delete(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder delete(final Class> entityClass) {
return delete(entityClass, null);
}
public static CQLBuilder delete(final Class> entityClass, final Set excludedPropNames) {
return delete(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder deleteFrom(final String tableName) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.DELETE;
instance.tableName = tableName;
return instance;
}
public static CQLBuilder deleteFrom(final Class> entityClass) {
return deleteFrom(ClassUtil.getSimpleClassName(entityClass));
}
public static CQLBuilder deleteFrom(final Class> entityClass, final Set excludedPropNames) {
return delete(entityClass, excludedPropNames).from(entityClass);
}
}
/**
* All the property/column names in collection/map/entity/condition will be kept without any change and the cql will be parameterized with named parameter with Hibernate/JPA format :parameterName
*
* @author haiyang li
*
*/
public static final class NE3 extends CQLBuilder {
NE3() {
super(NamingPolicy.LOWER_CAMEL_CASE, CQLPolicy.NAMED_CQL);
}
static NE3 createInstance() {
return new NE3();
}
public static CQLBuilder insert(final String expr) {
return insert(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder insert(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder insert(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder insert(final Map props) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
instance.props = props;
return instance;
}
public static CQLBuilder insert(final Object entity) {
return insert(entity, null);
}
public static CQLBuilder insert(final Object entity, final Set excludedPropNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.ADD;
parseInsertEntity(instance, entity, excludedPropNames);
return instance;
}
public static CQLBuilder insert(final Class> entityClass) {
return insert(entityClass, null);
}
public static CQLBuilder insert(final Class> entityClass, final Set excludedPropNames) {
return insert(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder insertInto(final Class> entityClass) {
return insertInto(entityClass, null);
}
public static CQLBuilder insertInto(final Class> entityClass, final Set excludedPropNames) {
return insert(entityClass, excludedPropNames).into(entityClass);
}
public static CQLBuilder select(final String expr) {
return select(N.asArray(expr));
}
@SafeVarargs
public static CQLBuilder select(final String... columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNames = columnNames;
return instance;
}
public static CQLBuilder select(final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnNameList = columnNames;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnNames
* @return
*/
public static CQLBuilder select(final String expr, final Collection columnNames) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnNameList = columnNames;
return instance;
}
public static CQLBuilder select(final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.columnAliases = columnAliases;
return instance;
}
/**
*
* @param expr ALL | DISTINCT | DISTINCTROW...
* @param columnAliases
* @return
*/
public static CQLBuilder select(final String expr, final Map columnAliases) {
final CQLBuilder instance = createInstance();
instance.op = OperationType.QUERY;
instance.predicates = expr;
instance.columnAliases = columnAliases;
return instance;
}
public static CQLBuilder select(final Class> entityClass) {
return select(entityClass, null);
}
public static CQLBuilder select(final Class> entityClass, final Set excludedPropNames) {
return select(getPropNamesByClass(entityClass, excludedPropNames));
}
public static CQLBuilder selectFrom(final Class> entityClass) {
return selectFrom(entityClass, null);
}
public static CQLBuilder selectFrom(final Class> entityClass, final Set