blob: 5c850c09c123bb76b5d311abcfb8999823d7f80a [file]
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.
*/
#ifndef IOTDB_SESSION_C_H
#define IOTDB_SESSION_C_H
#include <stdint.h>
#include <stdbool.h>
#include <stddef.h>
#ifdef __cplusplus
extern "C" {
#endif
/* ============================================================
* Error Handling
* ============================================================ */
typedef int64_t TsStatus;
#define TS_OK 0
#define TS_ERR_CONNECTION -1
#define TS_ERR_EXECUTION -2
#define TS_ERR_INVALID_PARAM -3
#define TS_ERR_NULL_PTR -4
#define TS_ERR_UNKNOWN -99
/**
* Returns the error message from the last failed C API call on the current thread.
* The returned pointer is valid until the next C API call on the same thread.
*/
const char* ts_get_last_error(void);
/* ============================================================
* Opaque Handle Types
* ============================================================ */
typedef struct CSession_ CSession;
typedef struct CTableSession_ CTableSession;
typedef struct CTablet_ CTablet;
typedef struct CSessionDataSet_ CSessionDataSet;
typedef struct CRowRecord_ CRowRecord;
/* ============================================================
* Enums (values match C++ TSDataType / TSEncoding / CompressionType)
* ============================================================ */
typedef enum {
TS_TYPE_BOOLEAN = 0,
TS_TYPE_INT32 = 1,
TS_TYPE_INT64 = 2,
TS_TYPE_FLOAT = 3,
TS_TYPE_DOUBLE = 4,
TS_TYPE_TEXT = 5,
TS_TYPE_TIMESTAMP = 8,
TS_TYPE_DATE = 9,
TS_TYPE_BLOB = 10,
TS_TYPE_STRING = 11,
/** Not a server type; used for invalid arguments / error paths in the C API. */
TS_TYPE_INVALID = 255
} TSDataType_C;
typedef enum {
TS_ENCODING_PLAIN = 0,
TS_ENCODING_DICTIONARY = 1,
TS_ENCODING_RLE = 2,
TS_ENCODING_DIFF = 3,
TS_ENCODING_TS_2DIFF = 4,
TS_ENCODING_BITMAP = 5,
TS_ENCODING_GORILLA_V1 = 6,
TS_ENCODING_REGULAR = 7,
TS_ENCODING_GORILLA = 8,
TS_ENCODING_ZIGZAG = 9,
TS_ENCODING_FREQ = 10
} TSEncoding_C;
typedef enum {
TS_COMPRESSION_UNCOMPRESSED = 0,
TS_COMPRESSION_SNAPPY = 1,
TS_COMPRESSION_GZIP = 2,
TS_COMPRESSION_LZO = 3,
TS_COMPRESSION_SDT = 4,
TS_COMPRESSION_PAA = 5,
TS_COMPRESSION_PLA = 6,
TS_COMPRESSION_LZ4 = 7,
TS_COMPRESSION_ZSTD = 8,
TS_COMPRESSION_LZMA2 = 9
} TSCompressionType_C;
typedef enum { TS_COL_TAG = 0, TS_COL_FIELD = 1, TS_COL_ATTRIBUTE = 2 } TSColumnCategory_C;
/* ============================================================
* Session Lifecycle — Tree Model
* ============================================================ */
CSession* ts_session_new(const char* host, int rpcPort, const char* username, const char* password);
CSession* ts_session_new_with_zone(const char* host, int rpcPort, const char* username,
const char* password, const char* zoneId, int fetchSize);
CSession* ts_session_new_multi_node(const char* const* nodeUrls, int urlCount, const char* username,
const char* password);
void ts_session_destroy(CSession* session);
TsStatus ts_session_open(CSession* session);
TsStatus ts_session_open_with_compression(CSession* session, bool enableRPCCompression);
TsStatus ts_session_close(CSession* session);
/* ============================================================
* Session Lifecycle — Table Model
* ============================================================ */
CTableSession* ts_table_session_new(const char* host, int rpcPort, const char* username,
const char* password, const char* database);
CTableSession* ts_table_session_new_multi_node(const char* const* nodeUrls, int urlCount,
const char* username, const char* password,
const char* database);
void ts_table_session_destroy(CTableSession* session);
TsStatus ts_table_session_open(CTableSession* session);
TsStatus ts_table_session_close(CTableSession* session);
/* ============================================================
* Timezone
* ============================================================ */
TsStatus ts_session_set_timezone(CSession* session, const char* zoneId);
TsStatus ts_session_get_timezone(CSession* session, char* buf, int bufLen);
/* ============================================================
* Database Management (Tree Model)
* ============================================================ */
TsStatus ts_session_create_database(CSession* session, const char* database);
TsStatus ts_session_delete_database(CSession* session, const char* database);
TsStatus ts_session_delete_databases(CSession* session, const char* const* databases, int count);
/* ============================================================
* Timeseries Management (Tree Model)
* ============================================================ */
TsStatus ts_session_create_timeseries(CSession* session, const char* path, TSDataType_C dataType,
TSEncoding_C encoding, TSCompressionType_C compressor);
TsStatus ts_session_create_timeseries_ex(CSession* session, const char* path, TSDataType_C dataType,
TSEncoding_C encoding, TSCompressionType_C compressor,
int propsCount, const char* const* propKeys,
const char* const* propValues, int tagsCount,
const char* const* tagKeys, const char* const* tagValues,
int attrsCount, const char* const* attrKeys,
const char* const* attrValues,
const char* measurementAlias);
TsStatus ts_session_create_multi_timeseries(CSession* session, int count, const char* const* paths,
const TSDataType_C* dataTypes,
const TSEncoding_C* encodings,
const TSCompressionType_C* compressors);
TsStatus ts_session_create_aligned_timeseries(CSession* session, const char* deviceId, int count,
const char* const* measurements,
const TSDataType_C* dataTypes,
const TSEncoding_C* encodings,
const TSCompressionType_C* compressors);
TsStatus ts_session_check_timeseries_exists(CSession* session, const char* path, bool* exists);
TsStatus ts_session_delete_timeseries(CSession* session, const char* path);
TsStatus ts_session_delete_timeseries_batch(CSession* session, const char* const* paths, int count);
/* ============================================================
* Tablet Operations
* ============================================================ */
CTablet* ts_tablet_new(const char* deviceId, int columnCount, const char* const* columnNames,
const TSDataType_C* dataTypes, int maxRowNumber);
CTablet* ts_tablet_new_with_category(const char* deviceId, int columnCount,
const char* const* columnNames, const TSDataType_C* dataTypes,
const TSColumnCategory_C* columnCategories, int maxRowNumber);
void ts_tablet_destroy(CTablet* tablet);
void ts_tablet_reset(CTablet* tablet);
int ts_tablet_get_row_count(CTablet* tablet);
TsStatus ts_tablet_set_row_count(CTablet* tablet, int rowCount);
TsStatus ts_tablet_add_timestamp(CTablet* tablet, int rowIndex, int64_t timestamp);
TsStatus ts_tablet_add_value_bool(CTablet* tablet, int colIndex, int rowIndex, bool value);
TsStatus ts_tablet_add_value_int32(CTablet* tablet, int colIndex, int rowIndex, int32_t value);
TsStatus ts_tablet_add_value_int64(CTablet* tablet, int colIndex, int rowIndex, int64_t value);
TsStatus ts_tablet_add_value_float(CTablet* tablet, int colIndex, int rowIndex, float value);
TsStatus ts_tablet_add_value_double(CTablet* tablet, int colIndex, int rowIndex, double value);
TsStatus ts_tablet_add_value_string(CTablet* tablet, int colIndex, int rowIndex, const char* value);
/* ============================================================
* Data Insertion — Tree Model (Record)
* ============================================================ */
TsStatus ts_session_insert_record_str(CSession* session, const char* deviceId, int64_t time,
int count, const char* const* measurements,
const char* const* values);
TsStatus ts_session_insert_record(CSession* session, const char* deviceId, int64_t time, int count,
const char* const* measurements, const TSDataType_C* types,
const void* const* values);
TsStatus ts_session_insert_aligned_record_str(CSession* session, const char* deviceId, int64_t time,
int count, const char* const* measurements,
const char* const* values);
TsStatus ts_session_insert_aligned_record(CSession* session, const char* deviceId, int64_t time,
int count, const char* const* measurements,
const TSDataType_C* types, const void* const* values);
/* Batch insert — multiple devices (string values) */
TsStatus ts_session_insert_records_str(CSession* session, int deviceCount,
const char* const* deviceIds, const int64_t* times,
const int* measurementCounts,
const char* const* const* measurementsList,
const char* const* const* valuesList);
TsStatus ts_session_insert_aligned_records_str(CSession* session, int deviceCount,
const char* const* deviceIds, const int64_t* times,
const int* measurementCounts,
const char* const* const* measurementsList,
const char* const* const* valuesList);
/* Batch insert — multiple devices (typed values) */
TsStatus ts_session_insert_records(CSession* session, int deviceCount, const char* const* deviceIds,
const int64_t* times, const int* measurementCounts,
const char* const* const* measurementsList,
const TSDataType_C* const* typesList,
const void* const* const* valuesList);
TsStatus ts_session_insert_aligned_records(CSession* session, int deviceCount,
const char* const* deviceIds, const int64_t* times,
const int* measurementCounts,
const char* const* const* measurementsList,
const TSDataType_C* const* typesList,
const void* const* const* valuesList);
/* Batch insert — single device (typed values) */
TsStatus ts_session_insert_records_of_one_device(CSession* session, const char* deviceId,
int rowCount, const int64_t* times,
const int* measurementCounts,
const char* const* const* measurementsList,
const TSDataType_C* const* typesList,
const void* const* const* valuesList, bool sorted);
TsStatus ts_session_insert_aligned_records_of_one_device(
CSession* session, const char* deviceId, int rowCount, const int64_t* times,
const int* measurementCounts, const char* const* const* measurementsList,
const TSDataType_C* const* typesList, const void* const* const* valuesList, bool sorted);
/* ============================================================
* Data Insertion — Tree Model (Tablet)
* ============================================================ */
TsStatus ts_session_insert_tablet(CSession* session, CTablet* tablet, bool sorted);
TsStatus ts_session_insert_aligned_tablet(CSession* session, CTablet* tablet, bool sorted);
TsStatus ts_session_insert_tablets(CSession* session, int tabletCount, const char* const* deviceIds,
CTablet** tablets, bool sorted);
TsStatus ts_session_insert_aligned_tablets(CSession* session, int tabletCount,
const char* const* deviceIds, CTablet** tablets,
bool sorted);
/* ============================================================
* Data Insertion — Table Model (Tablet)
* ============================================================ */
TsStatus ts_table_session_insert(CTableSession* session, CTablet* tablet);
/* ============================================================
* Query — Tree Model
* ============================================================ */
TsStatus ts_session_execute_query(CSession* session, const char* sql, CSessionDataSet** dataSet);
TsStatus ts_session_execute_query_with_timeout(CSession* session, const char* sql,
int64_t timeoutInMs, CSessionDataSet** dataSet);
TsStatus ts_session_execute_non_query(CSession* session, const char* sql);
TsStatus ts_session_execute_raw_data_query(CSession* session, int pathCount,
const char* const* paths, int64_t startTime,
int64_t endTime, CSessionDataSet** dataSet);
TsStatus ts_session_execute_last_data_query(CSession* session, int pathCount,
const char* const* paths, CSessionDataSet** dataSet);
TsStatus ts_session_execute_last_data_query_with_time(CSession* session, int pathCount,
const char* const* paths, int64_t lastTime,
CSessionDataSet** dataSet);
/* ============================================================
* Query — Table Model
* ============================================================ */
TsStatus ts_table_session_execute_query(CTableSession* session, const char* sql,
CSessionDataSet** dataSet);
TsStatus ts_table_session_execute_query_with_timeout(CTableSession* session, const char* sql,
int64_t timeoutInMs,
CSessionDataSet** dataSet);
TsStatus ts_table_session_execute_non_query(CTableSession* session, const char* sql);
/* ============================================================
* SessionDataSet & RowRecord — Result Iteration
* ============================================================ */
void ts_dataset_destroy(CSessionDataSet* dataSet);
/** On failure (null handle, exception), see ts_get_last_error(). */
bool ts_dataset_has_next(CSessionDataSet* dataSet);
/** On failure (null handle, exception), see ts_get_last_error(); nullptr may also mean end of rows. */
CRowRecord* ts_dataset_next(CSessionDataSet* dataSet);
int ts_dataset_get_column_count(CSessionDataSet* dataSet);
const char* ts_dataset_get_column_name(CSessionDataSet* dataSet, int index);
const char* ts_dataset_get_column_type(CSessionDataSet* dataSet, int index);
void ts_dataset_set_fetch_size(CSessionDataSet* dataSet, int fetchSize);
void ts_row_record_destroy(CRowRecord* record);
int64_t ts_row_record_get_timestamp(CRowRecord* record);
int ts_row_record_get_field_count(CRowRecord* record);
bool ts_row_record_is_null(CRowRecord* record, int index);
bool ts_row_record_get_bool(CRowRecord* record, int index);
int32_t ts_row_record_get_int32(CRowRecord* record, int index);
int64_t ts_row_record_get_int64(CRowRecord* record, int index);
float ts_row_record_get_float(CRowRecord* record, int index);
double ts_row_record_get_double(CRowRecord* record, int index);
const char* ts_row_record_get_string(CRowRecord* record, int index);
/** Returns TS_TYPE_INVALID if record is null or index is out of range. */
TSDataType_C ts_row_record_get_data_type(CRowRecord* record, int index);
/* ============================================================
* Data Deletion (Tree Model)
* ============================================================ */
TsStatus ts_session_delete_data(CSession* session, const char* path, int64_t endTime);
TsStatus ts_session_delete_data_batch(CSession* session, int pathCount, const char* const* paths,
int64_t endTime);
TsStatus ts_session_delete_data_range(CSession* session, int pathCount, const char* const* paths,
int64_t startTime, int64_t endTime);
#ifdef __cplusplus
} /* extern "C" */
#endif
#endif /* IOTDB_SESSION_C_H */