/*
* Copyright (c) 2013-2015 Josef Hardi <josef.hardi@gmail.com>
*
* 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.obidea.semantika.mapping.base.sql;
import java.util.HashSet;
import java.util.Set;
import com.obidea.semantika.database.sql.base.ISqlColumn;
import com.obidea.semantika.database.sql.base.ISqlExpression;
import com.obidea.semantika.database.sql.base.ISqlExpressionVisitor;
import com.obidea.semantika.database.sql.base.ISqlJoin;
import com.obidea.semantika.database.sql.base.SqlJoinCondition;
import com.obidea.semantika.knowledgebase.TermSubstitutionBinding;
public class SqlJoin extends SyntacticSugarMediator implements ISqlJoin
{
private static final long serialVersionUID = 629451L;
private boolean mIsInnerJoin = false;
private boolean mIsLeftJoin = false;
private ISqlExpression mLeftExpression;
private ISqlExpression mRightExpression;
private Set<SqlJoinCondition> mJoinConditions = new HashSet<SqlJoinCondition>();
private Set<ISqlExpression> mFilters = new HashSet<ISqlExpression>();
public SqlJoin()
{
super();
}
@Override
public String getName()
{
if (isInnerJoin()) {
return "JOIN"; //$NON-NLS-1$
}
else if (isLeftJoin()) {
return "LEFTJOIN"; //$NON-NLS-1$
}
else {
return "<undefined>"; //$NON-NLS-1$
}
}
@Override
public void setInnerJoin(boolean value)
{
mIsInnerJoin = value;
}
@Override
public boolean isInnerJoin()
{
return mIsInnerJoin;
}
@Override
public void setLeftJoin(boolean value)
{
mIsLeftJoin = value;
}
@Override
public boolean isLeftJoin()
{
return mIsLeftJoin;
}
public void setLeftExpression(ISqlExpression expression)
{
mLeftExpression = expression;
}
@Override
public ISqlExpression getLeftExpression()
{
return mLeftExpression;
}
public void setRightExpression(ISqlExpression expression)
{
mRightExpression = expression;
}
@Override
public ISqlExpression getRightExpression()
{
return mRightExpression;
}
@Override
public void addJoinCondition(ISqlColumn leftColumn, ISqlColumn rightColumn)
{
mJoinConditions.add(new SqlJoinCondition(leftColumn, rightColumn));
}
public void addJoinConditions(Set<SqlJoinCondition> joinConditions)
{
mJoinConditions.addAll(joinConditions);
}
@Override
public Set<SqlJoinCondition> getJoinConditions()
{
return mJoinConditions;
}
@Override
public boolean hasJoinConditions()
{
return mJoinConditions.isEmpty() ? false : true;
}
@Override
public void addFilter(ISqlExpression filter)
{
mFilters.add(filter);
}
public void addFilters(Set<ISqlExpression> filters)
{
mFilters.addAll(filters);
}
@Override
public Set<ISqlExpression> getFilters()
{
return mFilters;
}
@Override
public boolean hasFilters()
{
return mFilters.isEmpty() ? false : true;
}
@Override
public void apply(TermSubstitutionBinding binding)
{
// NO-OP
}
@Override
public void accept(ISqlExpressionVisitor visitor)
{
visitor.visit(this);
}
@Override
public int hashCode()
{
final int prime = 31;
int result = 1;
result = prime * result + getName().hashCode();
result = prime * result + getLeftExpression().hashCode();
result = prime * result + getRightExpression().hashCode();
result = prime * result + getJoinConditions().hashCode();
result = prime * result + getFilters().hashCode();
return result;
}
@Override
public boolean equals(Object obj)
{
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (getClass() != obj.getClass()) {
return false;
}
final SqlJoin other = (SqlJoin) obj;
return getName().equals(other.getName())
&& getLeftExpression().equals(other.getLeftExpression())
&& getRightExpression().equals(other.getRightExpression())
&& getJoinConditions().equals(other.getJoinConditions())
&& getFilters().equals(other.getFilters());
}
@Override
public String toString()
{
StringBuilder sb = new StringBuilder();
sb.append(getName());
sb.append("("); //$NON-NLS-1$
sb.append(mLeftExpression);
sb.append(", "); //$NON-NLS-1$
sb.append(mRightExpression);
sb.append(", "); //$NON-NLS-1$
sb.append(mJoinConditions);
sb.append(", "); //$NON-NLS-1$
sb.append(mFilters);
sb.append(")"); //$NON-NLS-1$
return sb.toString();
}
}