kv-4.0.9.src.oracle.kv.table.TableUtils Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of oracle-nosql-client Show documentation
Show all versions of oracle-nosql-client Show documentation
Oracle NoSQL Database Client - supplies build and runtime support for the client side of the Oracle NoSQL Database. Note that a running Oracle NoSQL Database Server (store) is required to do anything meaningful with this client.
/*-
*
* This file is part of Oracle NoSQL Database
* Copyright (C) 2011, 2016 Oracle and/or its affiliates. All rights reserved.
*
* If you have received this file as part of Oracle NoSQL Database the
* following applies to the work as a whole:
*
* Oracle NoSQL Database server software is free software: you can
* redistribute it and/or modify it under the terms of the GNU Affero
* General Public License as published by the Free Software Foundation,
* version 3.
*
* Oracle NoSQL Database 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
* Affero General Public License for more details.
*
* If you have received this file as part of Oracle NoSQL Database Client or
* distributed separately the following applies:
*
* Oracle NoSQL Database client software is free software: you can
* redistribute it and/or modify it under the terms of the Apache License
* as published by the Apache Software Foundation, version 2.0.
*
* You should have received a copy of the GNU Affero General Public License
* and/or the Apache License in the LICENSE file along with Oracle NoSQL
* Database client or server distribution. If not, see
*
* or
* .
*
* An active Oracle commercial licensing agreement for this product supersedes
* these licenses and in such case the license notices, but not the copyright
* notice, may be removed by you in connection with your distribution that is
* in accordance with the commercial licensing terms.
*
* For more information please contact:
*
* [email protected]
*
*/
package oracle.kv.table;
import oracle.kv.impl.api.table.IndexKeyImpl;
import oracle.kv.impl.api.table.RowImpl;
import oracle.kv.impl.api.table.TableImpl;
/**
* TableUtils is a utility class that encapsulates a number of useful
* functions that do not belong in any specific interface.
*
* @since 3.0
*/
public class TableUtils {
/**
* @hidden
* Private constructor to satisfy CheckStyle and to prevent
* instantiation of this utility class.
*/
private TableUtils() {
throw new AssertionError("Instantiated utility class " +
TableUtils.class);
}
/**
* Returns the size of the serialized data for the row. This includes
* only the value portion of the record and not the key and is the length
* of the byte array that will be put as a database record.
*
* @param row the Row to use for the operation
*
* @return the size of the data portion of the serialized row, in bytes
*
* @throws IllegalArgumentException if called with a {@link PrimaryKey}
* which has not data size
*/
public static int getDataSize(Row row) {
return ((RowImpl) row).getDataSize();
}
/**
* Returns the size of the serialized primary key for this row. It is the
* length of the byte array that is used as the database key for this row.
* If the key is not fully specified the value returned is that of the
* partial key.
*
* @param row the Row to use for the operation
*
* @return the size of the key portion serialized row, in bytes
*/
public static int getKeySize(Row row) {
return ((RowImpl) row).getKeySize();
}
/**
* Returns the size of the serialized index key. It is the length of the
* byte array that is used as the database key for this row. If the key is
* not fully specified the value returned is that of the partial key.
*
* @param key the IndexKey to use for the operation
*
* @return the size of the key portion serialized row, in bytes
*/
public static int getKeySize(IndexKey key) {
return ((IndexKeyImpl) key).getKeySize();
}
/**
* Get the table's ID. The ID is a system generated identifier used to
* create short keys for the table. It is not of general interest to
* applications other than browers and introspective applications.
*
* @return the numeric id value
*/
public static long getId(Table table) {
return ((TableImpl) table).getId();
}
/**
* Get the table's ID as a String. This is the string that is used in keys
* generated for this table. It is not of general interest to applications
* other than browers and introspective applications. Because of the
* serialization format this value may not be human readable.
*
* If the table is created as compatible with an R2 Avro schema this
* value is equal to the table name and is human readable.
*
* @return the string version of the id or the table name
*/
public static String getIdString(Table table) {
return ((TableImpl) table).getIdString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy