public class org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable extends java.lang.Object implements org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.statements.DDLStatement
{
private org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.expresssions.table.Table table;
private org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.expressions.table.StagedFilesTable stagedFilesTable;
private final java.util.List columns;
public void <init>()
{
org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable v;
java.util.ArrayList v;
v := @this: org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable: java.util.List columns> = v;
return;
}
public void genSql(java.lang.StringBuilder) throws org.finos.legend.engine.persistence.components.relational.sqldom.SqlDomException
{
org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause v, v, v, v, v, v;
org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.expressions.table.StagedFilesTable v;
org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable v;
java.lang.String v, v, v, v, v, v;
org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.expresssions.table.Table v;
java.util.List v;
java.lang.StringBuilder v;
v := @this: org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable;
v := @parameter: java.lang.StringBuilder;
virtualinvoke v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable: void validate()>();
v = <org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause CREATE>;
v = virtualinvoke v.<org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: java.lang.String get()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(" ");
v = <org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause OR>;
v = virtualinvoke v.<org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: java.lang.String get()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(" ");
v = <org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause REPLACE>;
v = virtualinvoke v.<org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: java.lang.String get()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(" ");
v = <org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause EXTERNAL>;
v = virtualinvoke v.<org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: java.lang.String get()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(" ");
v = <org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause TABLE>;
v = virtualinvoke v.<org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: java.lang.String get()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(" ");
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable: org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.expresssions.table.Table table>;
virtualinvoke v.<org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.expresssions.table.Table: void genSqlWithoutAlias(java.lang.StringBuilder)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(" ");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("(");
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable: java.util.List columns>;
staticinvoke <org.finos.legend.engine.persistence.components.relational.sqldom.SqlGen: void genSqlList(java.lang.StringBuilder,java.util.List,java.lang.String,java.lang.String)>(v, v, "", ",");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(")");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(" ");
v = <org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause OPTIONS>;
v = virtualinvoke v.<org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: java.lang.String get()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(" ");
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable: org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.expressions.table.StagedFilesTable stagedFilesTable>;
virtualinvoke v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.expressions.table.StagedFilesTable: void genSql(java.lang.StringBuilder)>(v);
return;
}
public void push(java.lang.Object)
{
java.util.List v;
org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable v;
java.lang.Object v;
boolean v, v, v;
v := @this: org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable;
v := @parameter: java.lang.Object;
v = v instanceof org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.expresssions.table.Table;
if v == 0 goto label;
v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable: org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.expresssions.table.Table table> = v;
goto label;
label:
v = v instanceof org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.expressions.table.StagedFilesTable;
if v == 0 goto label;
v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable: org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.expressions.table.StagedFilesTable stagedFilesTable> = v;
goto label;
label:
v = v instanceof org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.Column;
if v == 0 goto label;
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable: java.util.List columns>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
return;
}
void validate() throws org.finos.legend.engine.persistence.components.relational.sqldom.SqlDomException
{
org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable v;
org.finos.legend.engine.persistence.components.relational.sqldom.SqlDomException v, v;
org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.expresssions.table.Table v;
org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.expressions.table.StagedFilesTable v;
v := @this: org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable;
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable: org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.expressions.table.StagedFilesTable stagedFilesTable>;
if v != null goto label;
v = new org.finos.legend.engine.persistence.components.relational.sqldom.SqlDomException;
specialinvoke v.<org.finos.legend.engine.persistence.components.relational.sqldom.SqlDomException: void <init>(java.lang.String)>("stagedFilesTable is mandatory for Copy Table Command");
throw v;
label:
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateExternalTable: org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.expresssions.table.Table table>;
if v != null goto label;
v = new org.finos.legend.engine.persistence.components.relational.sqldom.SqlDomException;
specialinvoke v.<org.finos.legend.engine.persistence.components.relational.sqldom.SqlDomException: void <init>(java.lang.String)>("table is mandatory for Copy Table Command");
throw v;
label:
return;
}
}