ALTER TABLE
Descriptionβ
Modifies an existing table, including:
- Rename table, partition, index
- Modify table comment
- Modify partitions (add/delete partitions and modify partition attributes)
- Modify the bucketing method and number of buckets
- Modify columns (add/delete columns and change the order of columns)
- Create/delete rollup index
- Modify bitmap index
- Modify table properties
- Atomic swap
- Manual data version compaction
This operation requires the ALTER privilege on the destination table.
Syntaxβ
ALTER TABLE [<db_name>.]<tbl_name>
alter_clause1[, alter_clause2, ...]
alter_clause can held the following operations: rename, comment, partition, bucket, column, rollup index, bitmap index, table property, swap, and compaction.
- rename: renames a table, rollup index, or partition.
- comment: modifies the table comment (supported from v3.1 onwards).
- partition: modifies partition properties, drops a partition, or adds a partition.
- bucket: modifies the bucketing method and number of buckets.
- column: adds, drops, or reorders columns, or modifies column type.
- rollup index: creates or drops a rollup index.
- bitmap index: modifies index (only Bitmap index can be modified).
- swap: atomic exchange of two tables.
- compaction: performs manual compaction to merge versions of loaded data (supported from v3.1 onwards).
Limits and usage notesβ
- Operations on partition, column, and rollup index cannot be performed in one ALTER TABLE statement.
- Column names cannot be modified.
- Column comments cannot be modified.
- One table can have only one ongoing schema change operation at a time. You cannot run two schema change commands on a table at the same time.
- Operations on bucket, column and rollup index are asynchronous operations. A success message is return immediately after the task is submitted. You can run the SHOW ALTER TABLE command to check the progress, and run the CANCEL ALTER TABLE command to cancel the operation.
- Operations on rename, comment, partition, bitmap index and swap are synchronous operations, and a command return indicates that the execution is finished.
Renameβ
Rename supports modification of table name, rollup index, and partition name.
Rename a tableβ
ALTER TABLE <tbl_name> RENAME <new_tbl_name>
Rename a rollup indexβ
ALTER TABLE [<db_name>.]<tbl_name>
RENAME ROLLUP <old_rollup_name> <new_rollup_name>
Rename a partitionβ
ALTER TABLE [<db_name>.]<tbl_name>
RENAME PARTITION <old_partition_name> <new_partition_name>
Alter table comment (from v3.1)β
Syntax:
ALTER TABLE [<db_name>.]<tbl_name> COMMENT = "<new table comment>";
Currently, column comments cannot be modified.
Modify partitionβ
Add a partitionβ
You can choose to add range partitions or list partitions. Adding expression partitions is not supported.
SyntaxοΌ
- 
Range partitions ALTER TABLE
 ADD { single_range_partition | multi_range_partitions } [distribution_desc] ["key"="value"];
 single_range_partition ::=
 PARTITION [IF NOT EXISTS] <partition_name> VALUES partition_key_desc
 partition_key_desc ::=
 { LESS THAN { MAXVALUE | value_list }
 | [ value_list , value_list ) } -- Note that [ represents a left-closed interval.
 value_list ::=
 ( <value> [, ...] )
 multi_range_partitions ::=
 { PARTITIONS START ("<start_date_value>") END ("<end_date_value>") EVERY ( INTERVAL <N> <time_unit> )
 | PARTITIONS START ("<start_integer_value>") END ("<end_integer_value>") EVERY ( <granularity> ) } -- The partition column values still need to be enclosed in double quotes even if the partition column values specified by START and END are integers. However, the interval values in the EVERY clause do not need to be enclosed in double quotes.
- 
List partitions ALTER TABLE
 ADD PARTITION <partition_name> VALUES IN (value_list) [distribution_desc] ["key"="value"];
 value_list ::=
 value_item [, ...]
 value_item ::=
 { <value> | ( <value> [, ...] ) }
Parameters:
- 
Partition-related parameters: - For range partitions, you can add a single range partition (single_range_partition) or multiple range partitions in batch (multi_range_partitions).
- For list partitions, you can only add a single list partition.
 
- For range partitions, you can add a single range partition (
- 
distribution_desc:You can set the number of buckets for the new partition separately, but you cannot set the bucketing method separately. 
- 
"key"="value":You can set properties for the new partition. For details, see CREATE TABLE. 
Examples:
- 
Range partitions - 
If the partition column is specified as event_dayat table creation, for examplePARTITION BY RANGE(event_day), and a new partition needs to be added after table creation, you can execute:ALTER TABLE site_access ADD PARTITION p4 VALUES LESS THAN ("2020-04-30");
- 
If the partition column is specified as datekeyat table creation, for examplePARTITION BY RANGE (datekey), and multiple partitions need to be added in batch after table creation, you can execute:ALTER TABLE site_access
 ADD PARTITIONS START ("2021-01-05") END ("2021-01-10") EVERY (INTERVAL 1 DAY);
 
- 
- 
List partitions - 
If a single partition column is specified at table creation, for example PARTITION BY LIST (city), and a new partition needs to be added after table creation, you can execute:ALTER TABLE t_recharge_detail2
 ADD PARTITION pCalifornia VALUES IN ("Los Angeles","San Francisco","San Diego");
- 
If multiple partition columns are specified at table creation, for example PARTITION BY LIST (dt,city), and a new partition needs to be added after table creation, you can execute:ALTER TABLE t_recharge_detail4
 ADD PARTITION p202204_California VALUES IN
 (
 ("2022-04-01", "Los Angeles"),
 ("2022-04-01", "San Francisco"),
 ("2022-04-02", "Los Angeles"),
 ("2022-04-02", "San Francisco")
 );
 
- 
Drop a partitionβ
Syntax:
-- Before 2.0
ALTER TABLE [<db_name>.]<tbl_name>
DROP PARTITION [IF EXISTS | FORCE] <partition_name>
-- 2.0 or later
ALTER TABLE [<db_name>.]<tbl_name>
DROP PARTITION [IF EXISTS] <partition_name> [FORCE]
Note:
- Keep at least one partition for partitioned tables.
- After executing DROP PARTITION, you can recover the dropped partition by using the RECOVER command within a specified period (1 day by default).
- If DROP PARTITION FORCE is executed, the partition will be deleted directly and cannot be recovered without checking whether there are any unfinished activities on the partition. Thus, generally, this operation is not recommended.
Add a temporary partitionβ
Syntax:
ALTER TABLE [<db_name>.]<tbl_name> 
ADD TEMPORARY PARTITION [IF NOT EXISTS] <partition_name>
partition_desc ["key"="value"]
[DISTRIBUTED BY HASH (k1[,k2 ...]) [BUCKETS num]]
Use a temporary partition to replace the current partitionβ
Syntax:
ALTER TABLE [<db_name>.]<tbl_name>
REPLACE PARTITION <partition_name>
partition_desc ["key"="value"]
WITH TEMPORARY PARTITION
partition_desc ["key"="value"]
[PROPERTIES ("key"="value", ...)]
Drop a temporary partitionβ
Syntax:
ALTER TABLE [<db_name>.]<tbl_name>
DROP TEMPORARY PARTITION <partition_name>
Modify partition propertiesβ
Syntax
ALTER TABLE [<db_name>.]<tbl_name>
MODIFY PARTITION { <partition_name> | ( <partition1_name> [, <partition2_name> ...] ) | (*) }
SET ("key" = "value", ...);
Usages
- 
The following properties of a partition can be modified: - storage_medium
- storage_cooldown_ttl or storage_cooldown_time
- replication_num
 
- 
For the table that has only one partition, the partition name is the same as the table name. If the table is divided into multiple partitions, you can use (*)to modify the properties of all partitions, which is more convenient.
- 
Execute SHOW PARTITIONS FROM <tbl_name>to view the partition properties after modification.
Modify the bucketing method and number of buckets (from v3.2)β
Syntax:
ALTER TABLE [<db_name>.]<table_name>
[ partition_names ]
[ distribution_desc ]
partition_names ::= 
    (PARTITION | PARTITIONS) ( <partition_name> [, <partition_name> ...] )
distribution_desc ::=
    DISTRIBUTED BY RANDOM [ BUCKETS <num> ] |
    DISTRIBUTED BY HASH ( <column_name> [, <column_name> ...] ) [ BUCKETS <num> ]
Example:
For example, the original table is a Duplicate Key table where hash bucketing is used and the number of buckets is automatically set by StarRocks.
CREATE TABLE IF NOT EXISTS details (
    event_time DATETIME NOT NULL COMMENT "datetime of event",
    event_type INT NOT NULL COMMENT "type of event",
    user_id INT COMMENT "id of user",
    device_code INT COMMENT "device code",
    channel INT COMMENT ""
)
DUPLICATE KEY(event_time, event_type)
PARTITION BY date_trunc('day', event_time)
DISTRIBUTED BY HASH(user_id);
-- Insert data of several days
INSERT INTO details (event_time, event_type, user_id, device_code, channel) VALUES
-- Data of November 26th
('2023-11-26 08:00:00', 1, 101, 12345, 2),
('2023-11-26 09:15:00', 2, 102, 54321, 3),
('2023-11-26 10:30:00', 1, 103, 98765, 1),
-- Data of November 27th
('2023-11-27 08:30:00', 1, 104, 11111, 2),
('2023-11-27 09:45:00', 2, 105, 22222, 3),
('2023-11-27 11:00:00', 1, 106, 33333, 1),
-- Data of November 28th
('2023-11-28 08:00:00', 1, 107, 44444, 2),
('2023-11-28 09:15:00', 2, 108, 55555, 3),
('2023-11-28 10:30:00', 1, 109, 66666, 1);
Modify the bucketing method onlyβ
NOTICE
- The modification is applied to all partitions in the table and cannot be applied to specific partitions only.
- Although only the bucketing method needs to be modified, the number of buckets still needs to be specified in the command using
BUCKETS <num>. IfBUCKETS <num>is not specified, it means that the number of buckets is automatically determined by StarRocks.
- 
The bucketing method is modified to random bucketing from hash bucketing and the number of buckets remains automatically set by StarRocks. ALTER TABLE details DISTRIBUTED BY RANDOM;
- 
The keys for hash bucketing are modified to user_id, event_timefromevent_time, event_type. And the number of buckets remains automatically set by StarRocks.ALTER TABLE details DISTRIBUTED BY HASH(user_id, event_time);
Modify the number of buckets onlyβ
NOTICE
Although only the number of buckets needs to be modified, the bucketing method still needs to be specified in the command, for example,
HASH(user_id).
- 
Modify the number of buckets for all partitions to 10 from being automatically set by StarRocks. ALTER TABLE details DISTRIBUTED BY HASH(user_id) BUCKETS 10;
- 
Modify the number of buckets for specified partitions to 15 from being automatically set by StarRocks. ALTER TABLE details PARTITIONS (p20231127, p20231128) DISTRIBUTED BY HASH(user_id) BUCKETS 15 ;NOTE Partition names can be viewed by executing SHOW PARTITIONS FROM <table_name>;.
Modify both the bucketing method and the number of bucketsβ
NOTICE
The modification is applied to all partitions in the table and cannot be applied to specific partitions only.
- 
Modify the bucketing method from hash bucketing to random bucketing, and change the number of buckets to 10 from being automatically set by StarRocks. ALTER TABLE details DISTRIBUTED BY RANDOM BUCKETS 10;
- 
Modify the key for hash bucketing, and change the number of buckets to 10 from being automatically set by StarRocks. The key used for hashing bucketing is modified to user_id, event_timefrom the originalevent_time, event_type. The number of buckets is modified to 10 from automatically set by StarRocks.ALTER TABLE details DISTRIBUTED BY HASH(user_id, event_time) BUCKETS 10;
 ``
Modify columns (add/delete columns, change the order of columns)β
Add a column to the specified location of the specified indexβ
Syntax:
ALTER TABLE [<db_name>.]<tbl_name>
ADD COLUMN column_name column_type [KEY | agg_type] [DEFAULT "default_value"]
[AFTER column_name|FIRST]
[TO rollup_index_name]
[PROPERTIES ("key"="value", ...)]
Note:
- If you add a value column to an Aggregate table, you need to specify agg_type.
- If you add a key column to a non-Aggregate table (such as a Duplicate Key table), you need to specify the KEY keyword.
- You cannot add a column that already exists in the base index to the rollup index. (You can recreate a rollup index if needed.)
Add multiple columns to specified indexβ
Syntax:
- 
Add multiple columns ALTER TABLE [<db_name>.]<tbl_name>
 ADD COLUMN (column_name1 column_type [KEY | agg_type] DEFAULT "default_value", ...)
 [TO rollup_index_name]
 [PROPERTIES ("key"="value", ...)]
- 
Add multiple columns and use AFTER to specify locations of the added columns ALTER TABLE [<db_name>.]<tbl_name>
 ADD COLUMN column_name1 column_type [KEY | agg_type] DEFAULT "default_value" AFTER column_name,
 ADD COLUMN column_name2 column_type [KEY | agg_type] DEFAULT "default_value" AFTER column_name
 [, ...]
 [TO rollup_index_name]
 [PROPERTIES ("key"="value", ...)]
Note:
- 
If you add a value column to an Aggregate table, you need to specify agg_type.
- 
If you add a key column to a non-Aggregate table, you need to specify the KEY keyword. 
- 
You cannot add a column that already exists in the base index to the rollup index. (You can create another rollup index if needed.) 
Add a generated column (from v3.1)β
Syntax:
ALTER TABLE [<db_name>.]<tbl_name>
ADD COLUMN col_name data_type [NULL] AS generation_expr [COMMENT 'string']
You can add a generated column and specify its expression. The generated column can be used to precompute and store the results of expressions, which significantly accelerates queries with the same complex expressions. Since v3.1, StarRocks supports generated columns.
Drop a column from specified indexβ
Syntax:
ALTER TABLE [<db_name>.]<tbl_name>
DROP COLUMN column_name
[FROM rollup_index_name];
Note:
- You cannot drop partition column.
- If the column is dropped from the base index, it will also be dropped if it is included in the rollup index.
Modify the column type and column position of specified indexβ
Syntax:
ALTER TABLE [<db_name>.]<tbl_name>
MODIFY COLUMN column_name column_type [KEY | agg_type] [NULL | NOT NULL] [DEFAULT "default_value"]
[AFTER column_name|FIRST]
[FROM rollup_index_name]
[PROPERTIES ("key"="value", ...)]
Note:
- 
If you modify the value column in aggregation models, you need to specify agg_type. 
- 
If you modify the key column in non-aggregation models, you need to specify the KEY keyword. 
- 
Only the type of column can be modified. The other properties of the column remain as they are currently. (i.e. other properties need to be explicitly written in the statement according to the original property, see example 8 in the column part). 
- 
The partition column cannot be modified. 
- 
The following types of conversions are currently supported (accuracy loss is guaranteed by the user). - Convert TINYINT/SMALLINT/INT/BIGINT to TINYINT/SMALLINT/INT/BIGINT/DOUBLE.
- Convert TINYINT/SMALLINT/INT/BIGINT/LARGEINT/FLOAT/DOUBLE/DECIMAL to VARCHAR. VARCHAR supports modification of maximum length.
- Convert VARCHAR to TINYINT/SMALLINT/INT/BIGINT/LARGEINT/FLOAT/DOUBLE.
- Convert VARCHAR to DATE (currently support six formats: "%Y-%m-%d", "%y-%m-%d", "%Y%m%d", "%y%m%d", "%Y/%m/%d, "%y/%m/%d")
- Convert DATETIME to DATE(only year-month-day information is retained, i.e. 2019-12-09 21:47:05<-->2019-12-09)
- Convert DATE to DATETIME (set hour, minute, second to zero, For example: 2019-12-09<-->2019-12-09 00:00:00)
- Convert FLOAT to DOUBLE
- Convert INT to DATE (If the INT data fails to convert, the original data remains the same)
 
- 
Conversion from NULL to NOT NULL is not supported. 
Reorder the columns of specified indexβ
Syntax:
ALTER TABLE [<db_name>.]<tbl_name>
ORDER BY (column_name1, column_name2, ...)
[FROM rollup_index_name]
[PROPERTIES ("key"="value", ...)]
Note:
- All columns in the index must be written.
- The value column is listed after the key column.
Modify columns of the sort key in a Primary Key tableβ
Syntax:
ALTER TABLE [<db_name>.]<table_name>
[ order_desc ]
order_desc ::=
    ORDER BY <column_name> [, <column_name> ...]
Example:
For example, the original table is a Primary Key table where the sort key and the primary key are coupled, which is dt, order_id.
create table orders (
    dt date NOT NULL,
    order_id bigint NOT NULL,
    user_id int NOT NULL,
    merchant_id int NOT NULL,
    good_id int NOT NULL,
    good_name string NOT NULL,
    price int NOT NULL,
    cnt int NOT NULL,
    revenue int NOT NULL,
    state tinyint NOT NULL
) PRIMARY KEY (dt, order_id)
PARTITION BY date_trunc('day', dt)
DISTRIBUTED BY HASH(order_id);
Decouple the sort key from the primary key, and modify the sort key to dt, revenue, state.
ALTER TABLE orders ORDER BY (dt, revenue, state);
Modify a STRUCT column to add or drop a fieldβ
From v3.2.10 and v3.3.2 onwards, StarRocks supports modifying a STRUCT column to add or drop a field, which can be nested or within an ARRAY type.
Syntax:
-- Add a field
ALTER TABLE [<db_name>.]<tbl_name> MODIFY COLUMN <column_name>
ADD FIELD field_path field_desc
-- Drop a field
ALTER TABLE [<db_name>.]<tbl_name> MODIFY COLUMN <column_name>
DROP FIELD field_path
field_path ::= [ { <field_name>. | [*]. } [ ... ] ]<field_name>
  -- Note that here `[*]` as a whole is a pre-defined symbol and represents all elements in the ARRAY field 
  -- when adding or removing a field in a STRUCT type nested within an ARRAY type.
  -- For detailed information, see the parameter description and examples of `field_path`.
field_desc ::= <field_type> [ AFTER <prior_field_name> | FIRST ]
Parameters:
- field_path: The field to be added or removed. This can be a simple field name, indicating a top-dimension field, for example,- new_field_name, or a Column Access Path that represents a nested field, for example,- lv1_k1.lv2_k2.[*].new_field_name.
- [*]: When a STRUCT type is nested within an ARRAY type,- [*]represents all elements in the ARRAY field. It is used to add or remove a field in all STRUCT elements nested under the ARRAY field.
- prior_field_name: The field preceding the newly added field. Used in conjunction with the AFTER keyword to specify the order of the new field. You do not need to specify this parameter if the FIRST keyword is used, indicating the new field should be the first field. The dimension of- prior_field_nameis determined by- field_path(specifically, the part preceding- new_field_name, that is,- level1_k1.level2_k2.[*]) and does not need to be specified explicitly.
Examples of field_path:
- 
Add or drop a sub-field in a STRUCT field nested within a STRUCT column. Suppose there is a column fx stuct<c1 int, c2 struct <v1 int, v2 int>>. The syntax to add av3field underc2is:ALTER TABLE tbl MODIFY COLUMN fx ADD FIELD c2.v3 INTAfter the operation, the column becomes fx stuct<c1 int, c2 struct <v1 int, v2 int, v3 int>>.
- 
Add or drop a sub-field in every STRUCT field nested within a ARRAY field. Suppose there is a column fx struct<c1 int, c2 array<struct <v1 int, v2 int>>>. The fieldc2is an ARRAY type, which contains a STRUCT with two fieldsv1andv2. The syntax to add av3field to the nested STRUCT is:ALTER TABLE tbl MODIFY COLUMN fx ADD FIELD c2.[*].v3 INTAfter the operation, the column becomes fx struct<c1 int, c2 array<struct <v1 int, v2 int, v3 int>>>.
For more usage instructions, see Example - Column -14.
- Currently, this feature is only supported in shared-nothing clusters.
- The table must have the fast_schema_evolutionproperty enabled.
- Modifying the Value type of a MAP subfield in a STRUCT type is not supported, regardless of whether the Value type is ARRAY, STRUCT, or MAP.
- Newly added fields cannot have default values or attributes such as Nullable specified. They default to being Nullable, with a default value of null.
- After this feature is used, downgrading the cluster directly to a version that does not support this feature is not allowed.
Modify rollup indexβ
Create a rollup indexβ
Syntax:
ALTER TABLE [<db_name>.]<tbl_name> 
ADD ROLLUP rollup_name (column_name1, column_name2, ...)
[FROM from_index_name]
[PROPERTIES ("key"="value", ...)]
PROPERTIES: Support setting timeout time and the default timeout time is one day.
Example:
ALTER TABLE [<db_name>.]<tbl_name> 
ADD ROLLUP r1(col1,col2) from r0;
Create rollup indexes in batchesβ
Syntax:
ALTER TABLE [<db_name>.]<tbl_name>
ADD ROLLUP [rollup_name (column_name1, column_name2, ...)
[FROM from_index_name]
[PROPERTIES ("key"="value", ...)],...];
Example:
ALTER TABLE [<db_name>.]<tbl_name>
ADD ROLLUP r1(col1,col2) from r0, r2(col3,col4) from r0;
Note:
- If from_index_name is not specified, then create from base index by default.
- The columns in the rollup table must be existing columns in from_index.
- In properties, user can specify the storage format. See CREATE TABLE for details.
Drop a rollup indexβ
Syntax:
ALTER TABLE [<db_name>.]<tbl_name>
DROP ROLLUP rollup_name [PROPERTIES ("key"="value", ...)];
Example:
ALTER TABLE [<db_name>.]<tbl_name> DROP ROLLUP r1;
Batch drop rollup indexesβ
Syntax:
ALTER TABLE [<db_name>.]<tbl_name>
DROP ROLLUP [rollup_name [PROPERTIES ("key"="value", ...)],...];
Example:
ALTER TABLE [<db_name>.]<tbl_name> DROP ROLLUP r1, r2;
Note: You cannot drop the base index.
Modify bitmap indexesβ
Bitmap index supports the following modifications:
Create a bitmap indexβ
Syntax:
ALTER TABLE [<db_name>.]<tbl_name>
ADD INDEX index_name (column [, ...],) [USING BITMAP] [COMMENT 'balabala'];
Note:
1. Bitmap index is only supported for the current version.
2. A BITMAP index is created only in a single column.
Drop an bitmap indexβ
Syntax:
DROP INDEX index_name;
Modify table propertiesβ
Syntax:
ALTER TABLE [<db_name>.]<tbl_name>
SET ("key" = "value")
Currently, StarRocks supports modifying the following table properties:
- replication_num
- default.replication_num
- storage_cooldown_ttl
- storage_cooldown_time
- Dynamic partitioning related properties
- enable_persistent_index
- bloom_filter_columns
- colocate_with
- bucket_size(supported since 3.2)
- base_compaction_forbidden_time_ranges(supported since v3.2.13)
- In most cases, you are only allowed to modify one property at a time. You can only modify multiple properties at a time only if these properties have the same prefix. Currently, only dynamic_partition.andbinlog.are supported.
- You can also modify the properties by merging into the above operation on column. See the following examples.
Swapβ
Swap supports atomic exchange of two tables.
Syntax:
ALTER TABLE [<db_name>.]<tbl_name>
SWAP WITH <tbl_name>;
Manual compaction (from 3.1)β
StarRocks uses a compaction mechanism to merge different versions of loaded data. This feature can combine small files into large files, which effectively improves query performance.
Before v3.1, compaction is performed in two ways:
- Automatic compaction by system: Compaction is performed at the BE level in the background. Users cannot specify database or table for compaction.
- Users can perform compaction by calling an HTTP interface.
Starting from v3.1, StarRocks offers a SQL interface for users to manually perform compaction by running SQL commands. They can choose a specific table or partition for compaction. This provides more flexibility and control over the compaction process.
NOTE
From v3.2.13 onwards, you can forbid Base Compaction within certain time range using the property
base_compaction_forbidden_time_ranges.
Syntax:
ALTER TABLE <tbl_name> [ BASE | CUMULATIVE ] COMPACT [ <partition_name> | ( <partition1_name> [, <partition2_name> ...] ) ]
That is:
-- Perform compaction on the entire table.
ALTER TABLE <tbl_name> COMPACT
-- Perform compaction on a single partition.
ALTER TABLE <tbl_name> COMPACT <partition_name>
-- Perform compaction on multiple partitions.
ALTER TABLE <tbl_name> COMPACT (<partition1_name>[,<partition2_name>,...])
-- Perform cumulative compaction.
ALTER TABLE <tbl_name> CUMULATIVE COMPACT (<partition1_name>[,<partition2_name>,...])
-- Perform base compaction.
ALTER TABLE <tbl_name> BASE COMPACT (<partition1_name>[,<partition2_name>,...])
The be_compactions table in the information_schema database records compaction results. You can run SELECT * FROM information_schema.be_compactions; to query data versions after compaction.
Examplesβ
Tableβ
- 
Modify the default number of replicas of the table, which is used as the default number of replicas for newly added partitions. ALTER TABLE example_db.my_table
 SET ("default.replication_num" = "2");
- 
Modify the actual number of replicas of a single-partition table. ALTER TABLE example_db.my_table
 SET ("replication_num" = "3");
- 
Modify data writing and replication mode among replicas. ALTER TABLE example_db.my_table
 SET ("replicated_storage" = "false");This example sets the data writing and replication mode among replicas to "leaderless replication", which means data is written to multiple replicas at the same time without differentiating primary and secondary replicas. For more information, see the replicated_storageparameter in CREATE TABLE.
Partitionβ
- 
Add a partition and use the default bucketing mode. The existing partition is [MIN, 2013-01-01). The added partition is [2013-01-01, 2014-01-01). ALTER TABLE example_db.my_table
 ADD PARTITION p1 VALUES LESS THAN ("2014-01-01");
- 
Add a partition and use the new number of buckets. ALTER TABLE example_db.my_table
 ADD PARTITION p1 VALUES LESS THAN ("2015-01-01")
 DISTRIBUTED BY HASH(k1);
- 
Add a partition and use the new number of replicas. ALTER TABLE example_db.my_table
 ADD PARTITION p1 VALUES LESS THAN ("2015-01-01")
 ("replication_num"="1");
- 
Alter the number of replicas for a partition. ALTER TABLE example_db.my_table
 MODIFY PARTITION p1 SET("replication_num"="1");
- 
Batch alter the number of replicas for specified partitions. ALTER TABLE example_db.my_table
 MODIFY PARTITION (p1, p2, p4) SET("replication_num"="1");
- 
Batch alter the storage medium of all partitions. ALTER TABLE example_db.my_table
 MODIFY PARTITION (*) SET("storage_medium"="HDD");
- 
Drop a partition. ALTER TABLE example_db.my_table
 DROP PARTITION p1;
- 
Add a partition that has upper and lower boundaries. ALTER TABLE example_db.my_table
 ADD PARTITION p1 VALUES [("2014-01-01"), ("2014-02-01"));
Rollup indexβ
- 
Create an rollup index example_rollup_indexbased on the base index (k1,k2,k3,v1,v2). Column-based storage is used.ALTER TABLE example_db.my_table
 ADD ROLLUP example_rollup_index(k1, k3, v1, v2)
 PROPERTIES("storage_type"="column");
- 
Create an index example_rollup_index2based onexample_rollup_index(k1,k3,v1,v2).ALTER TABLE example_db.my_table
 ADD ROLLUP example_rollup_index2 (k1, v1)
 FROM example_rollup_index;
- 
Create an index example_rollup_index3based on the base index (k1, k2, k3, v1). The rollup timeout time is set to one hour.ALTER TABLE example_db.my_table
 ADD ROLLUP example_rollup_index3(k1, k3, v1)
 PROPERTIES("storage_type"="column", "timeout" = "3600");
- 
Drop an index example_rollup_index2.ALTER TABLE example_db.my_table
 DROP ROLLUP example_rollup_index2;
Columnβ
- 
Add a key column new_col(non-aggregate column) after thecol1column ofexample_rollup_index.ALTER TABLE example_db.my_table
 ADD COLUMN new_col INT KEY DEFAULT "0" AFTER col1
 TO example_rollup_index;
- 
Add a value column new_col(non-aggregate column) after thecol1column ofexample_rollup_index.ALTER TABLE example_db.my_table
 ADD COLUMN new_col INT DEFAULT "0" AFTER col1
 TO example_rollup_index;
- 
Add a key column new_col(aggregate column) after thecol1column ofexample_rollup_index.ALTER TABLE example_db.my_table
 ADD COLUMN new_col INT DEFAULT "0" AFTER col1
 TO example_rollup_index;
- 
Add a value column new_col SUM(aggregate column) after thecol1column ofexample_rollup_index.ALTER TABLE example_db.my_table
 ADD COLUMN new_col INT SUM DEFAULT "0" AFTER col1
 TO example_rollup_index;
- 
Add multiple columns to example_rollup_index(aggregate).ALTER TABLE example_db.my_table
 ADD COLUMN (col1 INT DEFAULT "1", col2 FLOAT SUM DEFAULT "2.3")
 TO example_rollup_index;
- 
Add multiple columns to example_rollup_index(aggregate) and specify the locations of the added columns usingAFTER.ALTER TABLE example_db.my_table
 ADD COLUMN col1 INT DEFAULT "1" AFTER `k1`,
 ADD COLUMN col2 FLOAT SUM AFTER `v2`,
 TO example_rollup_index;
- 
Drop a column from example_rollup_index.ALTER TABLE example_db.my_table
 DROP COLUMN col2
 FROM example_rollup_index;
- 
Modify the column type of col1 of the base index to BIGINT and put it after col2.ALTER TABLE example_db.my_table
 MODIFY COLUMN col1 BIGINT DEFAULT "1" AFTER col2;
- 
Modify the maximum length of the val1column of the base index to 64. The original length is 32.ALTER TABLE example_db.my_table
 MODIFY COLUMN val1 VARCHAR(64) REPLACE DEFAULT "abc";
- 
Reorder the columns in example_rollup_index. The original column order is k1, k2, k3, v1, v2.ALTER TABLE example_db.my_table
 ORDER BY (k3,k1,k2,v2,v1)
 FROM example_rollup_index;
- 
Perform two operations (ADD COLUMN and ORDER BY) at one time. ALTER TABLE example_db.my_table
 ADD COLUMN v2 INT MAX DEFAULT "0" AFTER k2 TO example_rollup_index,
 ORDER BY (k3,k1,k2,v2,v1) FROM example_rollup_index;
- 
Alter the bloomfilter columns of the table. ALTER TABLE example_db.my_table
 SET ("bloom_filter_columns"="k1,k2,k3");This operation can also be merged into the above column operation (note that the syntax of multiple clauses is slightly different). ALTER TABLE example_db.my_table
 DROP COLUMN col2
 PROPERTIES ("bloom_filter_columns"="k1,k2,k3");
- 
Modify the data type of multiple columns in a single statement. ALTER TABLE example_db.my_table
 MODIFY COLUMN k1 VARCHAR(100) KEY NOT NULL,
 MODIFY COLUMN v2 DOUBLE DEFAULT "1" AFTER v1;
- 
Add and drop fields in STRUCT-type data. Prerequisites: Create a table and insert a row of data. CREATE TABLE struct_test(
 c0 INT,
 c1 STRUCT<v1 INT, v2 STRUCT<v4 INT, v5 INT>, v3 INT>,
 c2 STRUCT<v1 INT, v2 ARRAY<STRUCT<v3 INT, v4 STRUCT<v5 INT, v6 INT>>>>
 )
 DUPLICATE KEY(c0)
 DISTRIBUTED BY HASH(`c0`) BUCKETS 1
 PROPERTIES (
 "fast_schema_evolution" = "true"
 );
 INSERT INTO struct_test VALUES (
 1,
 ROW(1, ROW(2, 3), 4),
 ROW(5, [ROW(6, ROW(7, 8)), ROW(9, ROW(10, 11))])
 );mysql> SELECT * FROM struct_test\G
 *************************** 1. row ***************************
 c0: 1
 c1: {"v1":1,"v2":{"v4":2,"v5":3},"v3":4}
 c2: {"v1":5,"v2":[{"v3":6,"v4":{"v5":7,"v6":8}},{"v3":9,"v4":{"v5":10,"v6":11}}]}- Add a new field to a STRUCT-type column.
 ALTER TABLE struct_test MODIFY COLUMN c1 ADD FIELD v4 INT AFTER v2;mysql> SELECT * FROM struct_test\G
 *************************** 1. row ***************************
 c0: 1
 c1: {"v1":1,"v2":{"v4":2,"v5":3},"v4":null,"v3":4}
 c2: {"v1":5,"v2":[{"v3":6,"v4":{"v5":7,"v6":8}},{"v3":9,"v4":{"v5":10,"v6":11}}]}- Add a new field to a nested STRUCT type.
 ALTER TABLE struct_test MODIFY COLUMN c1 ADD FIELD v2.v6 INT FIRST;mysql> SELECT * FROM struct_test\G
 *************************** 1. row ***************************
 c0: 1
 c1: {"v1":1,"v2":{"v6":null,"v4":2,"v5":3},"v4":null,"v3":4}
 c2: {"v1":5,"v2":[{"v3":6,"v4":{"v5":7,"v6":8}},{"v3":9,"v4":{"v5":10,"v6":11}}]}- Add a new field to a STRUCT type in an array.
 ALTER TABLE struct_test MODIFY COLUMN c2 ADD FIELD v2.[*].v7 INT AFTER v3;mysql> SELECT * FROM struct_test\G
 *************************** 1. row ***************************
 c0: 1
 c1: {"v1":1,"v2":{"v6":null,"v4":2,"v5":3},"v4":null,"v3":4}
 c2: {"v1":5,"v2":[{"v3":6,"v7":null,"v4":{"v5":7,"v6":8}},{"v3":9,"v7":null,"v4":{"v5":10,"v6":11}}]}- Drop a field from a STRUCT-type column.
 ALTER TABLE struct_test MODIFY COLUMN c1 DROP FIELD v3;mysql> SELECT * FROM struct_test\G
 *************************** 1. row ***************************
 c0: 1
 c1: {"v1":1,"v2":{"v6":null,"v4":2,"v5":3},"v4":null}
 c2: {"v1":5,"v2":[{"v3":6,"v7":null,"v4":{"v5":7,"v6":8}},{"v3":9,"v7":null,"v4":{"v5":10,"v6":11}}]}- Drop a field from a nested STRUCT type.
 ALTER TABLE struct_test MODIFY COLUMN c1 DROP FIELD v2.v4;mysql> SELECT * FROM struct_test\G
 *************************** 1. row ***************************
 c0: 1
 c1: {"v1":1,"v2":{"v6":null,"v5":3},"v4":null}
 c2: {"v1":5,"v2":[{"v3":6,"v7":null,"v4":{"v5":7,"v6":8}},{"v3":9,"v7":null,"v4":{"v5":10,"v6":11}}]}- Drop a field from a STRUCT type in an array.
 ALTER TABLE struct_test MODIFY COLUMN c2 DROP FIELD v2.[*].v3;mysql> SELECT * FROM struct_test\G
 *************************** 1. row ***************************
 c0: 1
 c1: {"v1":1,"v2":{"v6":null,"v5":3},"v4":null}
 c2: {"v1":5,"v2":[{"v7":null,"v4":{"v5":7,"v6":8}},{"v7":null,"v4":{"v5":10,"v6":11}}]}
Table propertyβ
- 
Alter the Colocate property of the table. ALTER TABLE example_db.my_table
 SET ("colocate_with" = "t1");
- 
Alter the dynamic partition property of the table. ALTER TABLE example_db.my_table
 SET ("dynamic_partition.enable" = "false");If you need to add dynamic partition properties to a table with no dynamic partition properties configured, you need to specify all the dynamic partition properties. ALTER TABLE example_db.my_table
 SET (
 "dynamic_partition.enable" = "true",
 "dynamic_partition.time_unit" = "DAY",
 "dynamic_partition.end" = "3",
 "dynamic_partition.prefix" = "p",
 "dynamic_partition.buckets" = "32"
 );
Renameβ
- 
Rename table1totable2.ALTER TABLE table1 RENAME table2;
- 
Rename rollup index rollup1ofexample_tabletorollup2.ALTER TABLE example_table RENAME ROLLUP rollup1 rollup2;
- 
Rename partition p1ofexample_tabletop2.ALTER TABLE example_table RENAME PARTITION p1 p2;
Bitmap indexβ
- 
Create a bitmap index for column siteidintable1.ALTER TABLE table1
 ADD INDEX index_1 (siteid) [USING BITMAP] COMMENT 'balabala';
- 
Drop the bitmap index of column siteidintable1.ALTER TABLE table1
 DROP INDEX index_1;
Swapβ
Atomic swap between table1 and table2.
ALTER TABLE table1 SWAP WITH table2
Manual compactionβ
CREATE TABLE compaction_test( 
    event_day DATE,
    pv BIGINT)
DUPLICATE KEY(event_day)
PARTITION BY date_trunc('month', event_day)
DISTRIBUTED BY HASH(event_day) BUCKETS 8
PROPERTIES("replication_num" = "3");
INSERT INTO compaction_test VALUES
('2023-02-14', 2),
('2033-03-01',2);
{'label':'insert_734648fa-c878-11ed-90d6-00163e0dcbfc', 'status':'VISIBLE', 'txnId':'5008'}
INSERT INTO compaction_test VALUES
('2023-02-14', 2),('2033-03-01',2);
{'label':'insert_85c95c1b-c878-11ed-90d6-00163e0dcbfc', 'status':'VISIBLE', 'txnId':'5009'}
ALTER TABLE compaction_test COMPACT;
ALTER TABLE compaction_test COMPACT p203303;
ALTER TABLE compaction_test COMPACT (p202302,p203303);
ALTER TABLE compaction_test CUMULATIVE COMPACT (p202302,p203303);
ALTER TABLE compaction_test BASE COMPACT (p202302,p203303);