Dağınık dizgeleri temizleme

SQL Server Veritabanlarında Veri Temizleme

Miriam Antona

Software Engineer

Fazladan boşlukları kaldırma

SELECT * FROM carriers
| code | name                            |
|------|---------------------------------|
| YV   | Mesa Airlines Inc.              |
| AA   |   American Airlines Inc.        |
| B6   |   JetBlue Airways               |
| DL   |   Delta Air Lines Inc.          |
| HA   |   Hawaiian Airlines Inc.        |
| MQ   |   American Eagle Airlines Inc.  |
| EV   |  ExpressJet Airlines Inc.       |
| UA   |  United Air Lines Inc.          |
| US   |  US Airways Inc.                |
| ...  | ...                             |
SQL Server Veritabanlarında Veri Temizleme

Fazladan boşlukları kaldırma - TRIM

TRIM ( [characters ] string )
  • SQL Server 2017’den beri mevcut
  • Bir dizgenin başındaki ve sonundaki belirtilen karakterleri kaldırır
  • Karakter belirtmezsek boşluk karakterini kaldırır
SELECT TRIM('   JetBlue Airways    ');
JetBlue Airways
SQL Server Veritabanlarında Veri Temizleme

Fazladan boşlukları kaldırma - RTRIM ve LTRIM

  • SQL Server 2017’den eski sürümler için -> RTRIM ve LTRIM.
-- Sondaki tüm boşlukları kaldırır
RTRIM ( character_expression )
-- Baştaki tüm boşlukları kaldırır
LTRIM ( character_expression )
SELECT LTRIM(RTRIM('   JetBlue Airways    '));
JetBlue Airways
SQL Server Veritabanlarında Veri Temizleme

Fazladan boşlukları kaldırma

SELECT code, TRIM(name) AS name FROM carriers
SELECT code, LTRIM(RTRIM(name)) AS name FROM carriers
| code | name                         |
|------|------------------------------|
| YV   | Mesa Airlines Inc.           |
| AA   | American Airlines Inc.       |
| B6   | JetBlue Airways              |
| DL   | Delta Air Lines Inc.         |
| HA   | Hawaiian Airlines Inc.       |
| US   | US Airways Inc.              |
| ...  | ...                          |
SQL Server Veritabanlarında Veri Temizleme

Dizgeleri birleştirme

SELECT * FROM airports 
ORDER BY airport_state
| airport_code | airport_name                            | airport_city    | airport_state |
|--------------|-----------------------------------------|-----------------|---------------|
| ...          | ...                                     | ...             | ...           |
| MIA          | Miami International                     | Miami           | fl            |
| TPA          | Tampa International                     | Tampa           | Fl            |
| FLL          | Fort Lauderdale-Hollywood International | Fort Lauderdale | FL            |
| MCO          | Orlando International                   | Orlando         | Florida       |
| ...          | ...                                     | ...             | ...           |
SQL Server Veritabanlarında Veri Temizleme

Dizgeleri birleştirme - REPLACE

"Fl" / "fl" / "Florida" -> "Florida"

REPLACE ( string_to_replace , occurrences , string_replacement )
  • Belirtilen tüm alt dizgeleri başka bir dizgeyle değiştirir

  • Karşılaştırmaları girdinin sıralamasına (collation) göre yapar

    • Belirli bir sıralama ile karşılaştırmak için COLLATE kullanın
    • Girdilerimizin sıralamasının büyük/küçük harfe duyarsız olduğunu varsayalım
SQL Server Veritabanlarında Veri Temizleme

Dizgeleri birleştirme - REPLACE

SELECT 
    airport_code, airport_name, airport_city, 
    REPLACE(airport_state, 'FL', 'Florida') AS airport_state
FROM airports
ORDER BY airport_state
| airport_code | airport_name                            | airport_city    | airport_state |
|--------------|-----------------------------------------|-----------------|---------------|
| ...          | ...                                     | ...             | ...           |
| MIA          | Miami International                     | Miami           | Florida       |
| TPA          | Tampa International                     | Tampa           | Florida       |
| FLL          | Fort Lauderdale-Hollywood International | Fort Lauderdale | Florida       |
| MCO          | Orlando International                   | Orlando         | Floridaorida  |
| ...          | ...                                     | ...             | ...           |
SQL Server Veritabanlarında Veri Temizleme

Dizgeleri birleştirme - REPLACE

SELECT 
    airport_code, airport_name, airport_city, 
    REPLACE
        (REPLACE(airport_state, 'FL', 'Florida'),
         'Floridaorida', 'Florida') AS airport_state
FROM airports
ORDER BY airport_state
| airport_code | airport_name                            | airport_city    | airport_state |
|--------------|-----------------------------------------|-----------------|---------------|
| MCO          | Orlando International                   | Orlando         | Florida       |
| TPA          | Tampa International                     | Tampa           | Florida       |
| FLL          | Fort Lauderdale-Hollywood International | Fort Lauderdale | Florida       |
| MIA          | Miami International                     | Miami           | Florida       |
| ...          | ...                                     | ...             | ...           |
SQL Server Veritabanlarında Veri Temizleme

Dizgeleri birleştirme - REPLACE + CASE

SELECT airport_code, airport_name, airport_city, 
    CASE
        WHEN airport_state <> 'Florida' THEN REPLACE(airport_state, 'FL', 'Florida')
        ELSE airport_state 
    END AS airport_state
FROM airports
ORDER BY airport_state
| airport_code | airport_name                            | airport_city    | airport_state |
|--------------|-----------------------------------------|-----------------|---------------|
| MCO          | Orlando International                   | Orlando         | Florida       |
| TPA          | Tampa International                     | Tampa           | Florida       |
| FLL          | Fort Lauderdale-Hollywood International | Fort Lauderdale | Florida       |
| MIA          | Miami International                     | Miami           | Florida       |
| ...          | ...                                     | ...             | ...           |
SQL Server Veritabanlarında Veri Temizleme

Dizgeleri birleştirme - REPLACE + UPPER

"Fl" / "fl" / "Florida" -> "FL"

SELECT 
    airport_code, airport_name, airport_city, 
    REPLACE(airport_state, 'Florida', 'FL') AS airport_state
FROM airports
ORDER BY airport_state
| airport_code | airport_name                            | airport_city    | airport_state |
|--------------|-----------------------------------------|-----------------|---------------|
| MCO          | Orlando International                   | Orlando         | FL            |
| TPA          | Tampa International                     | Tampa           | Fl            |
| FLL          | Fort Lauderdale-Hollywood International | Fort Lauderdale | FL            |
| MIA          | Miami International                     | Miami           | fl            |
| ...          | ...                                     | ...             | ...           |
SQL Server Veritabanlarında Veri Temizleme

Dizgeleri birleştirme - REPLACE + UPPER

UPPER ( character_expression )
  • Verilen bir dizgeyi büyük harfe çevirir.
SELECT 
    airport_code, airport_name, airport_city, 
        UPPER(
              REPLACE(airport_state, 'Florida', 'FL')
        ) AS airport_state
FROM airports
ORDER BY airport_state
SQL Server Veritabanlarında Veri Temizleme

Dizgeleri birleştirme - REPLACE + UPPER

| airport_code | airport_name                            | airport_city    | airport_state |
|--------------|-----------------------------------------|-----------------|---------------|
| ...          | ...                                     | ...             | ...           |
| MCO          | Orlando International                   | Orlando         | FL            |
| TPA          | Tampa International                     | Tampa           | FL            |
| FLL          | Fort Lauderdale-Hollywood International | Fort Lauderdale | FL            |
| MIA          | Miami International                     | Miami           | FL            |
| ...          | ...                                     | ...             | ...           |
SQL Server Veritabanlarında Veri Temizleme

Hadi pratik yapalım!

SQL Server Veritabanlarında Veri Temizleme

Preparing Video For Download...