Manipolare i dati di testo

Tipi di dati e funzioni in Snowflake

Jake Roach

Field Data Engineer

Trovare la LENGTH di una stringa

LENGTH(<field>)
SELECT
    song_name,
    LENGTH(song_name) AS characters
FROM MUSIC.songs;
       song_name    |  characters
   ---------------- | -----------
     Levon          |      5     
     Tiny Dancer    |      11
     Rocket Man     |      10

LENGTH restituisce il numero di caratteri in una stringa

$$

  • Include gli spazi
  • VARCHAR, TEXT, STRING, ecc.
  • LEN è sinonimo di LENGTH
Tipi di dati e funzioni in Snowflake

TRIM

Rimuove i caratteri iniziali e finali dai valori di testo

$$

  • Usata soprattutto per rimuovere spazi
  • Case-insensitive
  • Controparti: LTRIM e RTRIM
SELECT
    <field>,

    -- Remove characters at the
    -- beginning or end of the column
    TRIM(<1>, <2>)

FROM ...;

<1>: la colonna o il valore da ripulire

<2>: opzionale, il pattern da togliere all’inizio o alla fine; altrimenti è uno spazio ' '

Tipi di dati e funzioni in Snowflake

TRIM

SELECT
    song_long_name,
    TRIM(song_long_name, '(Remastered)') AS trimmed_song_name
FROM MUSIC.songs;
TRIM(song_long_name, '(Remastered)')
                song_long_name          |     trimmed_song_name
           ---------------------------- | --------------------------
             (Remastered) Piano Man     |      Piano Man
             Ticking (Remastered)       |      Ticking
             Come Sail Away             |      Come Sail Away
Tipi di dati e funzioni in Snowflake

SPLIT

Divide il testo in un array di valori in base a un separatore

$$

  • Il tipo restituito è ARRAY
  • Puoi usare le parentesi per recuperare i valori

$$

$$

<1>: la colonna da SPLIT

<2>: il separatore

SELECT
    <field>,

    -- SPLIT the field, use bracket-
    -- notation to retrieve first chunk
    SPLIT(<1>, <2>),
    SPLIT(<1>, <2>)[X]

FROM ...;
       Math,Science,Art,Reading
                 ...
 ['Math', 'Science', 'Art', 'Reading']
Tipi di dati e funzioni in Snowflake

SPLIT

SELECT
    collaborators,

SPLIT(collaborators, ',') AS all_collaborators,
SPLIT(collaborators, ',')[0] AS primary_artist -- Return the first collaborator
FROM MUSIC.songs;
          collaborators       |          all_collaborators         |  primary_artist
   -------------------------- | ---------------------------------- | ---------------
   Queen, David Bowie         |  ['Queen', ' David Bowie']         |  Queen
   Elton John, Kiki Dee       |  ['Elton John', ' Kiki Dee']       |  Elton John
   Carly Simon, James Taylor  |  ['Carly Simon', ' James Taylor']  |  Carly Simon
Tipi di dati e funzioni in Snowflake

CONCAT

SELECT
    <field>,
    <another-field>,
    <third-field>,

    CONCAT(
        <field>, 
        <another-field>,
        ' ',
        <third-field>
    )

FROM ...;

Può unire due o più valori di testo

$$

  • Numero arbitrario di valori, separati da ,
  • Devi inserire gli spazi tra i caratteri
  • Utile per combinare nome e cognome
Tipi di dati e funzioni in Snowflake

CONCAT

SELECT
    song_name, artist_name,

    -- Concatenate three text values together
    CONCAT(song_name, ' is written by ', artist_name) AS description

FROM MUSIC.songs;
      song_name    |   artist_name  |         description        
 ----------------- | -------------- | --------------------------------------------
 Night Moves       |  Bob Seger     |  Night Moves is written by Bob Seger
 Cracklin' Rosie   |  Neal Diamond  |  Cracklin' Rosie is written by Neal Diamond
Tipi di dati e funzioni in Snowflake

Passons à la pratique !

Tipi di dati e funzioni in Snowflake

Preparing Video For Download...