net.sf.jsqlparser.schema.Table Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jsqlparser Show documentation
Show all versions of jsqlparser Show documentation
JSqlParser parses an SQL statement and translate it into a hierarchy of Java classes.
The generated hierarchy can be navigated using the Visitor Pattern.
/*
* #%L
* JSQLParser library
* %%
* Copyright (C) 2004 - 2013 JSQLParser
* %%
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation, either version 2.1 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 Lesser Public License for more details.
*
* You should have received a copy of the GNU General Lesser Public
* License along with this program. If not, see
* .
* #L%
*/
package net.sf.jsqlparser.schema;
import net.sf.jsqlparser.expression.*;
import net.sf.jsqlparser.parser.ASTNodeAccessImpl;
import net.sf.jsqlparser.statement.select.*;
/**
* A table. It can have an alias and the schema name it belongs to.
*/
public class Table extends ASTNodeAccessImpl implements FromItem, MultiPartName {
private Database database;
private String schemaName;
private String name;
private Alias alias;
private Pivot pivot;
public Table() {
}
public Table(String name) {
this.name = name;
}
public Table(String schemaName, String name) {
this.schemaName = schemaName;
this.name = name;
}
public Table(Database database, String schemaName, String name) {
this.database = database;
this.schemaName = schemaName;
this.name = name;
}
public Database getDatabase() {
return database;
}
public void setDatabase(Database database) {
this.database = database;
}
public String getSchemaName() {
return schemaName;
}
public void setSchemaName(String string) {
schemaName = string;
}
public String getName() {
return name;
}
public void setName(String string) {
name = string;
}
@Override
public Alias getAlias() {
return alias;
}
@Override
public void setAlias(Alias alias) {
this.alias = alias;
}
@Override
public String getFullyQualifiedName() {
String fqn = "";
if (database != null) {
fqn += database.getFullyQualifiedName();
}
if (!fqn.isEmpty()) {
fqn += ".";
}
if (schemaName != null) {
fqn += schemaName;
}
if (!fqn.isEmpty()) {
fqn += ".";
}
if (name != null) {
fqn += name;
}
return fqn;
}
@Override
public void accept(FromItemVisitor fromItemVisitor) {
fromItemVisitor.visit(this);
}
public void accept(IntoTableVisitor intoTableVisitor) {
intoTableVisitor.visit(this);
}
@Override
public Pivot getPivot() {
return pivot;
}
@Override
public void setPivot(Pivot pivot) {
this.pivot = pivot;
}
@Override
public String toString() {
return getFullyQualifiedName()
+ ((pivot != null) ? " " + pivot : "")
+ ((alias != null) ? alias.toString() : "");
}
}