Data Types in SQL
Learn about different data types available in SQL, how to use them, and some examples.
What are data types?
Data types are classifications that define the kind of value a field (or column) can contain within a table in a database. It defines the type of data the field can hold, such as integer data, character data, monetary data, date and time data, binary strings, and so on.
Data types are important because they:
Ensure that the data entered into fields is valid for the type of data the field intends to hold.
Help maintain data integrity.
Help improve the performance of the database when working with large sets of data.
Data types in PostgreSQL
PostgreSQL has a large number of different data types available for use.
A list of some of the most common data types is given below:
Boolean
The boolean data type can store two values: True
or False
. There’s also a third Unknown
state, which is represented by Null
. It’s used for storing unknown or non applicable values. The boolean
data type takes one byte of storage. Boolean data types are often used with logical operators such as AND
, OR
, and NOT
.
Character strings
These are collections of alphanumeric characters (letters, numbers, and special characters) and can be of fixed or variable length. Examples of character string data types in PostgreSQL include Char
, Varchar
, and Text
.
Character varying(n)
: Also known asVarchar
, stores variable-length character strings of up ton
characters in length. If no value is specified forn
, the size is unlimited.Character(n)
: It’s similar tocharacter varying
but stores strings of exactlyn
characters in length. If the string is shorter in size thann
characters, it will be padded with spaces to make itn
characters long.Text
: It stores character strings of unlimited length.
Numeric
Numeric data types are used for storing numeric values. They can store whole numbers, decimal numbers, and floating point numbers. This data type is often used for storing financial information or measurements. They can be used in mathematical operators such as +
, -
, *
, and /
.
Numeric data types in PostgreSQL include SmallInt
, Integer
, BigInt
, Decimal
, Numeric
, Real
, Double Precision
, SmallSerial
, Serial
, and BigSerial
.
Smallint
: This data type stores integers (between -32,768 and 32,767). It takes 2 bytes of storage.Integer
: This data type stores whole numbers (between -2,147,483,648 and 2,147,483,647). It takes 4 bytes of storage.BigInt
: This data type stores whole numbers (between -9,223,372,036,854,775,808 and 9,223,372,036,854,775,807). It takes 8 bytes of storage.Decimal
orNumeric
: It stores decimal numbers (numbers with a fractional component). The decimal data type can store up to 131,072 digits before and up to 16,383 digits after the decimal point. TheDecimal
andNumeric
data types are interchangeable, so we can use either when we need to store a numeric value.Real
: It stores floating point numbers (numbers with a fractional component) with an accuracy of 6 decimal places. It takes 4 bytes of storage.Double
: It stores floating point numbers with an accuracy of 15 decimal places. It takes 8 bytes of storage.SmallSerial
: It stores integers (between 1 and 32,767) that are automatically incremented by the database. It takes 2 bytes of storage.Serial
: It stores integers (between 1 and 2,147,483,647) that are automatically incremented by the database. It takes 4 bytes of storage.BigSerial
: It stores integers (between 1 and 9,223,372,036,854,775,807) that are automatically incremented by the database. It takes 8 bytes of storage.
Get hands-on with 1300+ tech skills courses.