Syntax
Parameters
| Parameter | Description | 
|---|---|
| <table_name> | An identifier that specifies the name of the table. This name should be unique within the database. | 
| <column_name> | An identifier that specifies the name of the column. This name should be unique within the table. | 
| <column_type> | Specifies the data type for the column. | 
| <codec_chain> | Specifies the compression codec(s) for the column. Can be a single codec or chained codecs. See Column compression for details. | 
| <column_description> | The optional description of the column. | 
| <storage_parameter> | The name of a storage parameter for controlling behaviors related to storage and indexes. | 
| <storage_parameter_value> | The value assigned to a <storage_parameter>. | 
| <table_description> | The optional description of the table. | 
Column constraints and the default expression
Firebolt supports the following column constraints:| Constraint | Description | Default value | 
|---|---|---|
| DEFAULT <expression> | Determines the default value used when no value is provided, instead of inserting a NULLvalue. | |
| NULL | NOT NULL | Determines if the column may or may not contain NULLvalues. | NULL | 
| UNIQUE | Provides metadata to the query optimizer about column uniqueness. Does not enforce uniqueness - ensuring unique values is the user’s responsibility. | 
Only literals and the following functions are supported in default expressions: CURRENT_DATE, LOCALTIMESTAMP, CURRENT_TIMESTAMP, and NOW, which is an alias for CURRENT_TIMESTAMP.
STRUCT fields within ARRAY columns cannot have UNIQUE constraints
Example: Creating a table with NULL and NOT NULL values
The following example illustrates different use cases for column definitions and INSERT statements:
- An Explicit NULLinsert – a direct insertion of aNULLvalue into a particular column.
- An Implicit NULLinsert – anINSERTstatement with missing values for a particular column.
t1 with five columns, specifying if each column can contain NULL values, their default values, and a primary index on col2:
INSERT statements, as shown in the following examples:
| INSERT statement | Results and explanation | 
|---|---|
| INSERT INTO t1 VALUES (1,1,1,1,1) | This code example inserts 1into each column. | 
| INSERT INTO t1 VALUES (NULL,1,1,1,1) | This code example explicitly inserts a NULLvalue intocol1. Becausecol1can containNULLvalues, this operation is successful. | 
| INSERT INTO t1 (col2,col3,col4,col5) VALUES (1,1,1,1) | This code example shows both explicit and implicit INSERTstatements. Becausecol1has no value specified, and lacks a default expression, it is implicitly set toNULL. | 
| INSERT INTO t1 VALUES (1,NULL,1,1,1)INSERT INTO t1 (col1,col3,col4,col5) VALUES (1,1,1,1) | This code example shows how a null mismatch error is generated. Because col2is defined asNOT NULLwith no default expression, bothINSERTstatements implicitly try to insertNULLvalues intocol2, and generate “null mismatch” events. | 
| INSERT INTO t1 VALUES (1,1,NULL,1,1) | This code example explicitly inserts a NULLvalue intocol3. Becausecol3is defined asNULL DEFAULT 1, the operation is successful. | 
| INSERT INTO t1 (col1,col2,col4,col5) VALUES (1,1,1,1) | By not specifying a value for col3, this code example implicitly inserts the default value1intocol3, which is defined asNULL DEFAULT 1. | 
| INSERT INTO t1 VALUES (1,1,1,NULL,1) | This code example shows how another null mismatch error is generated. Because col4is defined asNOT NULL DEFAULT 1, the explicit insertion of aNULLvalue violates theNOT NULLconstraint, and results in a null mismatch event. | 
| INSERT INTO t1 (col1,col2,col3,col5) VALUES (1,1,1,1) | This code example shows how omitting a value in an implicit insert invokes the default value 1forcol4. | 
| INSERT INTO t1 VALUES (1,1,1,1,NULL)INSERT INTO t1 (col1,col2,col3,col4) VALUES (1,1,1,1) | This code example shows how explicit and implicit inserts cause a null mismatch error. Because col5was neither defined with a default expression nor allowed to containNULLvalues, Firebolt treatscol5asNOT NULL DEFAULT NULL. BothINSERTstatements attempt to insert aNULLvalue into aNOT NULL TEXTcolumn, invoking in a null mismatch event. | 
Example creating table with UNIQUE constraint over columns
The following examples illustrates UNIQUE constraint over different column definitions : Primitive types:PRIMARY INDEX
ThePRIMARY INDEX is an optional sparse index that sorts and organizes data based on the indexed field as it is ingested, without affecting data scan performance. For more information, see Primary index.
Syntax
| Parameter. | Description | Mandatory? | 
|---|---|---|
| <column_name> | Specifies the name of the column in the Firebolt table which composes the index. At least one column is required. | Y | 
PARTITION BY
ThePARTITION BY clause defines one or more columns that determine how the table is divided into physical parts. These columns serve as the partition key and cannot allow NULL values. When multiple columns are used as the partition key, the combination of all of these columns define the partition boundaries.
PARTITION BY expressions:
- TO_YYYYMM
- TO_YYYYMMDD
- EXTRACT(year|month|day|hour from <column_name>)
- DATE_TRUNC
Column compression
The optionalCOMPRESSION clause allows you to specify compression settings for individual columns. This overrides any table-level compression settings for that specific column.
Syntax
Supported compression codecs
| Codec type | Codecs | Description | 
|---|---|---|
| General-purpose | lz4,lz4hc(level),zstd(level),none,default | Can compress any data type and work independently | 
| Specialized | delta,doubledelta,gorilla | Optimize specific data patterns; must be chained with general-purpose codecs (require NOT NULL columns) | 
Examples
Table type
Firebolt supports two types of tables:- FACTtable - the data is distributed across all nodes of the engine.
- DIMENSIONtable - the entire table is replicated in every node of the engine.
FACT table. DIMENSION tables are ideal for relatively small tables, up to tens of gigabytes, that are used in joins with FACT tables.
Storage Parameters
Storage parameters are specified in the optionalWITH (...) clause as comma separated <storage_parameter> = <storage_parameter_value> assignments.
| Storage Parameter | Description | 
|---|---|
| <index_granularity> | The maximum number of rows in each granule. <storage_parameter_value>must be a power of 2 between 128 and 8192. The default value is 8192. For more information, see Index granularity. | 
| COMPRESSION | Specifies table-level compression using the new syntax: COMPRESSION (codec_name(parameters)). Applies to all columns unless overridden at column level. For more information, see Table and Column Compression. | 
Legacy compression parameters (deprecated)
The following compression parameters are still supported for backward compatibility withlz4 and zstd codecs only:
| Storage Parameter | Description | 
|---|---|
| COMPRESSION_LEVEL | Deprecated: Use COMPRESSION (codec_name(level))instead. Legacy compression level parameter. Cannot be set withoutCOMPRESSION. | 
Table-level compression examples
Using new compression syntax
Using legacy compression syntax (deprecated)
The legacy 
COMPRESSION and COMPRESSION_LEVEL parameters are deprecated. Use the new COMPRESSION (codec_name(parameters)) syntax for access to all compression features including specialized codecs and compression chaining.DESCRIPTION
It is possible to add a description to the table as well as to the columns during the table creation.Related functions
Firebolt also supports the following related functions:- CREATE TABLE AS SELECT (CTAS) – - Creates a table and loads data into it based on a SELECTquery.
- CREATE TABLE CLONE – Creates a table that is a copy of an existing table in the database.