A type is analogous to a traditional database schema for a table. Before data can be stored in Kinetica, a type must be specified for that data. For every type, Kinetica assigns a unique GUID. Kinetica will use the same GUID for all types with identical characteristics.
Every type in Kinetica consists of the following:
A type label serves as a tagging mechanism for the type. The type label can be any text string specified by the client. The type label serves two purposes. First, it identifies tables with similar data. Second, it helps determine a type’s uniqueness.
A type schema consists of a set of column names and their respective primitive types. Each column can also be assigned a number of pre-defined properties that determine aspects of that column, like searchability and whether or not the column is indexed.
A given column in a type schema must be of one of the following primitive types:
| General Type | Native Type | Minimum Value | Maximum Value | 
|---|---|---|---|
| int | integer (default) | -231 | 231 - 1 | 
| int16 | -215 | 215 - 1 | |
| int8 | -27 | 27 - 1 | |
| long | long (default) | -263 | 263 - 1 | 
| timestamp | 1/1/1000 00:00:00.000 | 12/31/2900 23:59:59.999 | |
| float | float (default) | -(2-2-23)*2127 | (2-2-23)*2127 | 
| double | double (default) | -(2-2-52)*21023 | (2-2-52)*21023 | 
| string | string (default) | (empty string) | (1,000,000,000 characters) | 
| char256 | (empty string) | (256 characters) | |
| char128 | (empty string) | (128 characters) | |
| char64 | (empty string) | (64 characters) | |
| char32 | (empty string) | (32 characters) | |
| char16 | (empty string) | (16 characters) | |
| char8 | (empty string) | (8 characters) | |
| char4 | (empty string) | (4 characters) | |
| char2 | (empty string) | (2 characters) | |
| char1 | (empty string) | (1 character) | |
| ipv4 | 0.0.0.0 | 255.255.255.255 | |
| decimal | -922337203685477.5808 | 922337203685477.5807 | |
| date | 1000-01-01 | 2900-12-31 | |
| time | 00:00:00.000 | 23:59:59.999 | |
| bytes | bytes (default) | (empty array) | (no configured limit) | 
The decimal type should be used instead of float or double when exact values need to be stored and rounding errors are unacceptable, such as currency.
Decimal fields are supported by most, but not all, endpoint functions. Those that currently support decimal are:
Kinetica has an additional layer of semantic regarding column data type. At the time of creation, a column can be given one or more of the supported properties, which give the column special meaning or handling. The properties can refine the data type, direct special handling, or define the keyed nature of the column. These modifiers can impact the number of records that can be stored in memory, the performance of queries, and the types of operations that can be performed on the data.
Only one of the following properties may be applied to a given column, and the column must be of the stated base type. The exception to this is nullability, which can be applied to any column in addition to the data type specifiers listed here. However, nullable is not used at type creation, but will be returned in a /show/table call. Denoting a column's nullability is API-dependent, and, with the exception of the Java API, does not involve the direct use of the nullable column property.
| Property | Base Type | Description | 
|---|---|---|
| char1 | string | Text of up to 1 character; optimizes memory, disk, and query performance | 
| char2 | string | Text of up to 2 characters; optimizes memory, disk, and query performance | 
| char4 | string | Text of up to 4 characters; optimizes memory, disk, and query performance | 
| char8 | string | Text of up to 8 characters; optimizes memory, disk, and query performance | 
| char16 | string | Text of up to 16 characters; optimizes memory, disk, and query performance | 
| char32 | string | Text of up to 32 characters; optimizes memory, disk, and query performance | 
| char64 | string | Text of up to 64 characters; optimizes memory, disk, and query performance | 
| char128 | string | Text of up to 128 characters; optimizes memory, disk, and query performance | 
| char256 | string | Text of up to 256 characters; optimizes memory, disk, and query performance | 
| date | string | Interprets a string field as a date of the form YYYY-MM-DD | 
| decimal | string | Interprets a string field as a decimal number, with up to 19 digits of precision and 4 digits of scale | 
| int8 | int | Numbers limited to 8-bit signed integers; optimizes memory and query performance | 
| int16 | int | Numbers limited to 16-bit signed integers; optimizes memory and query performance | 
| ipv4 | string | Dotted decimal IPv4 addresses of the form: A.B.C.DwhereA,B,CandDare between0and255, inclusive (e.g.127.0.0.1);
optimizes memory, disk, and query performance | 
| time | string | Interprets a string field as a time of the form HH:MM:SS[.mmm] | 
| timestamp | long | Timestamps in milliseconds since the Unix epoch: Jan 1 1970 00:00:00 | 
| nullable | <any> | Values can be set to null Note: This property is generally not used in column creation; assigning nullability is an API-dependent exercise | 
One or more of the following properties can be assigned to a column to alter the way the data is stored & handled. Valid combinations are detailed in the descriptions.
| Property | Description | 
|---|---|
| data | Directs that the column's data should be stored in memory,
making it available for use in query expressions.  Default
property for all numeric and string type columns, unless
overridden by store_only. | 
| text_search | Enables full text search for string columns.  Can be set
independently of data,disk_optimized, &store_only.
Default property for string type columns with no other column
properties set.  For full text search details and limitations,
see Full Text Search. | 
| store_only | Reduces system memory usage by not keeping a copy of the data
in memory and only persisting the values.  The data is able to
be queried by column name, but since not in memory, no column or
aggregation expressions can be applied.  It is mutually
exclusive with the dataproperty.  Default property for
bytes type columns. | 
| disk_optimized | Prevents variable-width strings from being written to an
indexing service, saving disk space at the cost of some
functionality.  A /filter/bystring applied will only
work in the equalsmode, /aggregate/unique
cannot be applied, and /aggregate/groupby can only be
used when thecountorcount_distinctfunction is
applied to the column--the column itself cannot otherwise appear
in the column list.  Requires thedataproperty. | 
One or both of these keyed attributes can be assigned to one or more columns. For more information, see the sections on primary keys & shard keys. Foreign keys cannot be assigned as column properties.
| Property | Description | 
|---|---|
| primary_key | Makes this column part of (or the entire) primary key | 
| shard_key | Makes this column part of (or the entire) shard key |