SnowConvert AI - Paramètres de conversion Oracle

Paramètres de conversion généraux

Conversion des objets

Page des paramètres de conversion généraux

  1. Transformer les synonymes : Indicateur signalant si les synonymes doivent être transformés ou non. Par défaut, ce paramètre est défini sur true.

  2. Transformer les paquets en nouveaux schémas : Indicateur signalant si les paquets doivent être transformés ou non en nouveaux schémas.

    Veuillez vérifier l’appellation de la procédure d’activation et de désactivation de l’indicateur :

Entrée

CREATE OR REPLACE PACKAGE emp_mgmt AS
PROCEDURE remove_emp (employee_id NUMBER );
END emp_mgmt;

CREATE OR REPLACE PACKAGE BODY emp_mgmt AS 
PROCEDURE remove_emp (employee_id NUMBER) IS 
   BEGIN 
      DELETE FROM employees 
      WHERE employees.employee_id = remove_emp.employee_id; 
      tot_emps := tot_emps - 1; 
   END; 
END emp_mgmt; 
Copy

Sortie par défaut

CREATE SCHEMA IF NOT EXISTS emp_mgmt
COMMENT = '{"origin":"sf_sc","name":"snowconvert","version":{"major":1, "minor":0},"attributes":{"component":"oracle"}}'
;

CREATE OR REPLACE PROCEDURE emp_mgmt.remove_emp (employee_id NUMBER(38, 18))
RETURNS VARCHAR
LANGUAGE SQL
COMMENT = '{"origin":"sf_sc","name":"snowconvert","version":{"major":1, "minor":0},"attributes":{"component":"oracle"}}'
EXECUTE AS CALLER
AS
$$
   BEGIN
      DELETE FROM
         employees
         WHERE employees.employee_id = remove_emp.employee_id;
         tot_emps :=
                     !!!RESOLVE EWI!!! /*** SSC-EWI-OR0036 - TYPES RESOLUTION ISSUES, ARITHMETIC OPERATION '-' MAY NOT BEHAVE CORRECTLY BETWEEN unknown AND Number ***/!!!
                     tot_emps - 1;
   END;
$$;
Copy

Sortie avec paramètre disablePackagesAsSchemas

-- Additional Params: --disablePackagesAsSchemas
CREATE OR REPLACE PROCEDURE EMP_MGMT_REMOVE_EMP (employee_id NUMBER(38, 18))
RETURNS VARCHAR
LANGUAGE SQL
COMMENT = '{"origin":"sf_sc","name":"snowconvert","version":{"major":1, "minor":0},"attributes":{"component":"oracle"}}'
EXECUTE AS CALLER
AS
$$
   BEGIN
      DELETE FROM
         employees
         WHERE employees.employee_id = remove_emp.employee_id;
         tot_emps :=
                     !!!RESOLVE EWI!!! /*** SSC-EWI-OR0036 - TYPES RESOLUTION ISSUES, ARITHMETIC OPERATION '-' MAY NOT BEHAVE CORRECTLY BETWEEN unknown AND Number ***/!!!
                     tot_emps - 1;
   END;
$$;
Copy
  1. Transformer la date en horodatage :

Indicateur spécifiant si SYSDATE doit être transformé en CURRENT_DATE ou CURRENT_TIMESTAMP. Cela affectera également toutes les colonnes DATE qui seront transformées en TIMESTAMP.

Entrée

CREATE TABLE DATE_TABLE(
    DATE_COL DATE
);

SELECT SYSDATE FROM DUAL;
Copy

Sortie par défaut

CREATE OR REPLACE TABLE DATE_TABLE (
        DATE_COL TIMESTAMP /*** SSC-FDM-OR0042 - DATE TYPE COLUMN HAS A DIFFERENT BEHAVIOR IN SNOWFLAKE. ***/
    )
    COMMENT = '{"origin":"sf_sc","name":"snowconvert","version":{"major":1, "minor":0},"attributes":{"component":"oracle"}}'
    ;

    SELECT
        CURRENT_TIMESTAMP()
    FROM DUAL;
Copy

Sortie avec paramètre disableDateAsTimestamp

-- Additional Params: --disableDateAsTimestamp
CREATE OR REPLACE TABLE DATE_TABLE (
        DATE_COL DATE /*** SSC-FDM-OR0042 - DATE TYPE COLUMN HAS A DIFFERENT BEHAVIOR IN SNOWFLAKE. ***/
    )
    COMMENT = '{"origin":"sf_sc","name":"snowconvert","version":{"major":1, "minor":0},"attributes":{"component":"oracle"}}'
    ;

    SELECT
        CURRENT_DATE()
    FROM DUAL;
Copy
  1. Transformer les JOINS OUTER en syntaxe ANSI : Indicateur signalant si les jointures externes doivent être transformées en syntaxe ANSI uniquement.

  2. Types de conversion de données : vous pouvez importer un fichier JSON ci-dessous pour définir des types de données spécifiques en tenant compte de l’origine du type de données et du nom de la colonne.

Onglet Résultats généraux

Onglet Résultats généraux

  1. Objets de commentaire avec des dépendances manquantes : indique si l’utilisateur souhaite commenter les nœuds dont les dépendances sont manquantes.

  2. Définition de l’encodage des fichiers d’entrée : consultez Paramètres généraux de conversion pour plus de détails.

Note

Pour passer en revue les paramètres qui s’appliquent à l’ensemble des langages pris en charge, consultez l”article suivant.

Paramètres des noms d’objet DB

Page des paramètres des noms d'objet DB

  1. Schéma : La valeur de chaîne spécifie le nom du schéma personnalisé à appliquer. S’il n’est pas spécifié, le nom de la base de données d’origine sera utilisé. Exemple : DB1.myCustomSchema.Table1.

  2. Base de données : La valeur de chaîne spécifie le nom de la base de données personnalisée à appliquer. Exemple : MyCustomDB.PUBLIC.Table1.

  3. Par défaut : Aucun des paramètres ci-dessus ne sera utilisé dans les noms d’objet.

Paramètres de préparation du code

Page des paramètres de préparation du code

Description

Préparer mon code : indique si le code d’entrée doit être traité avant l’analyse et la transformation. Cela peut être utile pour améliorer le processus d’analyse. Par défaut, la valeur est FALSE.

Divise les objets de niveau supérieur du code d’entrée en plusieurs fichiers. Les dossiers contenant des dossiers seront organisés comme suit :

Copie

└───A new folder named ''[input_folder_name]_Processed''
    └───Top-level object type
        └───Schema name
Copy

Exemple

Entrée

├───in
│       DDL_Packages.sql
│       DDL_Procedures.sql
│       DDL_Tables.sql
Copy

Sortie

Supposons que le nom des fichiers soit le nom des objets de niveau supérieur dans les fichiers d’entrée.


├───in_Processed
    ├───package
    │   └───MY_SCHEMA
    │           MY_FIRST_PACKAGE.sql
    │           ANOTHER_PACKAGE.sql
    │
    ├───procedure
    │   └───MY_SCHEMA
    │           A_PROCEDURE.sql
    │           ANOTHER_PROCEDURE.sql
    │           YET_ANOTHER_PROCEDURE.sql
    │
    └───table
        └───MY_SCHEMA
                MY_TABLE.sql
                ADDITIONAL_TABLE.sql
                THIRD_TABLE.sql
Copy

Dans le dossier « nom du schéma », il doit y avoir autant de fichiers que d’objets de premier niveau dans le code d’entrée. De plus, il est possible d’avoir des copies de certains fichiers lorsque plusieurs objets de niveau supérieur de même type ont le même nom. Dans ce cas, les noms de fichiers seront énumérés par ordre croissant.

Exigences

Pour identifier les objets de niveau supérieur, une balise doit être incluse dans un commentaire avant leur déclaration. Nos scripts Extraction génèrent ces balises.

La balise doit respecter le format suivant :

<sc-top_level_object_type>top_level_object_name</sc-top_level_object_type>
Copy

Vous pouvez suivre l’exemple suivant :

/* <sc-table> MY_SCHEMA.MY_TABLE</sc-table> */
CREATE TABLE "MY_SCHEMA"."MY_TABLE" (
    "MY_COLUMN" VARCHAR2(128)
) ;
Copy

Paramètres du taux de conversion

Page des paramètres du taux de conversion

Sur cette page, vous pouvez choisir si le pourcentage de code converti avec succès est calculé en utilisant les lignes de code ou en utilisant le nombre total de caractères. Le taux de conversion des caractères est l’option par défaut. Vous pouvez lire la documentation complète sur les taux sur la page de documentation.

Paramètres des langues cibles des procédures stockées

Page des paramètres des langues cibles des procédures stockées

Sur cette page, vous pouvez choisir si les procédures stockées sont migrées vers des procédures JavaScript intégrées dans Snow SQL, ou vers Snowflake Scripting. L’option par défaut est Snowflake Scripting.

Réinitialiser les paramètres : l’option Réinitialiser les paramètres apparaît sur chaque page. Si vous avez apporté des modifications, vous pouvez réinitialiser SnowConvert AI à ses paramètres par défaut d’origine.