The data types of fields in the data table are: TINYINT, SMALLINT, MEDIUMINT, INT, INTEGE, DATETIME, DATE, TIMESTAMP, TIME, YEAR, CHAR, VARCHAR, TEXT, TINYBLOB, BLOB, etc.
#The types of data fields defined in MySQL are very important for the optimization of your database.
MySQL supports multiple types, which can be roughly divided into three categories: numerical, date/time and string (character) types. [Recommended tutorial: "mysql tutorial"]
Numeric type
MySQL supports all standard SQL numeric data types.
These types include strict numeric data types (INTEGER, SMALLINT, DECIMAL, and NUMERIC), and approximate numeric data types (FLOAT, REAL, and DOUBLE PRECISION).
The keyword INT is a synonym for INTEGER, and the keyword DEC is a synonym for DECIMAL.
The BIT data type stores bit field values and supports MyISAM, MEMORY, InnoDB and BDB tables.
As an extension of the SQL standard, MySQL also supports integer types TINYINT, MEDIUMINT and BIGINT. The following table shows the storage and range required for each integer type.
Type | Size | Range (signed) | Range (unsigned) | Use |
---|---|---|---|---|
TINYINT | 1 byte | (-128,127) | (0,255) | Small integer value |
SMALLINT | 2 bytes | (-32 768, 32 767) | (0, 65 535) | Large integer value |
MEDIUMINT | 3 bytes | (-8 388 608, 8 388 607) | (0,16 777 215) | Large integer value |
INT or INTEGER | 4 bytes | ( -2 147 483 648, 2 147 483 647) | (0, 4 294 967 295) | Big integer value |
BIGINT | 8 bytes | (-9,223,372,036,854,775,808, 9 223 372 036 854 775 807) | (0,18 446 744 073 709 551 615) | Maximum integer value |
FLOAT | 4 bytes | (-3.402 823 466 E 38,-1.175 494 351 E-38), 0, (1.175 494 351 E-38, 3.402 823 466 351 E 38) | 0, (1.175 494 351 E-38, 3.402 823 466 E 38) | Single precision Floating point value |
DOUBLE | 8 bytes | (-1.797 693 134 862 315 7 E-308,-2.225 073 858 507 201 4 E-308), 0, ( 2.225 073 858 507 201 4 E-308, 1.797 693 134 862 315 7 E 308) | 0, (2.225 073 858 507 201 4 E-308, 1.797 693 134 862 315 7 E 30 8) | Double precision Floating point value |
For DECIMAL(M,D), if M>D, it is M 2 otherwise it is D 2 | Depends on the value of M and D | Depends on the value of M and D | Decimal value |
Date and time types
The date and time types representing time values are DATETIME, DATE, TIMESTAMP, TIME and YEAR. Each time type has a valid value range and a "zero" value. The "zero" value is used when specifying an illegal value that MySQL cannot represent. TIMESTAMP type has proprietary automatic update features, which will be described later.Size | (bytes) | RangeFormat | Purpose | |
---|---|---|---|---|
3 | 1000-01-01/9999-12-31 | YYYY-MM-DD | Date value | |
3 | '-838:59:59'/'838:59:59' | HH:MM:SS | Time value or duration | |
1 | 1901/2155 | YYYY | Year value | |
8 | 1000-01-01 00:00:00 /9999-12-31 23:59:59 | YYYY-MM-DD HH:MM:SS | Mixed date and time values | |
4 | 1970-01-01 00:00:00/2038The end time is the 2147483647 second, Beijing time 2038-1-19 11:14:07, January 19, 2038 03:14:07 AM GMT | YYYYMMDD HHMMSSMixed date and time value, timestamp |
Type | Size | Use |
---|---|---|
CHAR | 0 -255 bytes | Fixed-length string |
VARCHAR | 0-65535 bytes | Variable-length string |
TINYBLOB | 0-255 bytes | A binary string of no more than 255 characters |
TINYTEXT | 0-255 bytes | Short text string |
BLOB | 0-65 535 bytes | Binary form Long text data |
TEXT | 0-65 535 bytes | Long text data |
MEDIUMBLOB | 0-16 777 215 bytes | Medium-length text data in binary form |
0-16 777 215 bytes | Medium length text data | |
0-4 294 967 295 bytes | Very large text data in binary form | |
0-4 294 967 295 bytes | Very large text data |
The above is the detailed content of What are the data types of fields in mysql data table?. For more information, please follow other related articles on the PHP Chinese website!