Skip to main content
eLearner.app
Module 6 · Lesson 4 of 424/57 in the course~10 min
Module lessons (4/4)

CAST and type conversions

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

Exercise#sql.m6.l4.e1
Attempts: 0Loading…

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

Loading editor…
Show hint

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

Solution available after 3 attempts

Review exercise

Exercise#sql.m6.l4.e2
Attempts: 0Loading…

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

Loading editor…
Show hint

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

Solution available after 3 attempts