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

Alachisoft.NCache.Common.DataReader.RecordRow Maven / Gradle / Ivy

package Alachisoft.NCache.Common.DataReader;


import Alachisoft.NCache.Common.DataStructures.ColumnType;
import Alachisoft.NCache.Common.Queries.AverageResult;
import Alachisoft.NCache.Common.Queries.Order;
import Alachisoft.NCache.Common.Queries.OrderByArgument;
import com.alachisoft.ncache.serialization.core.io.InternalCompactSerializable;
import com.alachisoft.ncache.serialization.standard.io.CompactReader;
import com.alachisoft.ncache.serialization.standard.io.CompactWriter;

import java.io.IOException;
import java.math.BigDecimal;
import java.time.LocalDateTime;
import java.util.ArrayList;
import java.util.Date;

//  Copyright (c) 2020 Alachisoft
//
//  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

public class RecordRow implements Cloneable, InternalCompactSerializable {

    public boolean isSurrogate;
    private ColumnCollection _columns;
    private TwoDimensionalArray _objects;
    private Object _tag;

    public RecordRow(ColumnCollection columns) {
        _columns = columns;
        _objects = new TwoDimensionalArray(columns.getCount());
    }

    public final Object get(int index) {
        return _objects.get(index);
    }

    public final void set(int index, Object value) {
        _objects.set(index, value);
    }

    public final Object get(String columnName) {
        return _objects.get(_columns.getColumnIndex(columnName));
    }

    public final void set(String columnName, Object value) {
        _objects.set(_columns.getColumnIndex(columnName), value);
    }

    public final Object getTag() {
        return _tag;
    }

    public final void setTag(Object value) {
        _tag = value;
    }

    public final ColumnCollection getColumns() {
        return _columns;
    }

    public final void setColumns(ColumnCollection value) {
        _columns = value;
    }

    public final void setColumnValue(String columnName, Object value) {
        _objects.set(_columns.getColumnIndex(columnName), value);
    }

    public final void setColumnValue(int columnIndex, Object value) {
        _objects.set(columnIndex, value);
    }

    public final Object getColumnValue(String columnName) {
        return _objects.get(_columns.getColumnIndex(columnName));
    }

    public final Object getColumnValue(int columnIndex) {
        return _objects.get(columnIndex);
    }

    public final Object[] getAll() {
        return (Object[]) _objects.clone();
    }

    public final void setAll(ArrayList values) {
        System.arraycopy(values,0,_objects,0,values.size());
    }

    public final int getSize() {
        int size = 0;
        for (int i = 0; i < _columns.getCount(); i++) {
            switch (_columns.get(i).getDataType()) {
                case AverageResult:
                    size += 32;
                    break;
                case Bool:
                    size += 1;
                    break;
                case Byte:
                    size += 1;
                    break;
                case Char:
                    size += 2;
                    break;
                case DateTime:
                    size += 64;
                    break;
                case Decimal:
                    size += 16;
                    break;
                case Double:
                    size += 8;
                    break;
                case Float:
                    size += 4;
                    break;
                case Int16:
                    size += 2;
                    break;
                case Int32:
                    size += 4;
                    break;
                case Int64:
                    size += 8;
                    break;
                case Object:
                    break;
                case SByte:
                    size += 1;
                    break;
                case String:
                    String obj = _objects.get(i) instanceof String ? (String) _objects.get(i) : null;
                    if (obj != null) {
                        size += obj.length() * 2;
                    }
                    break;
                case UInt16:
                    size += 2;
                    break;
                case UInt32:
                    size += 4;
                    break;
                case UInt64:
                    size += 8;
                    break;
            }
        }
        return size;
    }

    public Object clone()
    {
        RecordRow row = new RecordRow(this._columns);
        row._objects = (TwoDimensionalArray)this._objects.clone();
        return row;
    }

    public final int compareOrder(RecordRow row, ArrayList orderBy) {
        int result = 0;

        for (OrderByArgument oba : orderBy) {
            Object columValue = getColumnValue(oba.getAttributeName());
            Object rowValue = row.getColumnValue(oba.getAttributeName());
            switch (_columns.get(oba.getAttributeName()).getDataType()) {
                case Bool:
                    result = ((Boolean) columValue).compareTo(((Boolean) rowValue));
                    break;
                case Byte:
                case SByte:
                    result = Byte.compare((byte) columValue, (byte) rowValue);
                    break;
                case Char:
                    Character c1 = (char) columValue;
                    Character c2 = (char) rowValue;
                    result = c1.compareTo(c2);
                    break;
                case DateTime:
                    result = ((Date) columValue).compareTo(((Date) rowValue));
                    break;
                case Decimal:
                    result = ((BigDecimal) columValue).compareTo(((BigDecimal) rowValue));
                    break;
                case Double:
                    result = ((Double) columValue).compareTo(((Double) rowValue));
                    break;
                case Float:
                    result = ((Float) columValue).compareTo(((Float) rowValue));
                    break;
                case Int16:
                case UInt16:
                    result = Short.compare((short) columValue, (short) rowValue);
                    break;
                case Int32:
                case UInt32:
                    result = ((Integer) columValue).compareTo(((Integer) rowValue));
                    break;
                case Int64:
                case UInt64:
                    result = ((Long) columValue).compareTo(((Long) rowValue));
                    break;
                case String:
                    result = compareString((String) columValue, (String) rowValue);
                case CompressedValueEntry:
                case Object:
                    break;
            }

            if (result != 0) {
                if (oba.getOrder() == Order.DESC) {
                    result = -result;
                }
                break;
            }
        }
        return result;
    }

    public final void merge(RecordRow row) {
        for (int i = 0; i < this._columns.getCount(); i++) {
            if (this._columns.get(i).getColumnType() == ColumnType.AggregateResultColumn) {
                switch (this._columns.get(i).getAggregateFunctionType()) {
                    case SUM:
                        Object thisVal = this._objects.get(i);
                        Object otherVal = row._objects.get(i);

                        BigDecimal sum = null;

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

                        if (sum != null) {
                            this._objects.set(i, sum);
                        } else {
                            this._objects.set(i, null);
                        }
                        break;

                    case COUNT:
                        BigDecimal a = (BigDecimal) this._objects.get(i);
                        BigDecimal b = (BigDecimal) row._objects.get(i);
                        BigDecimal count = a.add(b);

                        this._objects.set(i, count);
                        break;

                    case MIN:
                        java.lang.Comparable thisValue = (java.lang.Comparable) this._objects.get(i);
                        java.lang.Comparable otherValue = (java.lang.Comparable) row._objects.get(i);
                        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._objects.set(i, min);
                        break;

                    case MAX:
                        thisValue = (java.lang.Comparable) this._objects.get(i);
                        otherValue = (java.lang.Comparable) row._objects.get(i);
                        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._objects.set(i, max);
                        break;

                    case AVG:
                        thisVal = this._objects.get(i);
                        otherVal = row._objects.get(i);

                        AverageResult avg = null;
                        if (thisVal == null && otherVal != null) {
                            avg = (AverageResult) otherVal;
                        } else if (thisVal != null && otherVal == null) {
                            avg = (AverageResult) thisVal;
                        } else if (thisVal != null && otherVal != null) {
                            AverageResult thisResult = (AverageResult) thisVal;
                            AverageResult otherResult = (AverageResult) otherVal;

                            avg = new AverageResult();
                            avg.setSum(thisResult.getSum().add(otherResult.getSum()));
                            avg.setCount(thisResult.getCount().add((otherResult.getCount())));
                        }

                        this._objects.set(i, avg);
                        break;

                    // This will be always merging non negative integers.
                    case TERMFREQ:
                        thisVal = this._objects.get(i);
                        otherVal = row._objects.get(i);

                        long freqSum = 0;

                        if (thisVal == null && otherVal != null) {
                            freqSum = (long) otherVal;
                        } else if (thisVal != null && otherVal == null) {
                            freqSum = (long) thisVal;
                        } else if (thisVal != null && otherVal != null) {
                            freqSum = (long) thisVal + (long) otherVal;
                        }

                        _objects.set(i, freqSum);
                        break;
                }
            }
        }

    }

    private int compareString(String valueOne, String valueTwo) {
        int result;
        if (valueOne == null) {
            if (valueTwo == null) {
                result = 0;
            } else {
                result = -1;
            }
        } else {
            if (valueTwo == null) {
                result = 1;
            } else {
                result = valueOne.compareTo(valueTwo);
            }
        }

        return result;
    }

    @Override
    public void Deserialize(CompactReader reader) throws IOException, ClassNotFoundException {
        isSurrogate = reader.ReadBoolean();
        Object tempVar = reader.ReadObject();
        _columns = tempVar instanceof ColumnCollection ? (ColumnCollection) tempVar : null;
        _objects = new TwoDimensionalArray(_columns.getCount());
        for (int i = 0; i < _objects.size(); i++) {
            _objects.set(i, reader.ReadObject());
        }
    }

    @Override
    public void Serialize(CompactWriter writer) throws IOException {
        writer.Write(isSurrogate);
        writer.WriteObject(_columns);
        for (int i = 0; i < _objects.size(); i++) {
            writer.WriteObject(_objects.get(i));
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy