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.
/*
* Copyright (C) 2012 Timo Vesalainen
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
package org.vesalainen.parsers.sql;
import java.util.ArrayList;
import java.util.Collection;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.List;
/**
* @author Timo Vesalainen
*/
public class SelectStatement extends Statement
{
private List> subList;
private List
> tableList;
private Condition condition;
private List sortSpecification;
private Metadata metadata;
private ErrorReporter reporter;
public SelectStatement(
Engine engine,
LinkedHashMap> placeholderMap,
List> selectList,
TableExpression tableExpression
)
{
super(engine, placeholderMap);
this.subList = selectList;
this.tableList = tableExpression.getTableList();
this.condition = tableExpression.getCondition();
this.sortSpecification = tableExpression.getSortSpecificationList();
resolv();
if (condition != null)
{
condition.associateCondition(this, true);
}
if (subList == null)
{
// asterisk
subList = new ArrayList<>();
for (Table table : tableList)
{
TableMetadata tm = engine.getTableMetadata(table.getName());
if (tm != null)
{
for (ColumnMetadata cm : tm.getColumns())
{
subList.add(new ColumnReferenceImpl(table, cm.getName()));
}
}
}
}
}
private void resolv()
{
if (subList != null)
{
for (ColumnReference cf : subList)
{
resolvColumnReference(cf);
Table table = cf.getTable();
table.addSelectListColumn(cf.getColumn());
}
}
if (condition != null)
{
condition.walk(new Resolver(), true);
}
if (sortSpecification != null)
{
for (SortSpecification ss : sortSpecification)
{
RowValue rv = ss.getRv();
if (rv instanceof ColumnReference)
{
ColumnReference cf = (ColumnReference) rv;
resolvColumnReference(cf);
Table table = cf.getTable();
table.addSortColumn(cf.getColumn());
}
}
}
}
private void resolvColumnReference(ColumnReference cf)
{
cf.resolvTable(tableList);
}
@Override
public void check(Metadata metadata, ErrorReporter reporter)
{
super.check(metadata, reporter);
this.metadata = metadata;
this.reporter = reporter;
for (ColumnReference cf : subList)
{
checkColumnReference(cf, metadata, reporter);
}
for (Table table : tableList)
{
if (table.getName() != null)
{
TableMetadata tm = metadata.getTableMetadata(table.getName());
if (tm != null)
{
if (!table.getName().equals(tm.getName()))
{
reporter.replace(tm.getName(), table.getStart(), table.getStart()+tm.getName().length());
}
}
else
{
reporter.report("table "+table.getName()+" not defined", ErrorReporter.Level.Hint, table.getSource(), table.getStart(), table.getEnd());
}
}
}
if (condition != null)
{
condition.walk(new Checker(), true);
}
if (sortSpecification != null)
{
for (SortSpecification ss : sortSpecification)
{
RowValue rv = ss.getRv();
if (rv instanceof ColumnReference)
{
ColumnReference cf = (ColumnReference) rv;
checkColumnReference(cf, metadata, reporter);
}
}
}
this.metadata = null;
this.reporter = null;
}
private void checkColumnReference(ColumnReference cf, Metadata metadata, ErrorReporter reporter)
{
Table table = cf.getTable();
if (table.getName() == null)
{
String msg = cf+" table not specified";
reporter.report(msg, ErrorReporter.Level.Fatal, cf.getSource(), cf.getStart(), cf.getEnd());
}
else
{
TableMetadata tm = metadata.getTableMetadata(table.getName());
if (tm != null)
{
if (!table.getName().equals(tm.getName()))
{
reporter.replace(tm.getName(), cf.getStart(), cf.getStart()+tm.getName().length());
}
ColumnMetadata cm = tm.getColumnMetadata(cf.getColumn());
if (cm != null)
{
if (!cf.getColumn().equals(cm.getName()))
{
reporter.replace(cm.getName(), cf.getEnd()-cf.getColumn().length(), cf.getEnd());
}
}
else
{
reporter.report("column "+cf.getColumn()+" not defined", ErrorReporter.Level.Hint, cf.getSource(), cf.getEnd()-cf.getColumn().length(), cf.getEnd());
}
}
else
{
reporter.report("table "+table.getName()+" not defined", ErrorReporter.Level.Hint, cf.getSource(), cf.getStart(), cf.getEnd());
}
}
}
@Override
public OrderedFetchResult execute()
{
return engine.select(this);
}
public UpdateableFetchResult selectForUpdate()
{
engine.beginTransaction();
return engine.selectForUpdate(this);
}
public Collection
> getTables()
{
return tableList;
}
void setWhereClause(Condition condition)
{
this.condition = condition;
}
void setOrderByClause(List list)
{
sortSpecification = list;
}
public Condition getCondition()
{
return condition;
}
public List getSortSpecification()
{
return sortSpecification;
}
public List> getSelectList()
{
return subList;
}
public List> getReferencedColumns()
{
if (sortSpecification == null || sortSpecification.isEmpty())
{
return subList;
}
else
{
List> list = new ArrayList<>();
list.addAll(subList);
for (SortSpecification ss : sortSpecification)
{
if (!list.contains(ss.getRv()))
{
list.add((ColumnReference)ss.getRv());
}
}
return list;
}
}
@Override
public boolean isSelectStatement()
{
return true;
}
public int getTableCount()
{
return tableList.size();
}
private class Resolver implements ConditionVisitor
{
@Override
public void visit(Condition condition, boolean andPath)
{
if (condition instanceof ColumnCondition)
{
ColumnCondition cc = (ColumnCondition) condition;
ColumnReference cf = cc.getColumnReference();
resolvColumnReference(cf);
Table table = cf.getTable();
table.addConditionColumn(cf.getColumn());
}
if (condition instanceof JoinCondition)
{
JoinCondition jc = (JoinCondition) condition;
ColumnReference cf = jc.getColumnReference2();
resolvColumnReference(cf);
Table table = cf.getTable();
table.addConditionColumn(cf.getColumn());
}
}
}
private class Checker implements ConditionVisitor
{
@Override
public void visit(Condition condition, boolean andPath)
{
if (condition instanceof ColumnCondition)
{
ColumnCondition cc = (ColumnCondition) condition;
ColumnReference cf = cc.getColumnReference();
checkColumnReference(cf, metadata, reporter);
}
if (condition instanceof JoinCondition)
{
JoinCondition jc = (JoinCondition) condition;
ColumnReference cf = jc.getColumnReference2();
checkColumnReference(cf, metadata, reporter);
}
}
}
}