Patroonmatching

Gegevens opschonen in SQL Server-databases

Miriam Antona

Software Engineer

Patroonmatching - Introductie

SELECT * FROM series
| id  | name            | contact_number | ... |
|-----|-----------------|----------------|-----|
| 1   | Adventure Time  | 555-906-8845   | ... |
| 2   | Dexter          | 555-156-8845   | ... |
| 3   | Futurama        | 555-210-9951   | ... |
| 4   | Game of Thrones | 555-543-6641   | ... |
| ... | ...             | ...            | ... |
  • Geldige nummers: ###-###-####
    • eerste en vierde cijfer tussen 2 en 9
    • de rest tussen 0 en 9
  • Ongeldig nummer: 555-156-8845
Gegevens opschonen in SQL Server-databases

Patroonmatching - Introductie

  • SQL Server biedt geen volledige set reguliere expressies.
  • SQL Server kan patronen matchen met LIKE.
  • Voor de volledige set reguliere expressies: maak en installeer extensies.
Gegevens opschonen in SQL Server-databases

Patroonmatching - LIKE

  • Bepaalt of een string aan een patroon voldoet
Gegevens opschonen in SQL Server-databases

Patroonmatching - LIKE

  • Bepaalt of een string aan een patroon voldoet
Jokerteken Beschrijving Voorbeeld
% Elke tekenreeks van nul of meer tekens WHERE contact_number LIKE '555-%'
_ (underscore) Elk enkel teken WHERE contact_number LIKE '___-___-____'
[] Elk enkel teken binnen het opgegeven bereik of de set WHERE contact_number LIKE '[2-9][0-9][0-9]-[2-9][0-9][0-9]-[0-9][0-9][0-9][0-9]
[^] Elk enkel teken buiten het opgegeven bereik of de set WHERE contact_number LIKE '[^2-9]'
Gegevens opschonen in SQL Server-databases

Patroonmatching - voorbeeld met %

SELECT name, contact_number
FROM series
WHERE contact_number LIKE '555%'
| name            | contact_number |
|-----------------|----------------|
| Adventure Time  | 555-906-8845   |
| Dexter          | 555-156-8845   |
| Futurama        | 555-210-9951   |
| Game of Thrones | 555-abc-6641   |
| ...             | ...            |
Gegevens opschonen in SQL Server-databases

Patroonmatching - voorbeeld met %

SELECT 
    name, 
    contact_number
FROM series
WHERE contact_number NOT LIKE '555%'
| name            | contact_number |
|-----------------|----------------|
| The Good Doctor | 000-930-1274   |
Gegevens opschonen in SQL Server-databases

Patroonmatching - voorbeeld met [] (haken)

SELECT 
    name, 
    contact_number
FROM series
WHERE contact_number LIKE '[2-9][0-9][0-9]-[2-9][0-9][0-9]-[0-9][0-9][0-9][0-9]'
| name           | contact_number |
|----------------|----------------|
| Adventure Time | 555-906-8845   |
| Futurama       | 555-210-9951   |
| Homeland       | 555-985-6314   |
| Westworld      | 555-456-1234   |
| ...            | ...            |
Gegevens opschonen in SQL Server-databases

Patroonmatching - voorbeeld met [] (haken)

SELECT 
    name, 
    contact_number
FROM series
WHERE contact_number NOT LIKE '[2-9][0-9][0-9]-[2-9][0-9][0-9]-[0-9][0-9][0-9][0-9]'
| name            | contact_number |
|-----------------|----------------|
| Dexter          | 555-156-8845   |
| Game of Thrones | 555-abc-6641   |
| The Good Doctor | 000-930-1274   |
Gegevens opschonen in SQL Server-databases

Laten we oefenen!

Gegevens opschonen in SQL Server-databases

Preparing Video For Download...