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

org.dashbuilder.dataset.DataSet Maven / Gradle / Ivy

/*
 * Copyright 2014 Red Hat, Inc. and/or its affiliates.
 *
 * 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 org.dashbuilder.dataset;

import java.util.Date;
import java.util.List;

import org.dashbuilder.dataset.def.DataSetDef;

public interface DataSet {

    /**
     * The metadata
     */
    DataSetMetadata getMetadata();

    /**
     * The data set definition
     */
    DataSetDef getDefinition();

    /**
     * The data set definition
     */
    void setDefinition(DataSetDef def);

    /**
     * The unique data set identifier.
     */
    String getUUID();

    /**
     * Set an unique identifier to this data set.
     */
    void setUUID(String uuid);

    /**
     * The creation date
     */
    Date getCreationDate();

    /**
     * The creation date
     */
    void setCreationDate(Date date);

    /**
     * The dataset columns
     */
    List getColumns();
    void setColumns(List columnList);

    /**
     * Get a column by its id.
     */
    DataColumn getColumnById(String id);

    /**
     * Get a column by its index (starting at 0).
     */
    DataColumn getColumnByIndex(int index);

    /**
     * Get a column's internal DataSet index.
     */
    int getColumnIndex(DataColumn dataColumn);

    /**
     * Add a brand new column.
     */
    DataSet addColumn(String id, ColumnType type);

    /**
     * Add a brand new column populated with the given values.
     */
    DataSet addColumn(String id, ColumnType type, List values);

    /**
     * Add a brand new column.
     */
    DataSet addColumn(DataColumn column);

    /**
     * Removes an existing column.
     */
    DataSet removeColumn(String id);

    /**
     * Get the number of rows in the dataset.
     */
    int getRowCount();

    /**
     * Get the value at a given cell.
     * @param row The cell row (the first row is 0).
     * @param column The cell column (the first column is 0).
     */
    Object getValueAt(int row, int column);

    /**
     * Get the value at a given cell.
     * @param row The cell row (the first row is 0).
     * @param columnId The cell column id.
     */
    Object getValueAt(int row, String columnId);

    /**
     * Set the value at a given cell.
     * @param row The cell row (the first row is 0).
     * @param column The cell column (the first column is 0).
     */
    DataSet setValueAt(int row, int column, Object value);

    /**
     * Set all the values for a given row.
     * @param row The cell row (the first row is 0).
     */
    DataSet setValuesAt(int row, Object... values);

    /**
     * Add a row at the given position.
     * @param row The cell row (the first row is 0).
     */
    DataSet addValuesAt(int row, Object... values);

    /**
     * Add a row at the end of the data set.
     */
    DataSet addValues(Object... values);

    /**
     * Add an empty row at the given position.
     * @param row The cell row (the first row is 0).
     */
    DataSet addEmptyRowAt(int row);

    /**
     * Returns a data set containing only the specified row sub set.
     * @param offset The position where the row sub set starts (starting at 0).
     * @param rows The number of rows to get.
     * @return A trimmed data set.
     */
    DataSet trim(int offset, int rows);

    /**
     * Returns a data set containing only the specified row sub set.
     * @param rows The row ordinals to add to the resulting data set.
     * @return A trimmed data set.
     */
    DataSet trim(List rows);

    /**
     * If this data set is the result of a trim operation this method will return
     * the total number of rows existing before trim.
     *
     * @return The total number of existing rows before any trim operation (if any) or -1 if no trim operation has been carried out.
     */
    int getRowCountNonTrimmed();

    /**
     * If this data set is the result of a trim operation this method will return
     * the total number of rows existing before trim.
     */
    void setRowCountNonTrimmed(int count);

    /**
     * Build a data set with the same structure as this but containing no data.
     */
    DataSet cloneEmpty();

    /**
     * Build a data set with the same structure and content.
     */
    DataSet cloneInstance();

    /**
     * Return the estimated memory (in bytes) the data set is consuming.
     * @return The number of bytes
     */
    long getEstimatedSize();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy