Memanipulasi data teks

Tipe Data dan Fungsi di Snowflake

Jake Roach

Field Data Engineer

Menemukan LENGTH dari string

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 mengembalikan jumlah karakter dalam string teks

$$

  • Termasuk spasi
  • VARCHAR, TEXT, STRING, dll.
  • LEN sinonim LENGTH
Tipe Data dan Fungsi di Snowflake

TRIM

Menghapus karakter di awal dan akhir nilai teks

$$

  • Paling sering untuk menghapus spasi
  • Tidak peka huruf besar/kecil
  • Ada padanan LTRIM dan RTRIM
SELECT
    <field>,

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

FROM ...;

<1>: kolom atau nilai yang akan dipangkas

<2>: opsional, pola untuk memangkas dari awal atau akhir; jika tidak, ' ' (spasi)

Tipe Data dan Fungsi di 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
Tipe Data dan Fungsi di Snowflake

SPLIT

Memecah teks menjadi array nilai berdasarkan pemisah tertentu

$$

  • Tipe keluaran ARRAY
  • Dapat gunakan notasi kurung untuk mengambil nilai

$$

$$

<1>: kolom yang akan di-SPLIT

<2>: pemisah untuk membagi

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']
Tipe Data dan Fungsi di 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
Tipe Data dan Fungsi di Snowflake

CONCAT

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

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

FROM ...;

Dapat menggabungkan dua atau lebih nilai teks

$$

  • Jumlah nilai bebas, dipisah dengan ,
  • Perlu menambahkan spasi di antara karakter
  • Berguna untuk menggabungkan nama depan dan belakang
Tipe Data dan Fungsi di 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
Tipe Data dan Fungsi di Snowflake

Ayo berlatih!

Tipe Data dan Fungsi di Snowflake

Preparing Video For Download...