Metin verileriyle çalışma

Snowflake'te Veri Türleri ve Fonksiyonlar

Jake Roach

Field Data Engineer

Bir dizginin LENGTH değeri

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, bir metin dizisindeki karakter sayısını döndürür

$$

  • Boşluklar dahildir
  • VARCHAR, TEXT, STRING, vb.
  • LEN, LENGTH ile eşanlamlıdır
Snowflake'te Veri Türleri ve Fonksiyonlar

TRIM

Metinlerin başındaki ve sonundaki karakterleri kaldırır

$$

  • En çok boşluk kaldırmak için kullanılır
  • Büyük/küçük harfe duyarsız
  • LTRIM ve RTRIM karşılıkları vardır
SELECT
    <field>,

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

FROM ...;

<1>: kırpılacak sütun veya değer

<2>: isteğe bağlı, baştan/sondan kırpılacak desen; verilmezse ' ' (boşluk) kullanılır

Snowflake'te Veri Türleri ve Fonksiyonlar

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
Snowflake'te Veri Türleri ve Fonksiyonlar

SPLIT

Metni bir ayırıcıya göre bir değer dizisine böler

$$

  • Dönüş türü ARRAY
  • Köşeli ayraç gösterimiyle değerlere erişilebilir

$$

$$

<1>: SPLIT uygulanacak sütun

<2>: bölünecek ayırıcı

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']
Snowflake'te Veri Türleri ve Fonksiyonlar

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
Snowflake'te Veri Türleri ve Fonksiyonlar

CONCAT

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

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

FROM ...;

İki veya daha fazla metin değerini birleştirir

$$

  • Virgülle ayrılmış, isteğe bağlı sayıda değer
  • Boşlukları özellikle eklemek gerekir
  • Ad ve soyadı birleştirmek için kullanışlı
Snowflake'te Veri Türleri ve Fonksiyonlar

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
Snowflake'te Veri Türleri ve Fonksiyonlar

Vamos praticar!

Snowflake'te Veri Türleri ve Fonksiyonlar

Preparing Video For Download...