w3resource

SQL Data Types

Data Types

A data type is a set of representable values. Every representable value belongs to at least one data type and some belong to several data types. SQL supports three sorts of data types: predefined data types, constructed types, and user-defined types.
Predefined data types are sometimes called the "built-in data types", though not in this International Standard. Every predefined data type is a subtype of itself and of no other data types. It follows that every predefined data type is a supertype of itself and of no other data types.
User-defined data types can be defined by a standard, by an implementation, or by an application.
A constructed type is specified using one of SQL's data type constructors, ARRAY, REF, and ROW. The type is either an array type, a reference type or a row type, according to whether it is specified with ARRAY, REF, or ROW, respectively. Array types are the only examples of constructed types known generically as collection types.

Data types are used within the CREATE TABLE statement as part of column definitions :

CREATE TABLE <tablename>(   
<column_name> <data_type> ... ,   
<column_name> <data_type> ... ,   
... );

What is Unicode?

According to unicode.org "Unicode provides a unique number for every character, no matter what the platform, no matter what the program, no matter what the language. The Unicode Standard has been adopted by such industry leaders as Apple, HP, IBM, JustSystems, Microsoft, Oracle, SAP, Sun, Sybase, Unisys and many others. Unicode is required by modern standards such as XML, Java, ECMAScript (JavaScript), LDAP, CORBA 3.0, WML, etc., and is the official way to implement ISO/IEC 10646. It is supported in many operating systems, all modern browsers, and many other products. The emergence of the Unicode Standard and the availability of tools supporting it are among the most significant recent global software technology trends.
Incorporating Unicode into client-server or multi-tiered applications and websites offers significant cost savings over the use of legacy character sets. Unicode enables a single software product or a single website to be targeted across multiple platforms, languages and countries without re-engineering. It allows data to be transported through many different systems without corruption."

Examples of SQL Data Types:

Literal Examples
Character string '59', 'Python'
Numeric 48, 10.34, 2., .001, -125, +5.33333, 2.5E2, 5E-3
Boolean TRUE, FALSE, UNKNOWN
Datetime DATE, '2016-05-14', TIME '04:12:00',TIMESTAMP ‘2016-05-14 10:23:54’
Interval INTERVAL ‘15-3’ YEAR TO MONTH, INTERVAL ‘23:06:5.5’ HOUR TO SECOND

SQL Data Types : New Features in SQL 2003 standard

  • New data types
    • BIGINT
    • MULTISET
  • Extensions to existing data types
    • Unbounded ARRAY
  • Deletion of existing types
    • BIT
    • BIT VARYING

Here we have discussed SQL 2003 standard data types with a short description and example.

SQL Data Types with example and explanation

Contents:

Character String Types:

A character string data type is described by a character string data type descriptor.

Data Type Description
CHARACTER Character string, fixed length.
A string of text in an implementer-defined format. The size argument is a single nonnegative integer that refers to the maximum length of the string. Values for this type must enclose in single quotes.
CHARACTER VARYING (VARCHAR) Variable length character string, maximum length fixed.
CHARACTER LARGE OBJECT (CLOB) A Character Large OBject (or CLOB) is a collection of character data in a database management system, usually stored in a separate location that is referenced in the table itself.
NATIONAL CHARACTER (NCHAR)
NATIONAL CHARACTER type is the same as CHARACTER except that it holds standardized multibyte characters or Unicode characters.
NATIONAL CHARACTER VARYING (NCHAR VARYING) NATIONAL CHARACTER VARYING type is the same as CHARACTER VARYING except that it holds standardized multibyte characters or Unicode characters.
NATIONAL CHARACTER LARGE OBJECT (NCLOB) NCLOB type is the same as CLOB except that it holds standardized multibyte characters or Unicode characters.

SQL: Fixed-length character string :

SQL Data Type fixed length character string

SQL : Character strings of Varying length

SQL Data Type : Varying length character string

Example : A table with columns of fixed and varying length size strings and a CLOB string

CREATE TABLE test (   
id    DECIMAL PRIMARY KEY,   
col1 CHAR(8),       -- exactly 8 characters   
col2 VARCHAR(100),   -- up to 100 characters   
col3 CLOB            -- very large strings 
);

Explanation:

  • This SQL code creates a new table named "test" in the current schema.

  • The table consists of three columns: id, col1, col2, and col3.

  • Here's a breakdown of the table structure and column specifications:

    • id: This column is of the DECIMAL data type and is designated as the PRIMARY KEY for the table. The PRIMARY KEY constraint ensures that each value in the column is unique and not null.

    • col1: This column is of the CHAR data type with a length of 8 characters. CHAR columns store fixed-length character strings, padding shorter strings with spaces if necessary to meet the specified length.

    • col2: This column is of the VARCHAR data type with a maximum length of 100 characters. VARCHAR columns store variable-length character strings, allowing storage of up to 100 characters.

    • col3: This column is of the CLOB (Character Large Object) data type. CLOB columns are used to store very large strings, typically exceeding the maximum length allowed by VARCHAR.

DBMS Character String Types:

DBMS and version Types
MySQL 5.7 CHAR, VARCHAR, BINARY, VARBINARY, BLOB, TEXT, ENUM, and SET
PostgreSQL 9.5.3 CHARACTER VARYING(n), VARCHAR(n), CHARACTER(n), CHAR(n), TEXT
SQL Server CHAR, VARCHAR, TEXT, NCHAR, NVARCHAR, NTEXT
Oracle 11g CHAR, VARCHAR2, VARCHAR, NCHAR, NVARCHAR2, CLOB, NCLOB, LONG

Boolean Type:

The data type boolean comprises the distinct truth values true and false .The boolean data type also supports the unknown truth value as the null value unless prohibited by a NOT NULL constraint.

Data Type Description
BOOLEAN Stores truth values - either TRUE or FALSE.

Example : A table using boolean type


-- Creating a new table named "test" in the current schema
CREATE TABLE test (
    -- Defining a column named "id" of the DECIMAL data type, designated as the PRIMARY KEY
    id DECIMAL PRIMARY KEY,
    -- Defining a column named "col1" of the BOOLEAN data type
    col1 BOOLEAN
);

Explanation:

  • This SQL code creates a new table named "test" in the current schema.

  • The table consists of two columns: id and col1.

  • Here's a breakdown of the table structure and column specifications:

    • id: This column is of the DECIMAL data type. DECIMAL is used for numeric data with a fixed precision and scale. It is designated as the PRIMARY KEY for the table, implying that each value in this column must be unique and not null.

    • col1: This column is of the BOOLEAN data type. BOOLEAN columns store true/false or 1/0 values, representing logical values.

DBMS Boolean Types:

DBMS and version Types
MySQL 5.7 TINYINT(1)
PostgreSQL 9.5 BOOLEAN
SQL Server 2014 BIT
Oracle 11g BOOLEAN

Binary large object Type:

A binary string is a sequence of octets that does not have either a character set or collation associated with it and is described by a binary data type descriptor.

Data Type Description
BINARY LARGE OBJECT (BLOB). BLOB stores a long sequence of bytes.

Example : A table with columns of fixed and variable size binary data and a BLOB


-- Creating a new table named "test" in the current schema
CREATE TABLE test (
    -- Defining a column named "id" of the DECIMAL data type, designated as the PRIMARY KEY
    id DECIMAL PRIMARY KEY,
    -- Defining a column named "col1" of the BINARY data type with a fixed length of 8 bytes
    col1 BINARY(8),
    -- Defining a column named "col2" of the VARBINARY data type with a maximum length of 140 bytes
    col2 VARBINARY(140),
    -- Defining a column named "col3" of the BLOB data type, which can store very large binary data such as pictures or sounds
    col3 BLOB
);

Explanation:

  • This SQL code creates a new table named "test" in the current schema.

  • The table consists of four columns: id, col1, col2, and col3.

  • Here's a breakdown of the table structure and column specifications:

    • id: This column is of the DECIMAL data type. DECIMAL is used for numeric data with a fixed precision and scale. It is designated as the PRIMARY KEY for the table, implying that each value in this column must be unique and not null.

    • col1: This column is of the BINARY data type with a fixed length of 8 bytes. BINARY columns store fixed-length binary data, suitable for storing byte sequences.

    • col2: This column is of the VARBINARY data type with a maximum length of 140 bytes. VARBINARY columns store variable-length binary data, allowing storage of up to 140 bytes.

    • col3: This column is of the BLOB (Binary Large Object) data type. BLOB columns are used to store very large binary data, such as pictures or sounds. They can hold large amounts of data, limited only by the database's storage capacity.

DBMS Binary Types:

DBMS and version Types
MySQL 5.7 TINYBLOB, BLOB, MEDIUMBLOB, LONGBLOB
PostgreSQL 9.5 BYTEA
SQL Server 2014 BLOB
Oracle 11g LOB

Numeric Types:

Numeric data types represent numerical values.

Data Type Description
INTEGER Represents an integer. The minimum and maximum values depend on the DBMS.
SMALLINT Same as INTEGER type except that it might hold a smaller range of values, depending on the DBMS.
BIGINT Same as INTEGER type except that it might hold a larger range of values, depending on the DBMS.
DECIMAL(p, s) Exact numerical, precision p, scale s. A decimal number, that is a number that can have a decimal point in it. The size argument has two parts : precision and scale. The scale can not exceed the precision. Precision comes first, and a comma must separate from the scale argument.
NUMERIC(p, s) Exact numerical, precision p, scale s. The maximum precision depends on the DBMS.
FLOAT(p) Approximate numerical, mantissa precision p. Precision is greater than or equal to 1 and the maximum precision depends on the DBMS.
REAL Same as FLOAT type except that the DBMS defines the precision.
DOUBLE PRECISION Same as FLOAT type (DBMS defines the precision) but greater than that of REAL.

Example : Precision and Scale Examples for 235.89

SQL DATA TYPE Numeric precision and scale

Example : A table using numeric data types


-- Creating a new table named "test" in the current schema
CREATE TABLE test (
    -- Defining a column named "id" of the DECIMAL data type, designated as the PRIMARY KEY
    id DECIMAL PRIMARY KEY,
    -- Defining a column named "name" of the VARCHAR data type with a maximum length of 100 characters
    name VARCHAR(100),
    -- Defining a column named "col1" of the DECIMAL data type with 5 total digits, 2 of which are after the decimal point
    col1 DECIMAL(5,2),
    -- Defining a column named "col2" of the SMALLINT data type
    col2 SMALLINT,
    -- Defining a column named "col3" of the INTEGER data type
    col3 INTEGER,
    -- Defining a column named "col4" of the BIGINT data type
    col4 BIGINT,
    -- Defining a column named "col5" of the FLOAT data type with at least 2 digits after the decimal point
    col5 FLOAT(2),
    -- Defining a column named "col6" of the REAL data type
    col6 REAL,
    -- Defining a column named "col7" of the DOUBLE PRECISION data type
    col7 DOUBLE PRECISION
);

Explanation:

  • This SQL code creates a new table named "test" in the current schema.

  • The table consists of multiple columns with different data types and specifications.

  • Here's a breakdown of the table structure and column specifications:

    • id: This column is of the DECIMAL data type and serves as the primary key for the table.

    • name: This column is of the VARCHAR data type with a maximum length of 100 characters, suitable for storing textual data.

    • col1: This column is of the DECIMAL data type with 5 total digits, 2 of which are after the decimal point, allowing for precise numeric data storage.

    • col2: This column is of the SMALLINT data type, suitable for storing small integer values without decimal points.

    • col3: This column is of the INTEGER data type, suitable for storing integer values without decimal points.

    • col4: This column is of the BIGINT data type, suitable for storing large integer values without decimal points.

    • col5: This column is of the FLOAT data type with at least 2 digits after the decimal point, suitable for storing floating-point numeric data with varying precision.

    • col6: This column is of the REAL data type, suitable for storing single-precision floating-point numeric data.

    • col7: This column is of the DOUBLE PRECISION data type, suitable for storing double-precision floating-point numeric data.

DBMS Numeric Types:

DBMS and version Types
MySQL 5.7 INTEGER(TINYINT, SMALLINT, MEDIUMINT, INT BIGINT, INTEGER)
FIXED-POINT(DECIMAL, NUMERIC)
FLOATING-POINT(FLOAT, DOUBLE)
BIT-VALUE(BIT),
PostgreSQL 9.5.3 SMALLINT, INTEGER, BIGINT, DECIMAL, NUMERIC, REAL, DOUBLE PRECISION, SMALLSERIAL, SERIAL, BIGSERIAL
SQL Server 2014 EXACT NUMERICS(BIGINT, BIT, DECIMAL, INT, MONEY, NUMERIC, SMALLINT, SMALLMONEY, TINYINT)
APPROXIMATE NUMERICS(FLOAT, REAL )
Oracle 11g NUMBER
FLOATING-POINT(BINARY_FLOAT, BINARY_DOUBLE)

Datetime Types:

The datetime data types represent the date and time of day.

Data Type Description
DATE Represents a date. Format : yyyy-mm-dd
TIME WITHOUT TIME ZONE Represents a time of day without time zone. Format : hh:mm:ss
TIME WITH TIME ZONE Represents a time of day with time zone. Format : yyyy-mm-dd AT TIME ZONE -06:00.
TIMESTAMP WITHOUT TIME ZONE Represents a combination of DATE and TIME values separated by a space. Format : yyyy-mm-dd hh:mm:ss
TIMESTAMP WITH TIME ZONE Represents a combination of DATE and TIME values separated by a space with time zone. Format : yyyy-mm-dd hh:mm:ss AT TIME ZONE -06:00.

Example : A table using Datetime data types


-- Creating a new table named "test" in the current schema
CREATE TABLE test (
    -- Defining a column named "id" of the DECIMAL data type, designated as the PRIMARY KEY
    id DECIMAL PRIMARY KEY,
    -- Defining a column named "col1" of the DATE data type, capable of storing year, month, and day
    col1 DATE,
    -- Defining a column named "col2" of the TIME data type, capable of storing time without a date component
    col2 TIME,
    -- Defining a column named "col3" of the TIMESTAMP data type with precision of 9 digits after the decimal point for seconds
    col3 TIMESTAMP(9),
    -- Defining a column named "col4" of the TIMESTAMP WITH TIME ZONE data type, which includes timezone information
    col4 TIMESTAMP WITH TIME ZONE
);

Explanation:

  • This SQL code creates a new table named "test" in the current schema.

  • The table consists of multiple columns with different data types related to date and time.

  • Here's a breakdown of the table structure and column specifications:

    • id: This column is of the DECIMAL data type and serves as the primary key for the table.

    • col1: This column is of the DATE data type, capable of storing year, month, and day information without any time component.

    • col2: This column is of the TIME data type, capable of storing time information without any date component.

    • col3: This column is of the TIMESTAMP data type with a precision of 9 digits after the decimal point for seconds, capable of storing date and time information with high precision.

    • col4: This column is of the TIMESTAMP WITH TIME ZONE data type, capable of storing date and time information along with the name of a timezone, allowing for accurate representation of time in different time zones.

DBMS Date and Time Types:

DBMS and version Types
MySQL 5.7 DATE, TIME, DATETIME, TIMESTAMP, YEAR
PostgreSQL 9.5.3 TIMESTAMP [ WITHOUT TIME ZONE ], TIMESTAMP WITH TIME ZONE, DATE, TIME[ WITHOUT TIME ZONE ], TIME WITH TIME ZONE,
SQL Server DATE, DATETIME2, DATETIME, DATETIMEOFFSET, SMALLDATETIME, TIME
Oracle 11g DATE, TIMESTAMP, TIMESTAMP WITH TIME ZONE, TIMESTAMP WITH LOCAL TIME ZONE

Interval Type:

It stores the quantity of time between two datetime values. For example between 10:00 and 12:30 is an interval of 02:30 (2 hours and 30 minutes). There are two classes of intervals. The first one called year-month intervals, includes no fields other than YEAR and MONTH, though not both are required. The other class called day-time intervals that can include any fields other than YEAR or MONTH.

Data Type Description
Year-month Includes no fields other than YEAR and MONTH, though not both are required.
Day-time Includes any fields other than YEAR or MONTH. These intervals can contain a day value, hour value, minute value, second value, or some combination thereof.

Fields in Year-month INTERVAL values:

Keyword Meaning
YEAR years
MONTH months

Fields in day-time INTERVAL values:

Keyword Meaning
DAY Days
HOUR Hours
MINUTE Minutes
SECOND Seconds and possibly fractions of a second

Valid values for fields in INTERVAL values:

Keyword Valid values of INTERVAL fields
YEAR Unconstrained except by <interval leading field precision>
MONTH Months (within years) (0-11)
DAY Unconstrained except by <interval leading field precision>
HOUR Hours (within days) (0-23)
MINUTE Minutes (within hours) (0-59)
SECOND Seconds (within minutes) (0-59.999...)

Valid operators involving datetimes and intervals:

Operand1 Operator Operand2 Result Type
Datetime - Datetime Interval
Datetime + or - Interval Datetime
Interval + Datetime Datetime
Interval + or - Interval Interval
Interval * or / Numeric Interval
Numeric * Interval Interval

Example : A table using Interval data types


-- Creating a new table named "test" in the current schema
CREATE TABLE test (
    -- Defining a column named "id" of the DECIMAL data type, designated as the PRIMARY KEY
    id DECIMAL PRIMARY KEY,
    -- Defining a column named "col1" of the INTERVAL YEAR TO MONTH data type, capable of storing intervals in terms of years and months
    col1 INTERVAL YEAR TO MONTH,
    -- Defining a column named "col2" of the INTERVAL DAY TO SECOND data type with precision of 6 digits after the decimal point for seconds
    col2 INTERVAL DAY TO SECOND(6)
);

Explanation:

  • This SQL code creates a new table named "test" in the current schema.

  • The table consists of multiple columns with different data types related to intervals.

  • Here's a breakdown of the table structure and column specifications:

    • id: This column is of the DECIMAL data type and serves as the primary key for the table.

    • col1: This column is of the INTERVAL YEAR TO MONTH data type, capable of storing intervals in terms of years and months, without specifying any specific date or time.

    • col2: This column is of the INTERVAL DAY TO SECOND data type with a precision of 6 digits after the decimal point for seconds, capable of storing intervals in terms of days, hours, minutes, and seconds, with fractional seconds included.

DBMS Interval Types:

DBMS and version Types
MySQL 5.7 NOT SUPPORTED
PostgreSQL 9.5 INTERVAL
SQL Server 2014 NOT SUPPORTED
Oracle 11g INTERVAL YEAR TO MONTH
INTERVAL DAY TO SECOND

XML Types2

XML Stores XML data. It can be used wherever a SQL datatype is allowed, such as a column of a table.

Example : A table using XML data type


-- Creating a new table named "test" in the current schema
CREATE TABLE test (
    -- Defining a column named "id" of the DECIMAL data type, designated as the PRIMARY KEY
    id DECIMAL PRIMARY KEY,
    -- Defining a column named "col1" of the XML data type
    col1 XML
);

Explanation:

  • This SQL code creates a new table named "test" in the current schema.

  • The table consists of two columns: id and col1.

  • Here's a breakdown of the table structure and column specifications:

    • id: This column is of the DECIMAL data type and serves as the primary key for the table.

    • col1: This column is of the XML data type, designed for storing XML data.

Collection Types:

COLLECTION
( ARRAY, MULTISET )
ARRAY(offered in SQL99) is a set-length and ordered a collection of elements, MULTISET (added in SQL2003) is a variable-length and unordered collection of elements. Both the elements must be of a predefined datatype.

Check out our 1000+ SQL Exercises with solution and explanation to improve your skills.

Previous:SQL Home
Next: SQL Syntax



Follow us on Facebook and Twitter for latest update.