SQL Data Types define the type of value that can be stored in a table column. For example, if we want a column to store only integer values, then we can define it’s data type as
Table of Contents
SQL Data Types
SQL data types can be broadly divided into following categories.
- Numeric data types such as int, tinyint, bigint, float, real etc.
- Date and Time data types such as Date, Time, Datetime etc.
- Character and String data types such as char, varchar, text etc.
- Unicode character string data types, for example nchar, nvarchar, ntext etc.
- Binary data types such as binary, varbinary etc.
- Miscellaneous data types – clob, blob, xml, cursor, table etc.
SQL Data Types important points
- Not all data types are supported by every relational database vendors. For example, Oracle database doesn’t support DATETIME and MySQL doesn’t support CLOB data type. So while designing database schema and writing sql queries, make sure to check if the data types are supported or not.
- Data types listed here doesn’t include all the data types, these are the most popularly used data types. Some relational database vendors have their own data types that might be not listed here. For example, Microsoft SQL Server has
smallmoneydata types but since it’s not supported by other popular database vendors, it’s not listed here.
- Every relational database vendor has it’s own maximum size limit for different data types, you don’t need to remember the limit. Idea is to have the knowledge of what data type to be used in a specific scenario.
Let’s look into different categories of sql data types in detail.
SQL Numeric Data Types
|bigint||-9,223,372,036, 854,775,808||9,223,372,036, 854,775,807|
|decimal||-10^38 +1||10^38 -1|
|numeric||-10^38 +1||10^38 -1|
|float||-1.79E + 308||1.79E + 308|
|real||-3.40E + 38||3.40E + 38|
SQL Date and Time Data Types
|DATE||Stores date in the format YYYY-MM-DD|
|TIME||Stores time in the format HH:MI:SS|
|DATETIME||Stores date and time information in the format YYYY-MM-DD HH:MI:SS|
|TIMESTAMP||Stores number of seconds passed since the Unix epoch (‘1970-01-01 00:00:00’ UTC)|
|YEAR||Stores year in 2 digit or 4 digit format. Range 1901 to 2155 in 4-digit format. Range 70 to 69, representing 1970 to 2069.|
SQL Character and String Data Types
|CHAR||Fixed length with maximum length of 8,000 characters|
|VARCHAR||Variable length storage with maximum length of 8,000 characters|
|VARCHAR(max)||Variable length storage with provided max characters, not supported in MySQL|
|TEXT||Variable length storage with maximum size of 2GB data|
Note that all the above data types are for character stream, they should not be used with unicode data.
SQL Unicode Character and String Data Types
|NCHAR||Fixed length with maximum length of 4,000 characters|
|NVARCHAR||Variable length storage with maximum length of 4,000 characters|
|NVARCHAR(max)||Variable length storage with provided max characters|
|NTEXT||Variable length storage with maximum size of 1GB data|
Note that above data types are not supported in MySQL database.
SQL Binary Data Types
|BINARY||Fixed length with maximum length of 8,000 bytes|
|VARBINARY||Variable length storage with maximum length of 8,000 bytes|
|VARBINARY(max)||Variable length storage with provided max bytes|
|IMAGE||Variable length storage with maximum size of 2GB binary data|
SQL Miscellaneous Data Types
|CLOB||Character large objets that can hold up to 2GB|
|BLOB||For binary large objects|
|XML||for storing xml data|
|JSON||for storing JSON data|
That’s all for a quick roundup on SQL data types.