In this blog post, I will show you what you need to pay special attention to when you switch from Teradata to Snowflake.
We will look at the effect of executing DML statements (such as UPDATE or DELETE) in Snowflake and compare this with Teradata Row Storage and Column Storage.
When deleting, the rows in the data blocks are released. Teradata uses an array of pointers in each data block that points to the physical position of each row within the data block.
If too few rows remain in a data block, data blocks are merged.
An UPDATE statement causes the data block to be assembled in memory.
Depending on the effect of the update on the used space within a data block, it is split into several blocks or merged.
If all rows or an entire row partition of a table is deleted, they are physically deleted.
Otherwise, the rows to be deleted are only marked with a delete flag but continue to occupy space, which is necessary to keep the column containers synchronous.
The old Row-Based Engine comes into play during the UPDATE:
It selects the rows that are needed and assembles the column containers into rows. The rows to be changed will be marked with a delete flag but not deleted. The changed rows are transformed into column format and saved.
Snowflake stores data in micro partitions between 5 and 500 megabytes.
Every change (UPDATE, INSERT or DELETE) to a micro partition means that the entire micro partition must be replaced.
It is not possible to make changes in an existing micro partition, because Amazon S3 does not implement this.
Micro partitions are created when loading an empty table. If data is added, new micro partitions are created.
If a change through an UPDATE or DELETE statement is necessary, Snowflake deletes the existing micro partition and replaces it with a new one.
I assume that micro partitions will not be deleted immediately but will remain available for the Time Travel feature for a while.
At the moment I am missing more details about the implementation in Snowflake. But I will stay on it and will inform you as soon as I know more!