मुख्य सामग्री पर जाएं
eLearner.app
मॉड्यूल 6 · पाठ 4 का 4पाठ्यक्रम में 24/57~10 min
मॉड्यूल पाठ (4/4)

CAST और प्रकार रूपांतरण

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

व्यायाम#sql.m6.l4.e1
प्रयास: 0लोड हो रहा है...

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

संपादक लोड हो रहा है...
संकेत दिखाएँ

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

3 प्रयासों के बाद समाधान उपलब्ध है

Review exercise

व्यायाम#sql.m6.l4.e2
प्रयास: 0लोड हो रहा है...

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

संपादक लोड हो रहा है...
संकेत दिखाएँ

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

3 प्रयासों के बाद समाधान उपलब्ध है