Conversione esplicita

Funzioni per manipolare i dati in SQL Server

Ana Voicu

Data Engineer

Conversione implicita ed esplicita

  • IMPLICITA: eseguita automaticamente, in background
  • ESPLICITA: eseguita con le funzioni CAST() e CONVERT()
    • CAST() e CONVERT() convertono da un tipo di dato a un altro
Funzioni per manipolare i dati in SQL Server

CAST()

CAST(expression AS data_type [(length)])  
SELECT 
     CAST(3.14 AS int) AS DECIMAL_TO_INT,
     CAST('3.14' AS decimal(3,2)) AS STRING_TO_DECIMAL,
     CAST(GETDATE() AS nvarchar(20)) AS DATE_TO_STRING,
     CAST(GETDATE() AS float) AS DATE_TO_FLOAT;
| DECIMAL_TO_INT | STRING_TO_DECIMAL | DATE_TO_STRING     | DATE_TO_FLOAT    |
|----------------|-------------------|--------------------|------------------|
| 3              | 3.14              | Apr 11 2019 1:01PM | 43531.7052687886 |
Funzioni per manipolare i dati in SQL Server

CONVERT()

CONVERT(data_type [(length)], expression [,style])  
SELECT 
     CONVERT(int, 3.14) AS DECIMAL_TO_INT,
     CONVERT(decimal(3,2), '3.14') AS STRING_TO_DECIMAL,
     CONVERT(nvarchar(20), GETDATE(), 104) AS DATE_TO_STRING,
     CONVERT(float, GETDATE()) AS DATE_TO_FLOAT;
| DECIMAL_TO_INT | STRING_TO_DECIMAL | DATE_TO_STRING | DATE_TO_FLOAT    |
|----------------|-------------------|----------------|------------------|
| 3              | 3.14              | 11.04.2019     | 43531.7052687886 |
Funzioni per manipolare i dati in SQL Server

CAST() vs. CONVERT()

  • CAST() è standard SQL, CONVERT() è specifico di SQL Server
  • CAST() è disponibile nella maggior parte dei database
  • CONVERT() è leggermente più performante in SQL Server
Funzioni per manipolare i dati in SQL Server

Passiamo alla pratica!

Funzioni per manipolare i dati in SQL Server

Preparing Video For Download...