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

Alachisoft.NCache.Common.DataStructures.RecordSet Maven / Gradle / Ivy

package Alachisoft.NCache.Common.DataStructures;

import Alachisoft.NCache.Common.Enum.AggregateFunctionType;
import com.alachisoft.ncache.runtime.util.JvDateFormatter;
import com.alachisoft.ncache.serialization.core.io.ICompactSerializable;
import com.alachisoft.ncache.serialization.core.io.NCacheObjectInput;
import com.alachisoft.ncache.serialization.core.io.NCacheObjectOutput;

import java.io.IOException;
import java.util.Date;

public class RecordSet implements ICompactSerializable {
    private int _rowCount;
    private int _hiddenColumnCount;
    private java.util.HashMap _dataIntIndex;
    private java.util.HashMap _dataStringIndex;
    /**
     * Initializes new 
     */
    public RecordSet() {
        _rowCount = 0;
        _hiddenColumnCount = 0;
        _dataIntIndex = new java.util.HashMap();
        _dataStringIndex = new java.util.HashMap();
    }

    /**
     * Gets  of object
     *
     * @param obj Object whose  is required
     * @return  of object
     */
    public static ColumnDataType ToColumnDataType(Object obj) {
        if (obj instanceof String) {
            return ColumnDataType.String;
        } else if (obj instanceof java.math.BigDecimal) {
            return ColumnDataType.Decimal;
        } else if (obj instanceof Short) {
            return ColumnDataType.Int16;
        } else if (obj instanceof Integer) {
            return ColumnDataType.Int32;
        } else if (obj instanceof Long) {
            return ColumnDataType.Int64;
        } else if (obj instanceof Short) {
            return ColumnDataType.UInt16;
        } else if (obj instanceof Integer) {
            return ColumnDataType.UInt32;
        } else if (obj instanceof Long) {
            return ColumnDataType.UInt64;
        } else if (obj instanceof Double) {
            return ColumnDataType.Double;
        } else if (obj instanceof Float) {
            return ColumnDataType.Float;
        } else if (obj instanceof Byte) {
            return ColumnDataType.Byte;
        } else if (obj instanceof Byte) {
            return ColumnDataType.SByte;
        } else if (obj instanceof Boolean) {
            return ColumnDataType.Bool;
        } else if (obj instanceof Character) {
            return ColumnDataType.Char;
        } else if (obj instanceof java.util.Date) {
            return ColumnDataType.DateTime;
        } else if (obj instanceof com.alachisoft.ncache.runtime.queries.AverageResult)//AVG BUG
        {
            return ColumnDataType.AverageResult;
        } else {
            return ColumnDataType.Object;
        }
    }

    /**
     * Converts String represenation to appropriate object of specified 
     *
     * @param stringValue String representation of object
     * @param dataType     of object
     * @return
     */
    public static Object ToObject(String stringValue, ColumnDataType dataType) {
        switch (dataType) {
            case Bool:
                return Boolean.parseBoolean(stringValue);
            case Byte:
                return Byte.parseByte(stringValue);
            case Char:
                return Character.valueOf(stringValue.charAt(0));
            case DateTime:
                try {
                    java.text.DateFormat formatter = new JvDateFormatter("dd/MM/yyyy/HH/mm/ss/SSSS/ZZZZ");
                    formatter.parse(stringValue);
                    return formatter.getCalendar().getTime();
                } catch (Exception e) {
                    throw new RuntimeException(e.getMessage(), e);
                }
            case Decimal:
                return new java.math.BigDecimal(stringValue);
            case Double:
                return Double.parseDouble(stringValue);
            case Float:
                return Float.parseFloat(stringValue);
            case Int16:
                return Short.parseShort(stringValue);
            case Int32:
                return Integer.parseInt(stringValue);
            case Int64:
                return Long.parseLong(stringValue);
            case SByte:
                return Byte.parseByte(stringValue);
            case String:
                return stringValue;
            case UInt16:
                return Short.valueOf(stringValue);
            case UInt32:
                return Integer.valueOf(stringValue);
            case UInt64:
                return Long.valueOf(stringValue);
            default:
                throw new java.lang.ClassCastException();
        }
    }

    public static String GetString(Object obj, ColumnDataType dataType) {
        if (dataType == Alachisoft.NCache.Common.DataStructures.ColumnDataType.DateTime) {
            java.text.DateFormat formatter = new JvDateFormatter("dd/MM/yyyy/HH/mm/ss/SSSS/ZZZZ");
            String str = formatter.format((Date) obj);
            return str;
        } else {
            return obj.toString();
        }
    }

    /**
     * Gets Dictionary containg all column indexes and 
     */
    public final java.util.HashMap getData() {
        return _dataIntIndex;
    }

    /**
     * Adds specified value in speicified cell
     *
     * @param value    value to be added
     * @param rowID    Zero base row index in 
     * @param columnID Zero base column index in 
     */
    public final void Add(Object value, int rowID, int columnID) {
        if (_rowCount <= rowID) {
            throw new IllegalArgumentException("Invalid rowID. No of rows in RecordSet are less than specified rowID.");
        }
        if (this.getColumnCount() <= columnID) {
            throw new IllegalArgumentException("Invalid columnID. No of columns in RecordSet are less than specified columnID.");
        }
        _dataIntIndex.get(columnID).Add(value, rowID);
    }

    /**
     * Adds specified value in speicified cell
     *
     * @param value      value to be added
     * @param rowID      Zero base row index in 
     * @param columnName Column name in 
     */
    public final void Add(Object value, int rowID, String columnName) {
        if (_rowCount <= rowID) {
            throw new IllegalArgumentException("Invalid rowID. No of rows in RecordSet are less than specified rowID.");
        }
        if (!_dataStringIndex.containsKey(columnName)) {
            throw new IllegalArgumentException("Invalid columnName. Specified column does not exist in RecordSet.");
        }
        _dataStringIndex.get(columnName).Add(value, rowID);
    }

    /**
     * Adds a new row in 
     */
    public final void AddRow() {
        _rowCount++;
    }

    /**
     * Adds a new column in 
     *
     * @param columnName Name of column
     * @param isHidden   IsHidden property of column
     * @return fasle if column with same name already exists, true otherwise
     */
    public final boolean AddColumn(String columnName, boolean isHidden) {
        return this.AddColumn(columnName, isHidden, ColumnType.AttributeColumn, AggregateFunctionType.NOTAPPLICABLE);
    }

    /**
     * Adds a new column in 
     *
     * @param columnName            Name of column
     * @param isHidden              IsHidden property of column
     * @param aggregateFunctionType
     * @return fasle if column with same name already exists, true otherwise
     */
    public final boolean AddColumn(String columnName, boolean isHidden, AggregateFunctionType aggregateFunctionType) {
        return this.AddColumn(columnName, isHidden, ColumnType.AttributeColumn, aggregateFunctionType);
    }

    /**
     * Adds a new column in 
     *
     * @param columnName            Name of column
     * @param isHidden              IsHidden property of column
     * @param columnType
     * @param aggregateFunctionType
     * @return fasle if column with same name already exists, true otherwise
     */
    public final boolean AddColumn(String columnName, boolean isHidden, ColumnType columnType, AggregateFunctionType aggregateFunctionType) {
        if (_dataStringIndex.containsKey(columnName)) {
            return false;
        }
        RecordColumn column = new RecordColumn(columnName, isHidden);
        column.setType(columnType);
        column.setAggregateFunctionType(aggregateFunctionType);
        _dataIntIndex.put(this.getColumnCount(), column);
        _dataStringIndex.put(columnName, column);
        if (isHidden)
            _hiddenColumnCount++;
        return true;
    }

    /**
     * Gets object at specified cell
     *
     * @param rowID    Zero based row ID
     * @param columnID Zero based column ID
     * @return Object at specified row and column
     */
    public final Object GetObject(int rowID, int columnID) {
        if (_rowCount <= rowID) {
            throw new IllegalArgumentException("Invalid rowID. No of rows in RecordSet are less than specified rowID.");
        }
        if (this.getColumnCount() <= columnID) {
            throw new IllegalArgumentException("Invalid columnID. No of columns in RecordSet are less than specified columnID.");
        }
        return _dataIntIndex.get(columnID).Get(rowID);
    }

    /**
     * Gets object at specified cell
     *
     * @param rowID      Zero based row ID
     * @param columnName Name of column
     * @return Object at specified row and column
     */
    public final Object GetObject(int rowID, String columnName) {
        if (_rowCount <= rowID) {
            throw new IllegalArgumentException("Invalid rowID. No of rows in RecordSet are less than specified rowID.");
        }
        if (!_dataStringIndex.containsKey(columnName)) {
            throw new IllegalArgumentException("Invalid columnName. Specified column does not exist in RecordSet.");
        }
        return _dataStringIndex.get(columnName).Get(rowID);
    }

    /**
     * Gets column name of specified column ID
     *
     * @param columnID Zero based ID of column
     * @return Name of column
     */
    public final String GetColumnName(int columnID) {
        if (this.getColumnCount() <= columnID) {
            throw new IllegalArgumentException("Invalid columnID. No of columns in RecordSet are less than specified columnID.");
        }
        return _dataIntIndex.get(columnID).getName();
    }

    public final int GetColumnIndex(String columnName) {
        if (!_dataStringIndex.containsKey(columnName)) {
            throw new IllegalArgumentException("Invalid column name. Specified column does not exist in RecordSet.");
        }
        for (int i = 0; i < _dataIntIndex.size(); i++) {
            if (_dataIntIndex.get(i).getName() == columnName)
                return i;
        }
        throw new IllegalArgumentException("Invalid column name. Specified column does not exist in RecordSet.");

    }

    /**
     * Sets IsHidden property of specified column name true
     *
     * @param columnName Name of column
     */
    public final void HideColumn(String columnName) {
        if (_dataStringIndex.containsKey(columnName)) {
            if (_dataStringIndex.get(columnName).getIsHidden())
                return;
            else {
                _dataStringIndex.get(columnName).setIsHidden(true);
                _hiddenColumnCount++;
            }
        }
    }

    /**
     * Sets IsHidden property of specified column false
     *
     * @param columnName Name of column
     */
    public final void UnHideColumn(String columnName) {
        if (_dataStringIndex.containsKey(columnName)) {
            if (!_dataStringIndex.get(columnName).getIsHidden())
                return;
            else {
                _dataStringIndex.get(columnName).setIsHidden(false);
                _hiddenColumnCount--;
            }
        } else {
            throw new IllegalArgumentException("Invalid columnName. Specified column does not exist in RecordSet.");
        }
    }

    public final boolean GetIsHiddenColumn(int columnID) {
        if (this.getColumnCount() <= columnID) {
            throw new IllegalArgumentException("Invalid columnID. No of columns in RecordSet are less than specified columnID.");
        } else {
            return _dataIntIndex.get(columnID).getIsHidden();
        }
    }

    public final boolean GetIsHiddenColumn(String columnName) {
        if (_dataStringIndex.containsKey(columnName)) {
            return _dataStringIndex.get(columnName).getIsHidden();
        } else {
            throw new IllegalArgumentException("Invalid columnName. Specified column does not exist in RecordSet.");
        }
    }

    /**
     * Sets  of specified column
     *
     * @param columnName Name of column
     * @param dataType    to set
     */
    public final void SetColumnDataType(String columnName, ColumnDataType dataType) {
        if (_dataStringIndex.containsKey(columnName)) {
            _dataStringIndex.get(columnName).setDataType(dataType);
        } else {
            throw new IllegalArgumentException("Invalid columnName. Specified column does not exist in RecordSet.");
        }
    }

    /**
     * Sets  of specified column
     *
     * @param index    Zero based index of column
     * @param dataType  to set
     */
    public final void SetColumnDataType(int index, ColumnDataType dataType) {
        if (_dataIntIndex.containsKey(index)) {
            _dataIntIndex.get(index).setDataType(dataType);
        } else {
            throw new IllegalArgumentException("Invalid column index. Specified column does not exist in RecordSet.");
        }
    }

    /**
     * Gets  of specified column
     *
     * @param columnName Name of column
     * @return  of column
     */
    public final ColumnDataType GetColumnDataType(String columnName) {
        if (_dataStringIndex.containsKey(columnName)) {
            return _dataStringIndex.get(columnName).getDataType();
        } else {
            throw new IllegalArgumentException("Invalid columnName. Specified column does not exist in RecordSet.");
        }
    }

    /**
     * Gets  of specified column
     *
     * @param index Zero based index of column
     * @return  of column
     */
    public final ColumnDataType GetColumnDataType(int index) {
        if (_dataIntIndex.containsKey(index)) {
            return _dataIntIndex.get(index).getDataType();
        } else {
            throw new IllegalArgumentException("Invalid column index. Specified column does not exist in RecordSet.");
        }
    }

    /**
     * Sets  of specifeid column
     *
     * @param columnName Name of column
     * @param type        to set
     */
    public final void SetAggregateFunctionType(String columnName, AggregateFunctionType type) {
        _dataStringIndex.get(columnName).setAggregateFunctionType(type);
    }

    /**
     * Gets  of specified column
     *
     * @param columnName Name of column
     * @return  of column
     */
    public final AggregateFunctionType GetAggregateFunctionType(String columnName) {
        return _dataStringIndex.get(columnName).getAggregateFunctionType();
    }

    /**
     * Removes last column from 
     */
    public final void RemoveLastColumn() {
        _dataStringIndex.remove(this.GetColumnName(this.getColumnCount() - 1));
        if (_dataIntIndex.get(_dataIntIndex.size() - 1).getIsHidden())
            _hiddenColumnCount--;
        _dataIntIndex.remove(_dataIntIndex.size() - 1);
    }

    /**
     * Gets number of rows in 
     */
    public final int getRowCount() {
        return _rowCount;
    }

    /**
     * Gets number of columns in 
     */
    public final int getColumnCount() {
        return _dataStringIndex.size();
    }

    public final int getHiddenColumnCount() {
        return _hiddenColumnCount;
    }

    public final int getColumnIndex(String columnName) {
        if (!_dataStringIndex.containsKey(columnName))
            throw new IllegalArgumentException("Invalid column name. Specified column does not exist in RecordSet.");
        for (int i = 0; i < _dataIntIndex.size(); i++) {
            if (_dataIntIndex.get(i).getName().equals(columnName))
                return i;
        }
        throw new IllegalArgumentException("Invalid column name. Specified column does not exist in RecordSet.");
    }

    /**
     * Merges 
     *
     * @param recordSet  to merge
     */
    public final void Union(RecordSet recordSet) {
        if (this.getColumnCount() != recordSet.getColumnCount()) {
            throw new UnsupportedOperationException("Cannot compute union of two RecordSet with different number of columns.");
        }

        int thisRowCount = this._rowCount;
        for (int i = 0; i < recordSet.getRowCount(); i++) {
            boolean recordMatch = false;

            for (int l = 0; l < thisRowCount; l++) {
                boolean rowMatch = true;
                java.util.ArrayList aggregateColumns = new java.util.ArrayList();

                for (java.util.Map.Entry kvp : _dataStringIndex.entrySet()) {

                    if (kvp.getValue().getType() == ColumnType.AggregateResultColumn) {
                        aggregateColumns.add(kvp.getKey());
                        continue;
                    }

                    if (recordSet.GetObject(i, kvp.getKey()).equals(this.GetObject(l, kvp.getKey()))) {
                        continue;
                    }

                    rowMatch = false;
                    break;
                }

                if (rowMatch) {
                    //Rows matched, merging aggregate result columns
                    for (String column : aggregateColumns) {
                        switch (this.GetAggregateFunctionType(column)) {
                            case SUM:
                                java.math.BigDecimal a = new java.math.BigDecimal(0);
                                java.math.BigDecimal b = new java.math.BigDecimal(0);

                                Object thisVal = this.GetObject(i, column);
                                Object otherVal = recordSet.GetObject(i, column);

                                java.math.BigDecimal sum = null;

                                if (thisVal == null && otherVal != null) {
                                    sum = (java.math.BigDecimal) otherVal;
                                } else if (thisVal != null && otherVal == null) {
                                    sum = (java.math.BigDecimal) thisVal;
                                } else if (thisVal != null && otherVal != null) {
                                    a = (java.math.BigDecimal) thisVal;
                                    b = (java.math.BigDecimal) otherVal;
                                    sum = a.add(b);
                                }

                                if (sum != null) {
                                    this.Add(sum, i, column);
//                                        this.AggregateFunctionResult = sum;
                                } else {
                                    this.Add(null, i, column);
//                                        this.AggregateFunctionResult = null;
                                }
                                break;

                            case COUNT:
                                a = (java.math.BigDecimal) this.GetObject(i, column);
                                b = (java.math.BigDecimal) recordSet.GetObject(i, column);
                                java.math.BigDecimal count = a.add(b);

                                this.Add(count, i, column);
                                //this.AggregateFunctionResult = count;
                                break;

                            case MIN:
                                java.lang.Comparable thisValue = (java.lang.Comparable) this.GetObject(i, column);
                                java.lang.Comparable otherValue = (java.lang.Comparable) recordSet.GetObject(i, column);
                                java.lang.Comparable min = thisValue;

                                if (thisValue == null && otherValue != null) {
                                    min = otherValue;
                                } else if (thisValue != null && otherValue == null) {
                                    min = thisValue;
                                } else if (thisValue == null && otherValue == null) {
                                    min = null;
                                } else if (otherValue.compareTo(thisValue) < 0) {
                                    min = otherValue;
                                }

                                //this.AggregateFunctionResult = min;
                                this.Add(min, i, column);
                                break;

                            case MAX:
                                thisValue = (java.lang.Comparable) this.GetObject(i, column);
                                otherValue = (java.lang.Comparable) recordSet.GetObject(i, column);
                                java.lang.Comparable max = thisValue;

                                if (thisValue == null && otherValue != null) {
                                    max = otherValue;
                                } else if (thisValue != null && otherValue == null) {
                                    max = thisValue;
                                } else if (thisValue == null && otherValue == null) {
                                    max = null;
                                } else if (otherValue.compareTo(thisValue) > 0) {
                                    max = otherValue;
                                }

                                //this.AggregateFunctionResult = max;
                                this.Add(max, i, column);
                                break;

                            case AVG:
                                thisVal = this.GetObject(i, column);
                                otherVal = recordSet.GetObject(i, column);

                                com.alachisoft.ncache.runtime.queries.AverageResult avg = null;//AVG BUG
                                if (thisVal == null && otherVal != null) {
                                    avg = (com.alachisoft.ncache.runtime.queries.AverageResult) otherVal;//AVG BUG
                                } else if (thisVal != null && otherVal == null) {
                                    avg = (com.alachisoft.ncache.runtime.queries.AverageResult) thisVal;//AVG BUG
                                } else if (thisVal != null && otherVal != null) {
                                    com.alachisoft.ncache.runtime.queries.AverageResult thisResult = (com.alachisoft.ncache.runtime.queries.AverageResult) thisVal;//AVG BUG
                                    com.alachisoft.ncache.runtime.queries.AverageResult otherResult = (com.alachisoft.ncache.runtime.queries.AverageResult) otherVal;//AVG BUG

                                    avg = new com.alachisoft.ncache.runtime.queries.AverageResult();//AVG BUG
                                    avg.setSum(thisResult.getSum().add(otherResult.getSum()));
                                    avg.setCount(thisResult.getCount().add(otherResult.getCount()));
                                }

                                if (avg != null) {
                                    //this.AggregateFunctionResult = avg;
                                    this.Add(avg, i, column);
                                } else {
                                    //this.AggregateFunctionResult = null;
                                    this.Add(null, i, column);
                                }
                                break;
                        }
                    }
                    recordMatch = true;
                    break;
                }
            }

            if (recordMatch == true) {
                continue;
            }
            this.AddRow();
            //Append data to current record set
            for (int j = 0; j < this.getColumnCount(); j++) {
                this.Add(recordSet.GetObject(i, j), _rowCount - 1, j);
            }
        }
    }

    @Override
    public void serialize(NCacheObjectOutput out) throws IOException {
        out.write(_rowCount);
        for (java.util.Map.Entry kvp : _dataStringIndex.entrySet()) {
            out.writeObject(kvp.getKey());
            out.writeObject(kvp.getValue());
        }
    }

    @Override
    public void deserialize(NCacheObjectInput in) throws IOException, ClassNotFoundException {
        _rowCount = in.readInt();
        for (int i = 0; i < this.getColumnCount(); i++) {
            Object tempVar = in.readObject();
            String key = (String) ((tempVar instanceof String) ? tempVar : null);
            Object tempVar2 = in.readObject();
            RecordColumn col = (RecordColumn) ((tempVar2 instanceof RecordColumn) ? tempVar2 : null);
            _dataStringIndex.put(key, col);
            _dataIntIndex.put(i, col);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy