Gegevenstypen en functies in Snowflake
Jake Roach
Field Data Engineer
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
$$
VARCHAR, TEXT, STRING, enz.LEN is hetzelfde als LENGTHVerwijdert beginnende en eindigende tekens uit tekstwaarden
$$
LTRIM en RTRIMSELECT
<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)
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
Hakt tekst op in een array met waarden op basis van een scheidingsteken
$$
ARRAY$$
$$
<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']
SELECT collaborators,SPLIT(collaborators, ',') AS all_collaborators,SPLIT(collaborators, ',')[0] AS primary_artist -- Return the first collaboratorFROM 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
SELECT
<field>,
<another-field>,
<third-field>,
CONCAT(
<field>,
<another-field>,
' ',
<third-field>
)
FROM ...;
Kan twee of meer tekstwaarden aan elkaar plakken
$$
,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