
tools.xor.view.QueryFromSQL Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of xor Show documentation
Show all versions of xor Show documentation
Empowering Model Driven Architecture in J2EE applications
/**
* XOR, empowering Model Driven Architecture in J2EE applications
*
* Copyright (c) 2019, Dilip Dalton
*
* 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 tools.xor.view;
import java.util.LinkedList;
import java.util.List;
import tools.xor.Settings;
import tools.xor.service.DataStore;
public class QueryFromSQL implements QueryBuilderStrategy
{
private final View view;
private final QueryTree queryTree;
private final AggregateTree aggregateTree;
public QueryFromSQL (View view, QueryTree queryTree, AggregateTree aggregateTree)
{
this.view = view;
this.queryTree = queryTree;
this.aggregateTree = aggregateTree;
}
@Override public QueryHandle construct (Settings settings)
{
/* We first need to build the SQL from the following
* selectClause
* freestyle functions
*/
NativeQuery nativeQuery = view.getNativeQuery();
StringBuilder queryString = new StringBuilder(nativeQuery.getSelectClause());
List relevantParams = new LinkedList<>();
queryString.append(
QueryStringHelper.getFilterClause(
settings,
aggregateTree == null || aggregateTree.isRoot(queryTree),
nativeQuery.getFunction(),
nativeQuery.getParameterList(),
relevantParams));
QueryHandle handle = new QueryHandle(
queryString.toString(),
DataStore.QueryType.SQL,
nativeQuery);
handle.setBindParams(relevantParams);
// Initialized the selected columns
nativeQuery.deriveColumns(this.queryTree, handle, settings, this.aggregateTree, this.view);
return handle;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy