Tekstgegevens manipuleren

Gegevenstypen en functies in Snowflake

Jake Roach

Field Data Engineer

De LENGTH van een string bepalen

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 geeft het aantal tekens in een tekststring

$$

  • Inclusief spaties
  • VARCHAR, TEXT, STRING, enz.
  • LEN is hetzelfde als LENGTH
Gegevenstypen en functies in Snowflake

TRIM

Verwijdert beginnende en eindigende tekens uit tekstwaarden

$$

  • Meest gebruikt om spaties te verwijderen
  • Niet hoofdlettergevoelig
  • Heeft varianten LTRIM en RTRIM
SELECT
    <field>,

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

FROM ...;

<1>: de kolom of waarde die je bijsnijdt

<2>: optioneel, het patroon om aan begin/eind te verwijderen; anders ' ' (spatie)

Gegevenstypen en functies 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
Gegevenstypen en functies in Snowflake

SPLIT

Hakt tekst op in een array met waarden op basis van een scheidingsteken

$$

  • Resultaattype is ARRAY
  • Haal waarden op met bracket-notatie

$$

$$

<1>: de kolom om te SPLITten

<2>: het scheidingsteken om op te splitsen

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']
Gegevenstypen en functies 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
Gegevenstypen en functies in Snowflake

CONCAT

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

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

FROM ...;

Kan twee of meer tekstwaarden aan elkaar plakken

$$

  • Willekeurig aantal waarden, gescheiden door ,
  • Spaties expliciet opnemen
  • Handig voor voor- en achternaam combineren
Gegevenstypen en functies 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
Gegevenstypen en functies in Snowflake

Laten we oefenen!

Gegevenstypen en functies in Snowflake

Preparing Video For Download...