跳转到主要内容
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 次尝试后可用的解决方案