SnowConvert AI – Funktionale Unterschiede bei RedShift¶
SSC-FDM-RS0001¶
Data storage option is not supported in Snowflake. Data distribution is automatically handled by Snowflake.
Beschreibung¶
In Snowflake ist es nicht notwendig, SORTKEY und DISTSTYLE bei der Migration von RedShift explizit zu definieren, da die Architektur von Snowflake die Datenverteilung und Optimierung intern verwaltet. Snowflake führt die Partitionierung und Indizierung der Daten automatisch aus und optimiert so die Abfrageleistung, ohne dass diese Parameter manuell konfiguriert werden müssen.
Codebeispiel¶
Eingabecode:¶
Redshift¶
Generierter Code:¶
Snowflake¶
Best Practices¶
Es ist ratsam, die Verwendung von
CLUSTER BYin Snowflake während der Migration von RedShift zu bewerten, da es die Abfrageleistung verbessern kann, indem es die Datenlokalität für häufig abgefragte Spalten optimiert.Wenn Sie weitere Unterstützung benötigen, können Sie uns eine E-Mail an snowconvert-support@snowflake.com senden.
SSC-FDM-RS0002¶
The performance of CLUSTER BY in Snowflake may vary compared to the performance of SORTKEY in Redshift.
Beschreibung¶
SORTKEY (ausgenommen SORTKEY AUTO) in Amazon RedShift sind analog zu CLUSTER BY in Snowflake. Die Auswirkungen auf die Leistung können jedoch aufgrund von architektonischen Unterschieden zwischen RedShift und Snowflake variieren.
SORTKEYverbessert die Leistung, indem Daten in einer sortierten Reihenfolge auf der Grundlage bestimmter Spalten gepflegt werden. Dies ist besonders vorteilhaft für Bereichsabfragen und Sortieroperationen.CLUSTER BYin Snowflake organisiert Daten in Blöcken, die auf bestimmten Spalten basieren, und hilft so bei Filter- und Aggregationsaufgaben. Allerdings ist das Sortieren im Vergleich zuSORTKEYstreng.
Das Verständnis dieser Mechanismen ist entscheidend für die Optimierung der Leistung auf der jeweiligen Plattform.
Codebeispiel¶
Eingabecode:¶
Redshift¶
Generierter Code:¶
Snowflake¶
Best Practices¶
Benchmark after migration: Run representative queries on both platforms to compare performance, as
CLUSTER BYuses micro-partitioning rather than physical sort order.Consider automatic clustering: For large tables with frequent queries on specific columns, enable automatic clustering in Snowflake.
Wenn Sie weitere Unterstützung benötigen, können Sie uns eine E-Mail an snowconvert-support@snowflake.com senden.
SSC-FDM-RS0003¶
Pending SnowConvert AI translation for Redshift foreign key constraints.
Beschreibung¶
Pending SnowConvert AI translation for Redshift foreign key constraints. Snowflake supports foreign key constraints, but they are not enforced and serve only as referential integrity metadata. This is a SnowConvert AI limitation, not a Snowflake platform limitation.
Codebeispiel¶
Eingabecode:¶
Redshift¶
Generierter Code:¶
Snowflake¶
Best Practices¶
Sie können mit Fremdschlüsseln manuell Tabellen ändern und diese hinzufügen.
Wenn Sie weitere Unterstützung benötigen, können Sie uns eine E-Mail an snowconvert-support@snowflake.com senden.
SSC-FDM-RS0004¶
Es ist möglich, dass das Datum falsch ist und Snowflake akzeptiert keine falschen Daten.
Beschreibung¶
In Snowflake führt die Verwendung von TO_DATE mit einer ungültigen Datumszeichenfolge (wie „20010631“) zu einem Fehler, da diese eine strenge Validierung erzwingt und alle nicht vorhandenen Datumsangaben ablehnt. Im Gegensatz dazu, kann TO_DATE in RedShift solche ungültigen Daten an das nächste gültige Datum anpassen (z. B. Ändern von 31. Juni auf 1. Juli), wenn der Parameter is_strict auf „false“ gesetzt ist. Dieser Unterschied macht deutlich, wie Snowflake die Datenintegrität priorisiert, indem ungültige Daten nicht automatisch korrigiert werden, während RedShift mehr Flexibilität bei der Verwendung von Daten ermöglicht.
Codebeispiel¶
Eingabecode:¶
Redshift¶
Generierter Code:¶
Snowflake¶
Best Practices¶
Überprüfen Sie, ob das Datum in TRY_TO_DATE() korrekt ist.
Wenn Sie weitere Unterstützung benötigen, können Sie uns eine E-Mail an snowconvert-support@snowflake.com senden.
SSC-FDM-RS0005¶
Redshift MERGE rejects duplicate source rows. Snowflake allows them, which may produce different results.
Beschreibung¶
In Redshift, the MERGE statement throws an error when the source table contains duplicate rows matching the join condition. Snowflake allows MERGE to execute with duplicate source rows, which may produce non-deterministic results when multiple source rows match the same target row.
Codebeispiel¶
Eingabecode:¶
Redshift¶
Generierter Code:¶
Snowflake¶
Best Practices¶
Deduplicate source data: Add a
QUALIFY ROW_NUMBER() OVER (PARTITION BY join_key ORDER BY ...) = 1to the source subquery to ensure each target row matches at most one source row.Validate results: After migration, compare
MERGEoutput row counts between Redshift and Snowflake to detect non-deterministic behavior.Wenn Sie weitere Unterstützung benötigen, können Sie uns eine E-Mail an snowconvert-support@snowflake.com senden.
SSC-FDM-RS0006¶
Called procedure contains usages of COMMIT/ROLLBACK. Modifying the current transaction in child scopes is not supported in Snowflake.
Beschreibung¶
In RedShift ist es zulässig, innerhalb einer Prozedur COMMIT- und ROLLBACK-Anweisungen zu verwenden, um Änderungen einer Transaktion, die in einem äußeren Scope geöffnet wurde, dauerhaft zu übernehmen oder zu verwerfen.
Snowflake arbeitet mit dem Konzept der bereichsbezogenen Transaktionen, bei dem jeder Prozeduraufruf als eigene Transaktion behandelt wird. Dadurch sind die Auswirkungen von COMMIT- und ROLLBACK-Anweisungen auf den Scope der Prozedur beschränkt, in der sie deklariert sind.
Der oben genannte funktionale Unterschied wird mit dieser FDM angezeigt, wenn SnowConvert Aufrufe einer Prozedur erkennt, die COMMIT- oder ROLLBACK-Anweisungen enthält.
Codebeispiel¶
Eingabecode:¶
Redshift¶
Generierter Code:¶
Snowflake¶
Best Practices¶
Refactor transaction control: Move
COMMITandROLLBACKstatements into the outermost procedure or use scoped transactions where supported.Use caller’s rights: Ensure the calling procedure manages the transaction boundary, as Snowflake’s scoped transactions isolate child procedure changes.
Wenn Sie weitere Unterstützung benötigen, können Sie uns eine E-Mail an snowconvert-support@snowflake.com senden.
SSC-FDM-RS0007¶
DDL statements perform an automatic COMMIT in Snowflake. ROLLBACK will not undo DDL-committed changes.
Beschreibung¶
In Snowflake führen DDL-Anweisungen nach ihrer Ausführung automatisch ein COMMIT aus und machen damit alle Änderungen der aktuellen Transaktion dauerhaft. Das bedeutet, dass diese Änderungen nicht durch ein ROLLBACK rückgängig gemacht werden können.
Wenn in einer Prozedur eine ROLLBACK-Anweisung gefunden wird, die zusätzlich eine DDL-Anweisung enthält, generiert SnowConvert AI diese FDM, um auf das Autocommit-Verhalten von DDL-Anweisungen hinzuweisen.
Codebeispiel¶
Eingabecode:¶
Redshift¶
Generierter Code:¶
Snowflake¶
Best Practices¶
Separate DDL from DML transactions: Move DDL statements outside the transaction block, or execute them before
BEGIN TRANSACTIONto avoid implicit commits affecting DML operations.Use conditional logic: If DDL creation is conditional, check for object existence with
IF NOT EXISTSto avoid unnecessary autocommits.Wenn Sie weitere Unterstützung benötigen, können Sie uns eine E-Mail an snowconvert-support@snowflake.com senden.
SSC-FDM-RS0008¶
Snowflake uses autocommit by default. The NONATOMIC option is not supported in Snowflake.
Beschreibung¶
In Redshift, the NONATOMIC option on CREATE PROCEDURE allows individual statements within the procedure to commit independently. In Snowflake, autocommit is the default behavior — each statement is automatically committed unless wrapped in an explicit BEGIN TRANSACTION block. The NONATOMIC keyword is removed during migration because Snowflake’s autocommit provides equivalent semantics.
Codebeispiel¶
Eingabecode:¶
Redshift¶
Generierter Code:¶
Snowflake¶
Best Practices¶
Verify transaction behavior: If the original Redshift procedure relied on
NONATOMICfor partial commits, test the migrated Snowflake procedure to confirm that autocommit provides the expected semantics.Add explicit transactions where needed: If you need atomic (all-or-nothing) behavior for a group of statements in Snowflake, wrap them in
BEGIN TRANSACTION…COMMIT.Wenn Sie weitere Unterstützung benötigen, können Sie uns eine E-Mail an snowconvert-support@snowflake.com senden.