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

com.hazelcast.sql.impl.schema.Table Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2024 Hazelcast Inc.
 *
 * Licensed under the Hazelcast Community License (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://hazelcast.com/hazelcast-community-license
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.hazelcast.sql.impl.schema;

import com.hazelcast.sql.impl.optimizer.PlanObjectKey;

import java.util.Collections;
import java.util.List;
import java.util.Set;

/**
 * Generic table metadata.
 */
public abstract class Table {

    protected boolean streaming;
    private final String schemaName;
    private final String sqlName;
    private List fields;
    private final TableStatistics statistics;

    private Set conflictingSchemas;
    private final String objectType;

    protected Table(
            String schemaName,
            String sqlName,
            List fields,
            TableStatistics statistics,
            String objectType,
            boolean isStreaming
    ) {
        this.schemaName = schemaName;
        this.sqlName = sqlName;
        this.fields = fields;
        this.statistics = statistics;
        this.objectType = objectType;
        this.streaming = isStreaming;
    }

    public String getSchemaName() {
        return schemaName;
    }

    /**
     * Returns the name of the table in SQL.
     */
    public String getSqlName() {
        return sqlName;
    }

    public boolean isStreaming() {
        return streaming;
    }

    public List getFields() {
        if (fields == null) {
            fields = initFields();
        }
        return fields;
    }

    protected List initFields() {
        throw new AssertionError("initFields() should be overridden");
    }

    public int getFieldCount() {
        return getFields().size();
    }

    @SuppressWarnings("unchecked")
    public  T getField(int index) {
        return (T) getFields().get(index);
    }

    public int getFieldIndex(String fieldName) {
        for (int i = 0; i < getFieldCount(); i++) {
            if (getField(i).getName().equals(fieldName)) {
                return i;
            }
        }
        return -1;
    }

    public TableStatistics getStatistics() {
        return statistics;
    }

    public abstract PlanObjectKey getObjectKey();

    public Set getConflictingSchemas() {
        return conflictingSchemas != null ? conflictingSchemas : Collections.emptySet();
    }

    public void setConflictingSchemas(Set conflictingSchemas) {
        this.conflictingSchemas = conflictingSchemas;
    }

    public String getObjectType() {
        return objectType;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy