com.sharksharding.sql.ast.statement.SQLJoinTableSource Maven / Gradle / Ivy
The newest version!
/*
* Copyright 1999-2101 Alibaba Group Holding Ltd.
*
* 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.sharksharding.sql.ast.statement;
import java.util.ArrayList;
import java.util.List;
import com.sharksharding.sql.ast.SQLExpr;
import com.sharksharding.sql.visitor.SQLASTVisitor;
public class SQLJoinTableSource extends SQLTableSourceImpl {
protected SQLTableSource left;
protected JoinType joinType;
protected SQLTableSource right;
protected SQLExpr condition;
protected final List using = new ArrayList();
public SQLJoinTableSource(String alias){
super(alias);
}
public SQLJoinTableSource(){
}
protected void accept0(SQLASTVisitor visitor) {
if (visitor.visit(this)) {
acceptChild(visitor, this.left);
acceptChild(visitor, this.right);
acceptChild(visitor, this.condition);
acceptChild(visitor, this.using);
}
visitor.endVisit(this);
}
public JoinType getJoinType() {
return this.joinType;
}
public void setJoinType(JoinType joinType) {
this.joinType = joinType;
}
public SQLTableSource getLeft() {
return this.left;
}
public void setLeft(SQLTableSource left) {
if (left != null) {
left.setParent(this);
}
this.left = left;
}
public SQLTableSource getRight() {
return this.right;
}
public void setRight(SQLTableSource right) {
if (right != null) {
right.setParent(this);
}
this.right = right;
}
public SQLExpr getCondition() {
return this.condition;
}
public void setCondition(SQLExpr condition) {
if (condition != null) {
condition.setParent(this);
}
this.condition = condition;
}
public List getUsing() {
return this.using;
}
public void output(StringBuffer buf) {
this.left.output(buf);
buf.append(' ');
buf.append(JoinType.toString(this.joinType));
buf.append(' ');
this.right.output(buf);
if (this.condition != null) {
buf.append(" ON ");
this.condition.output(buf);
}
}
public static enum JoinType {
COMMA(","), //
JOIN("JOIN"), //
INNER_JOIN("INNER JOIN"), //
CROSS_JOIN("CROSS JOIN"), //
NATURAL_JOIN("NATURAL JOIN"), //
NATURAL_INNER_JOIN("NATURAL INNER JOIN"), //
LEFT_OUTER_JOIN("LEFT JOIN"), //
RIGHT_OUTER_JOIN("RIGHT JOIN"), //
FULL_OUTER_JOIN("FULL JOIN"),//
STRAIGHT_JOIN("STRAIGHT_JOIN"), //
OUTER_APPLY("OUTER APPLY"),//
CROSS_APPLY("CROSS APPLY");
public final String name;
JoinType(String name){
this.name = name;
}
public static String toString(JoinType joinType) {
return joinType.name;
}
}
}