Funzioni per posizioni

Funzioni per manipolare i dati in SQL Server

Ana Voicu

Data Engineer

Funzioni di posizione

  • LEN()
  • CHARINDEX()
  • PATINDEX()
Funzioni per manipolare i dati in SQL Server

LEN()

Definizione

  • Restituisce il numero di caratteri della stringa fornita.

Sintassi

LEN(character_expression)

Funzioni per manipolare i dati in SQL Server

Esempio LEN() - parametro costante

SELECT LEN('Do you know the length of this sentence?') AS length
|length|
|------|
|40    |
Funzioni per manipolare i dati in SQL Server

Esempio LEN() - parametro colonna tabella

SELECT DISTINCT TOP 5 
    bean_origin, 
    LEN(bean_origin) AS length
FROM ratings;
|bean_origin             |length|
|------------------------|------|
|Toscano Black           |13    |
|Trinite                 |7     |
|Ocumare- Puerto Cabello |23    |
|Maracaibo- El Rosario   |21    |
|Madagascar              |10    |
Funzioni per manipolare i dati in SQL Server

CHARINDEX()

Definizione

  • Cerca un'espressione di caratteri in una stringa.
  • Restituisce la posizione iniziale.

Sintassi

CHARINDEX (expression_to_find, expression_to_search [, start_location])

Funzioni per manipolare i dati in SQL Server

Esempio CHARINDEX()

SELECT 
 CHARINDEX('chocolate', 'White chocolate is not real chocolate'),
 CHARINDEX('chocolate', 'White chocolate is not real chocolate',10),
 CHARINDEX('chocolates', 'White chocolate is not real chocolate');
|position beginning|position in string|position of non-existing exp|
|------------------|------------------|----------------------------|
|7                 |29                |0                           |
Funzioni per manipolare i dati in SQL Server

PATINDEX()

Definizione

  • Simile a CHARINDEX()

  • Restituisce la posizione iniziale di un pattern in un'espressione

Sintassi

PATINDEX ('%pattern%', expression, [location ])

Funzioni per manipolare i dati in SQL Server

Caratteri jolly

Wildcard Spiegazione
% Corrisponde a qualsiasi stringa di lunghezza qualsiasi (anche zero)
_ Corrisponde a un singolo carattere
[ ] Corrisponde a un carattere tra le parentesi [ ] (ad es., [abc] corrisponde a a, b o c)
Funzioni per manipolare i dati in SQL Server

Esempio PATINDEX()

SELECT 
  PATINDEX('%chocolate%', 'White chocolate is not real chocolate') AS position1,
  PATINDEX('%ch_c%', 'White chocolate is not real chocolate') AS position2;

|position1|position2|
|---------|---------|
|7        |7        |
Funzioni per manipolare i dati in SQL Server

Ayo berlatih!

Funzioni per manipolare i dati in SQL Server

Preparing Video For Download...