Pular para o conteúdo principal
eLearner.app
Módulo 6 · Lição 4 de 424/57 no curso~10 min
Lições do módulo (4/4)

CAST e conversões de tipo

SQL is strongly typed: every column has a type (INTEGER, TEXT, NUMERIC, DATE, TIMESTAMP…), and many operations require the types to match. When they don't — or when you want to format a value differently — you use a cast.

Two equivalent syntaxes

SQL
-- SQL standard:
CAST(123 AS TEXT)

-- PostgreSQL shorthand (più comune nella pratica):
123::text

The two forms are identical. The shorthand ::type is more compact and chains nicely with other expressions:

SQL
SELECT ordered_at::date AS day,
       (oi.quantity * oi.unit_price)::numeric(10,2) AS total,
       id::text || ' - ' || email AS label
FROM   …;

Useful casts on the dataset

SQL
TIMESTAMPDATE          ordered_at::date
NUMERICINTEGER       price::int           -- tronca!
INTEGERNUMERIC       quantity::numeric    -- per evitare div. intera
INTEGERTEXT          id::text             -- per concatenare con ||
TEXTDATE          '2024-03-05'::date
NUMERICTEXT          price::text          -- per LIKE su numeri

When a cast can fail

SQL
SELECT 'abc'::int;   -- ERRORE: invalid input syntax for type integer
SELECT '12.5'::int;  -- ERRORE: invalid input syntax for type integer
SELECT 12.5::int;    -- 12   (cast numerico-numerico: arrotonda)

Casts from string → number or string → date are the riskiest: they raise an error if the string does not exactly match the expected format. In production, on external data, it is best to validate first with TRIM / LOWER / regex.

Cast and ORDER BY

A case that generates subtle bugs: sorting numbers stored as text.

SQL
SELECT '2', '10', '1' ORDER BY 1;  -- '1', '10', '2'   (alfabetico!)

Solution: cast inside ORDER BY:

SQL
SELECT code FROM articles ORDER BY code::int;

Try it

Exercício#sql.m6.l4.e1
Tentativas: 0Carregando…

For each order, show id and day (only the date part of ordered_at, of type date). Two columns. Order by id.

Carregando editor…
Mostrar dica

The TIMESTAMP → DATE cast drops the time: ordered_at::date.

Solução disponível após 3 tentativas

Review exercise

Exercício#sql.m6.l4.e2
Tentativas: 0Carregando…

For each customer show a label column that concatenates id and email separated by ' - ' (e.g. '1 - alice.rossi@example.com'). Order by id.

Carregando editor…
Mostrar dica

The || operator requires operands of the same type: casting id to text is the cleanest way.

Solução disponível após 3 tentativas