Changing columns
YDB supports adding columns to row and column tables, deleting non-key columns from tables, and changing properties of existing columns.
ADD COLUMN
Builds a new column with the specified name, type, and options for the specified table.
ALTER TABLE table_name ADD COLUMN column_name column_data_type [FAMILY <family_name>] [NULL | NOT NULL] [DEFAULT <default_value>] [COMPRESSION([algorithm=<algorithm_name>[, level=<value>]])];
Request parameters
table_name
The path of the table to be modified.
column_name
The name of the column to be created. When choosing a name for the column, consider the common column naming rules.
column_data_type
The data type of the column. The complete list of data types supported by YDB is available in the YQL data types section.
FAMILY <family_name> (column setting)
Specifies the belonging of this column to the specified group of columns. For more details, see the section Column groups.
DEFAULT <default_value>
Warning
The DEFAULT option is supported:
- Only for row-oriented tables.
- Only with literal values.
Allows you to set a default value for the column. If no value is specified for this column when inserting a row, the specified default value will be used. The default value must match the data type of the column.
The DEFAULT false NOT NULL construct is not allowed due to ambiguity of interpretation. In this case, you should use a comma-separated list or change the order of the options.
NULL
This column can contain NULL values (by default).
NOT NULL
This column does not accept NULL values.
COMPRESSION([algorithm=<algorithm_name>[, level=]])
Warning
Supported only for column-oriented tables.
The following compression parameters can be set for columns:
-
algorithm— the data compression algorithm. Allowed values:off(disable compression),lz4,zstd. -
level— the compression level, supported only for thezstdalgorithm (values from 0 to 22 are allowed).
If COMPRESSION() is specified without parameters, the default compression is used for the column. Currently, it is lz4; in future versions, it will be possible to configure the default compression at the cluster or table level.
ENCODING([OFF|DICT])
Warning
Supported only for column-oriented tables.
Allows you to set the data encoding method for the column.
Available options:
-
ENCODING(DICT)— enables dictionary encoding. Repeating values are replaced with small integer identifiers, and the values themselves are stored in a dictionary. Dictionary encoding is effective for columns with low cardinality (a small number of unique values). It reduces the amount of stored data and speeds up some operations. It is supported only for comparable data types, such asString,Timestamp,UInt64, and others. UsingENCODING(DICT)for incomparable types, such asJson,JsonDocument, orYson, will result in an error. -
ENCODING(OFF)— disables special encoding. Data will be stored in the standard format without additional encoding.
If ENCODING() is set without parameters, the default encoding will be used for the column. Currently, it is OFF; in future versions, it will be possible to configure the default encoding at the database or table level.
Example
The code below will add a column named views with data type Uint64 to the episodes table.
ALTER TABLE episodes ADD COLUMN views Uint64;
The code below will add a column named rate with data type Double and default value 5.0 to the episodes table.
ALTER TABLE episodes ADD COLUMN rate Double NOT NULL DEFAULT 5.0;
ALTER TABLE episodes ADD COLUMN rate Double (DEFAULT 5.0, NOT NULL); -- alternative syntax
ALTER COLUMN
Modifies properties of an existing column in the specified table. Property changes are applied without recreating the column. Some properties apply only to newly written data or during compaction (see the description of each property for details).
ALTER TABLE table_name ALTER COLUMN column_name SET [FAMILY <family_name>] [DEFAULT <default_value>] [COMPRESSION([algorithm=<algorithm_name>[, level=<value>]])] [ENCODING([OFF|DICT])];
ALTER TABLE table_name ALTER COLUMN column_name DROP [FAMILY] [NOT NULL] [DEFAULT] [COMPRESSION] [ENCODING];
Request parameters
table_name
The path of the table containing the column to change.
column_name
The name of the column to change in the specified table.
SET
Set a column option.
DROP
Remove a column option.
FAMILY <family_name> (column setting)
Specifies that this column belongs to the specified column group. For more information, see Column groups.
DEFAULT <default_value>
Warning
The DEFAULT option is supported:
- Only for row-oriented tables.
- Only with literal values.
Allows you to set a default value for a column. If no value is specified for this column when inserting a row, the specified default value will be used. The default value must match the column's data type.
NOT NULL
Warning
Currently only DROP NOT NULL is supported.
Removes the NOT NULL constraint from the column, allowing NULL values again.
COMPRESSION([algorithm=<algorithm_name>[, level=]])
Warning
Supported only for column-oriented tables.
You can set the following compression parameters for columns:
-
algorithm— compression algorithm. Allowed values:off(disable compression),lz4,zstd. -
level— compression level; supported only forzstd(allowed values are 0 through 22).
If COMPRESSION() is specified without parameters, the column uses the default compression. Currently that is lz4; future versions will let you configure default compression at the cluster or table level.
ENCODING([OFF|DICT])
Warning
Supported only for column-oriented tables.
Sets the encoding for a column's data.
Available options:
-
ENCODING(DICT)— enables dictionary encoding. Repeated values are replaced by small integer identifiers stored in a dictionary. Effective for low-cardinality columns (few unique values). Supported only for comparable types such asString,Timestamp,UInt64. UsingENCODING(DICT)on non-comparable types (Json,JsonDocument,Yson) returns an error. -
ENCODING(OFF)— disables special encoding. Data is stored in the standard format without additional encoding.
If ENCODING() is specified without parameters, the column uses the default encoding. Currently that is OFF; future versions will let you configure the default encoding at the database or table level.
A single ALTER TABLE statement can specify multiple ALTER COLUMN actions separated by commas.
Examples
The code below sets a default value for the rate column of the episodes table.
ALTER TABLE episodes ALTER COLUMN rate SET DEFAULT 5.0;
The code below changes default values for several columns of a table in a single statement — setting new defaults for col_1 and col_2 and clearing the default for col_3.
ALTER TABLE default_columns
ALTER COLUMN col_1 SET DEFAULT "new_a"u,
ALTER COLUMN col_2 SET DEFAULT 99,
ALTER COLUMN col_3 DROP DEFAULT;
Reset column compression settings:
ALTER TABLE compressed_table ALTER COLUMN info SET COMPRESSION();
After the query runs, the column uses the default compression algorithm again (see the COMPRESSION option above).
DROP COLUMN
Deletes a column with the specified name from the specified table.
ALTER TABLE table_name DROP COLUMN column_name;
Request parameters
table_name
The path of the table to be modified.
column_name
The name of the column to be deleted.
Example
The code below will delete the column named views from the episodes table.
ALTER TABLE episodes DROP COLUMN views;