Skip to main content

mutations

The table contains information about mutations of MergeTree tables and their progress. Each mutation command is represented by a single row.

Columns:

  • database (String) — The name of the database to which the mutation was applied.

  • table (String) — The name of the table to which the mutation was applied.

  • mutation_id (String) — The ID of the mutation. For replicated tables these IDs correspond to znode names in the <table_path_in_clickhouse_keeper>/mutations/ directory in ClickHouse Keeper. For non-replicated tables the IDs correspond to file names in the data directory of the table.

  • command (String) — The mutation command string (the part of the query after ALTER TABLE [db.]table).

  • create_time (DateTime) — Date and time when the mutation command was submitted for execution.

  • block_numbers.partition_id (Array(String)) — For mutations of replicated tables, the array contains the partitions' IDs (one record for each partition). For mutations of non-replicated tables the array is empty.

  • block_numbers.number (Array(Int64)) — For mutations of replicated tables, the array contains one record for each partition, with the block number that was acquired by the mutation. Only parts that contain blocks with numbers less than this number will be mutated in the partition.

    In non-replicated tables, block numbers in all partitions form a single sequence. This means that for mutations of non-replicated tables, the column will contain one record with a single block number acquired by the mutation.

  • parts_to_do_names (Array(String)) — An array of names of data parts that need to be mutated for the mutation to complete.

  • parts_to_do (Int64) — The number of data parts that need to be mutated for the mutation to complete.

  • is_killed (UInt8) — Indicates whether a mutation has been killed. Only available in ClickHouse Cloud.

Note

is_killed=1 does not necessarily mean the mutation is completely finalized. It is possible for a mutation to remain in a state where is_killed=1 and is_done=0 for an extended period. This can happen if another long-running mutation is blocking the killed mutation. This is a normal situation.

  • is_done (UInt8) — The flag whether the mutation is done or not. Possible values:
    • 1 if the mutation is completed,
    • 0 if the mutation is still in process.
Note

Even if parts_to_do = 0 it is possible that a mutation of a replicated table is not completed yet because of a long-running INSERT query, that will create a new data part needed to be mutated.

If there were problems with mutating some data parts, the following columns contain additional information:

  • latest_failed_part (String) — The name of the most recent part that could not be mutated.

  • latest_fail_time (DateTime) — The date and time of the most recent part mutation failure.

  • latest_fail_reason (String) — The exception message that caused the most recent part mutation failure.

Monitoring Mutations

To track the progress on the system.mutations table, use a query like the following - this requires read permissions on the system.* tables:

SELECT * FROM clusterAllReplicas('cluster_name', 'db', system.mutations)
WHERE is_done=0 AND table='tmp';
Tip

replace tmp in table='tmp' with the name of the table that you are checking mutations on.

See Also