Funzioni definite dall’utente in Snowflake

Tipi di dati e funzioni in Snowflake

Jake Roach

Field Data Engineer

Cosa sono le funzioni definite dall’utente (UDF)?

“Impacchetta” logica complessa in una funzione singola e riutilizzabile

$$

  • Più leggibile
  • Meno errori
  • Condividi la logica con altri

$$

$$

                      ... vediamolo da vicino!

Immagine che illustra il concetto di funzione definita dall’utente.

Tipi di dati e funzioni in Snowflake

Refactoring del codice con una UDF

SELECT
    first_name, last_name, school_name,

    CONCAT(
        first_name,
        '.',
        last_name,
        '@',
        school_name,
        '.com'
    )

FROM STUDENTS.personal_info;
SELECT
    first_name, 
    last_name, 
    school_name,

-- Riutilizzabile, leggibile build_email_address( first_name, last_name, school_name ) AS email_address
FROM STUDENTS.personal_info;
Tipi di dati e funzioni in Snowflake

Definire una UDF

CREATE OR REPLACE FUNCTION <name> (

-- Specifica argomenti e tipi <arg1> <type1>, <arg2> <type2>, ... )
RETURN <type> -- Dichiara il tipo di ritorno
AS $$ -- Definisci qui la funzione $$

$$

$$

  1. CREATE OR REPLACE FUNCTION
  2. Fornisci un nome funzione
  3. Tra parentesi, specifica nome e tipo di ogni argomento
  4. Dichiara il tipo di RETURN
  5. Definisci la logica tra $$ ... $$!
Tipi di dati e funzioni in Snowflake

Creare un indirizzo email

CREATE OR REPLACE FUNCTION build_email_address(

first_name TEXT, last_name TEXT, school_name TEXT
)
RETURN TEXT
AS $$ CONCAT(LOWER(first_name), '.', LOWER(last_name), '@', LOWER(school_name), '.com') $$;
Tipi di dati e funzioni in Snowflake

Usare una UDF

SELECT
    first_name, last_name, school_name,
    build_email_address(first_name, last_name, school_name) AS email_address

FROM STUDENTS.personal_info;
      first_name  |  last_name  |  school_name  |        email_address
     ------------ | ----------- | ------------- | ----------------------------
       Ryan       |  Cohen      |  Harvard      |  [email protected]
       Tatiana    |  Doyle      |  Stanford     |  [email protected]
       Pankaj     |  Pandey     |  MIT          |  [email protected]
       Jake       |  Roach      |  Purdue       |  [email protected]
Tipi di dati e funzioni in Snowflake

Passiamo alla pratica !

Tipi di dati e funzioni in Snowflake

Preparing Video For Download...