All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.nuiton.topia.service.script.table.TopiaSqlTable Maven / Gradle / Ivy

package org.nuiton.topia.service.script.table;

/*
 * #%L
 * ObServe Toolkit :: ToPIA Script service
 * %%
 * Copyright (C) 2017 - 2018 IRD, Ultreia.io
 * %%
 * 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
 * .
 * #L%
 */

import com.google.common.base.MoreObjects;
import com.google.common.collect.ImmutableSet;
import java.util.Objects;
import org.nuiton.topia.persistence.metadata.TopiaMetadataEntity;

/**
 * This object represents a sql table.
 * 

* Created on 30/12/15. * * @author Tony Chemit - [email protected] * @since 3.0.1 */ public class TopiaSqlTable { protected final TopiaMetadataEntity metadataEntity; protected final TopiaMetadataEntity associationMetadataEntity; /** * Table schema name. */ protected final String schemaName; /** * Table name. */ protected final String tableName; /** * Association table (optional only present for association table). */ private final boolean associationTable; /** * Join column name (optional only present for association table). */ private final String joinColumnName; /** * Fully table name (including the schema name). */ protected final String fullyTableName; /** * From clause. */ protected final String fromClause; /** * Where clause alias. */ protected final String whereClauseAlias; /** * Join clauses. */ protected final ImmutableSet joinClauses; public TopiaSqlTable(TopiaMetadataEntity metadataEntity, TopiaMetadataEntity associationMetadataEntity, String schemaName, String tableName, String fromClause, String whereClauseAlias, ImmutableSet joinClauses, String joinColumnName) { this.metadataEntity = metadataEntity; this.associationMetadataEntity = associationMetadataEntity; this.schemaName = schemaName.toLowerCase(); this.tableName = tableName.toLowerCase(); this.associationTable = associationMetadataEntity != null; this.fullyTableName = this.schemaName + "." + this.tableName; this.fromClause = fromClause; this.whereClauseAlias = whereClauseAlias; this.joinClauses = joinClauses; this.joinColumnName = joinColumnName; } public TopiaMetadataEntity getMetadataEntity() { return metadataEntity; } public TopiaMetadataEntity getAssociationMetadataEntity() { return associationMetadataEntity; } public String getSchemaName() { return schemaName; } public String getTableName() { return tableName; } public String getFullyTableName() { return fullyTableName; } public String getFromClause() { return fromClause; } public String getWhereClauseAlias() { return whereClauseAlias; } public String getWhereClause(ImmutableSet ids) { String result = whereClauseAlias; if (ids.size() == 1) { result += " = ?"; } else { String in = ""; for (String ignored : ids) { in += ", ?"; } result += " IN (" + in.substring(2) + ")"; } return result; } public ImmutableSet getJoinClauses() { return joinClauses; } public boolean isAssociationTable() { return associationTable; } public String getJoinColumnName() { return joinColumnName; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; TopiaSqlTable that = (TopiaSqlTable) o; return Objects.equals(fullyTableName, that.fullyTableName); } @Override public int hashCode() { return Objects.hash(fullyTableName); } @Override public String toString() { MoreObjects.ToStringHelper builder = MoreObjects.toStringHelper(this) .add("fullyTableName", this.fullyTableName); if (associationTable) { builder.add("associationTable", true); } return builder.toString(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy