com.bluenimble.platform.query.impls.SqlQueryCompiler Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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.bluenimble.platform.query.impls;
import java.time.LocalDateTime;
import java.time.ZoneOffset;
import java.util.Date;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import com.bluenimble.platform.Lang;
import com.bluenimble.platform.query.CompiledQuery;
import com.bluenimble.platform.query.Condition;
import com.bluenimble.platform.query.Filter;
import com.bluenimble.platform.query.GroupBy;
import com.bluenimble.platform.query.OrderBy;
import com.bluenimble.platform.query.OrderByField;
import com.bluenimble.platform.query.Query;
import com.bluenimble.platform.query.Query.Conjunction;
import com.bluenimble.platform.query.Query.Operator;
import com.bluenimble.platform.query.QueryException;
import com.bluenimble.platform.query.Select;
public class SqlQueryCompiler extends EventedQueryCompiler {
private static final long serialVersionUID = -721087118950354168L;
private static final Set> Primitives = new HashSet>();
static {
Primitives.add (Boolean.class);
Primitives.add (Boolean.TYPE);
Primitives.add (Short.class);
Primitives.add (Short.TYPE);
Primitives.add (Integer.class);
Primitives.add (Integer.TYPE);
Primitives.add (Long.class);
Primitives.add (Long.TYPE);
Primitives.add (Float.class);
Primitives.add (Float.TYPE);
Primitives.add (Double.class);
Primitives.add (Double.TYPE);
}
private static final String ParamPrefix = "p";
protected interface Sql {
String OrderBy = "order by";
String GroupBy = "group by";
String From = "from";
}
private static final Map OperatorsMap = new HashMap ();
static {
OperatorsMap.put (Operator.eq, "=");
OperatorsMap.put (Operator.neq, "<>");
OperatorsMap.put (Operator.gt, ">");
OperatorsMap.put (Operator.lt, "<");
OperatorsMap.put (Operator.gte, ">=");
OperatorsMap.put (Operator.lte, "<=");
OperatorsMap.put (Operator.like, "like");
OperatorsMap.put (Operator.nlike, "not like");
OperatorsMap.put (Operator.btw, "between");
OperatorsMap.put (Operator.nbtw, "not between");
OperatorsMap.put (Operator.all, "in");
OperatorsMap.put (Operator.in, "in");
OperatorsMap.put (Operator.nin, "not in");
OperatorsMap.put (Operator.nil, "is null");
OperatorsMap.put (Operator.nnil, "is not null");
}
protected StringBuilder buff = new StringBuilder ();
protected Map bindings;
private int counter;
protected Query.Construct dml;
private Query query;
public SqlQueryCompiler (Query.Construct dml) {
this (dml, -1);
}
public SqlQueryCompiler (Query.Construct dml, int counter) {
this.dml = dml;
this.counter = counter;
}
@Override
protected void onQuery (Timing timing, Query query) throws QueryException {
this.query = query;
}
@Override
protected void onSelect (Timing timing, Select select)
throws QueryException {
if (Timing.start.equals (timing)) {
buff.append (dml.name ());
} else {
buff.append (Lang.SPACE).append (Sql.From).append (Lang.SPACE);
entity ();
}
}
@Override
protected void onSelectField (String field, int count, int index)
throws QueryException {
if (!Query.Construct.select.equals (dml)) {
return;
}
buff.append (Lang.SPACE); field (field);
if (count == (index + 1)) {
return;
}
buff.append (Lang.COMMA);
}
@Override
protected void onConjunction (Timing timing, Conjunction conjunction, int index) throws QueryException {
switch (timing) {
case start:
if (index > 0) {
if (conjunction == null) {
conjunction = Conjunction.and;
}
buff.append (Lang.SPACE).append (conjunction.name ()).append (Lang.SPACE);
}
buff.append (Lang.PARENTH_OPEN);
break;
case end:
buff.append (Lang.PARENTH_CLOSE);
break;
default:
break;
}
}
@Override
protected void onFilter (Timing timing, Filter filter, Conjunction conjunction, boolean isWhere)
throws QueryException {
if (filter == null || filter.isEmpty ()) {
return;
}
switch (timing) {
case start:
if (isWhere) {
buff.append (Lang.SPACE).append (Query.Construct.where.name ()).append (Lang.SPACE);
} else {
buff.append (Lang.SPACE);
if (conjunction != null) {
buff.append (conjunction.name ()).append (Lang.SPACE);
}
buff.append (Lang.PARENTH_OPEN);
}
break;
case end:
if (!isWhere) {
buff.append (Lang.PARENTH_CLOSE);
}
break;
default:
break;
}
}
@Override
protected void onCondition (Condition condition, Conjunction conjunction, int index)
throws QueryException {
if (index > 0) {
if (conjunction == null) {
conjunction = Conjunction.and;
}
buff.append (Lang.SPACE).append (conjunction.name ()).append (Lang.SPACE);
}
field (condition.field ());
buff.append (Lang.SPACE).append (operatorFor (condition.operator ())).append (Lang.SPACE);
if (Operator.nil.equals (condition.operator ()) || Operator.nnil.equals (condition.operator ())) {
return;
}
if (condition.value () == null) {
return;
}
Object value = condition.value ();
if (Operator.all.equals (condition.operator ()) || Operator.in.equals (condition.operator ()) || Operator.nin.equals (condition.operator ())) {
if (List.class.isAssignableFrom (value.getClass ())) {
@SuppressWarnings("unchecked")
List
© 2015 - 2025 Weber Informatics LLC | Privacy Policy