1. mysql的数据类型
在mysql中有如下几种数据类型:
(1)数值型
数值前可放一个负号“-”以表示负值。
(2)字符(串)型
(3)日期和时间型
日期和时间是一些诸如“2006-07-12”或“12:30:43”这样的值。mysql还支持日期/时间的组合,如“2006-07-12 12:30:43”。
(4)null值
null表示未知值,与空“”不一样。
2. mysql的列(字段)类型
数据库中的每个表都是由一个或多个列(字段)构成的。在用create table语句创建一个表时,要为每列(字段)指定一个类型。列(字段)的类型比数据类型更为细化,它精确地描述了给定表列(字段)可能包含的值的种类,如是否带小数、是否文字很多。
2.1数值列类型
mysql有整数和浮点数值的列类型,如表1所示。整数列类型可以有符号也可无符号。有一种特殊的属性允许整数列值自动生成,这对需要唯一序列或标识号的应用系统来说是非常有用的。
数据库中的每个表都是由一个或多个列(字段)构成的。在用create table语句创建一个表时,要为每列(字段)指定一个类型。列(字段)的类型比数据类型更为细化,它精确地描述了给定表列(字段)可能包含的值的种类,如是否带小数、是否文字很多。
2.1数值列类型
mysql有整数和浮点数值的列类型,如表1所示。整数列类型可以有符号也可无符号。有一种特殊的属性允许整数列值自动生成,这对需要唯一序列或标识号的应用系统来说是非常有用的。
类型
|
说明
|
tinyint | 非常小的整数 |
smallint | 较小整数 |
mediumint | 中等大小整数 |
int | 标准整数 |
bigint | 较大整数 |
float | 单精度浮点数 |
double | 双精度浮点数 |
decimal | 一个串的浮点数 |
表1:数值列类型
类型说明
|
取值范围
|
tinyint[(m)] | 有符号值:-128 到127(- 27 到27 - 1) 无符号值:0到255(0 到28 - 1) |
smallint[(m)] | 有符号值:-32768 到32767(- 215 到215 - 1) 无符号值:0到65535(0 到216 - 1) |
mediumint[(m)] | 有符号值:-8388608 到8388607(- 223 到223 - 1 ) 无符号值:0到16777215(0 到224 - 1) |
int[(m)] | 有符号值:-2147683648 到2147683647(- 231 到231- 1) 无符号值:0到4294967295(0 到232 - 1) |
bigint[(m)] | 有符号值:-9223372036854775808 到9223373036854775807(- 263到263-1) 无符号值:0到18446744073709551615(0到264 – 1) |
float[(m, d)] | 最小非零值:±1.175494351e - 38 |
double[(m,d)] | 最小非零值:±2.2250738585072014e - 308 |
decimal (m, d) | 可变;其值的范围依赖于m 和d |
表2:数值列类型的取值范围
类型说明
|
存储需求
|
tinyint[(m)] | 1字节 |
smallint[(m)] | 2字节 |
mediumint[(m)] | 3字节 |
int[(m)] | 4字节 |
bigint[(m)] | 8字节 |
float[(m, d)] | 4字节 |
double[(m, d)] | 8字节 |
decimal (m, d) | m字节(mysql < 3.23),m+2字节(mysql > 3.23 ) |
表3:数值列类型的存储需求
mysql提供了五种整型: tinyint、smallint、mediumint、int和bigint。int为integer的缩写。这些类型在可表示的取值范围上是不同的。整数列可定义为unsigned从而禁用负值;这使列的取值范围为0以上。各种类型的存储量需求也是不同的。取值范围较大的类型所需的存储量较大。
mysql 提供三种浮点类型: float、double和decimal。与整型不同,浮点类型不能是unsigned的,其取值范围也与整型不同,这种不同不仅在于这些类型有最大值,而且还有最小非零值。最小值提供了相应类型精度的一种度量,这对于记录科学数据来说是非常重要的(当然,也有负的最大和最小值)。
在选择了某种数值类型时,应该考虑所要表示的值的范围,只需选择能覆盖要取值的范围的最小类型即可。选择较大类型会对空间造成浪费,使表不必要地增大,处理起来没有选择较小类型那样有效。
mysql 提供三种浮点类型: float、double和decimal。与整型不同,浮点类型不能是unsigned的,其取值范围也与整型不同,这种不同不仅在于这些类型有最大值,而且还有最小非零值。最小值提供了相应类型精度的一种度量,这对于记录科学数据来说是非常重要的(当然,也有负的最大和最小值)。
在选择了某种数值类型时,应该考虑所要表示的值的范围,只需选择能覆盖要取值的范围的最小类型即可。选择较大类型会对空间造成浪费,使表不必要地增大,处理起来没有选择较小类型那样有效。
对于整型值,如果数据取值范围较小,如人员年龄或兄弟姐妹数,则tinyint最合适。mediumint能够表示数百万的值并且可用于更多类型的值,但存储代价较大。bigint在全部整型中取值范围最大,而且需要的存储空间是表示范围次大的整型int类型的两倍,因此只在确实需要时才用。对于浮点值,double占用float的两倍空间。除非特别需要高精度或范围极大的值,一般应使用只用一半存储代价的float型来表示数据。
在定义整型列时,可以指定可选的显示尺寸m。如果这样,m应该是一个1 到255的整数。它表示用来显示列中值的字符数。例如,mediumint(4)指定了一个具有4个字符显示宽度的mediumint列。如果定义了一个没有明确宽度的整数列,将会自动分配给它一个缺省的宽度。缺省值为每种类型的“最长”值的长度。如果某个特定值的可打印表示需要不止m个字符,则显示完全的值;不会将值截断以适合m个字符。
对每种浮点类型,可指定一个最大的显示尺寸m 和小数位数d。m 的值应该取1 到255。d的值可为0 到3 0,但是不应大于m - 2(如果熟悉odbc 术语,就会知道m 和d 对应于odbc 概念的“精度”和“小数点位数”)。m和d对float和double 都是可选的,但对于decimal是必须的。在选项m 和d时,如果省略了它们,则使用缺省值。
在定义整型列时,可以指定可选的显示尺寸m。如果这样,m应该是一个1 到255的整数。它表示用来显示列中值的字符数。例如,mediumint(4)指定了一个具有4个字符显示宽度的mediumint列。如果定义了一个没有明确宽度的整数列,将会自动分配给它一个缺省的宽度。缺省值为每种类型的“最长”值的长度。如果某个特定值的可打印表示需要不止m个字符,则显示完全的值;不会将值截断以适合m个字符。
对每种浮点类型,可指定一个最大的显示尺寸m 和小数位数d。m 的值应该取1 到255。d的值可为0 到3 0,但是不应大于m - 2(如果熟悉odbc 术语,就会知道m 和d 对应于odbc 概念的“精度”和“小数点位数”)。m和d对float和double 都是可选的,但对于decimal是必须的。在选项m 和d时,如果省略了它们,则使用缺省值。
2.2字符串列类型
类型名
|
说明
|
char | 定长字符串 |
varchar | 可变长字符串 |
tinyblob | 非常小的blob(二进制大对象) |
blob | 小blob |
mediumblob | 中等的blob |
longblob | 大blob |
tinytext | 非常小的文本串 |
text | 小文本串 |
mediumtext | 中等文本串 |
longtext | 大文本串 |
enum | 枚举;列可赋予某个枚举成员 |
set | 集合;列可赋予多个集合成员 |
表4:字符串列类型
类型说明
|
最大尺寸
|
存储需求
|
char( m) | m 字节 | m 字节 |
varchar(m) | m 字节 | l + 1字节 |
tinyblob, tinytext | 28- 1字节 | l + 1字节 |
blob, text | 216 - 1 字节 | l + 2字节 |
mediumblob, mediumtext | 224- 1字节 | l + 3字节 |
longblob, longtext | 232- 1字节 | l + 4字节 |
enum(“value1”, “value2”, ...) | 65535 个成员 | 1 或2字节 |
set (“value1”, “value2”, ...) | 64个成员 | 1、2、3、4 或8字节 |
表5:串列类型最大尺寸及存储需求
l 以外所需的额外字节为存放该值的长度所需的字节数。mysql通过存储值的内容及其长度来处理可变长度的值。这些额外的字节是无符号整数。请注意,可变长类型的最大长度、此类型所需的额外字节数以及占用相同字节数的无符号整数之间的对应关系。例如,mediumblob 值可能最多224 - 1字节长并需要3 个字节记录其结果。3 个字节的整数类型mediumint 的最大无符号值为224 - 1。
2.3日期时间列类型
mysql 提供了几种时间值的列类型,它们分别是: date、datetime、time、timestamp和year。下表给出了mysql为定义存储日期和时间值所提供的这些类型,并给出了每种类型的合法取值范围。
mysql 提供了几种时间值的列类型,它们分别是: date、datetime、time、timestamp和year。下表给出了mysql为定义存储日期和时间值所提供的这些类型,并给出了每种类型的合法取值范围。
类型名
|
说明
|
date | “yyyy-mm-dd”格式表示的日期值 |
time | “hh:mm:ss”格式表示的时间值 |
datetime | “yyyy-mm-dd hh:mm:ss”格式 |
timestamp | “yyyymmddhhmmss”格式表示的时间戳值 |
year | “yyyy”格式的年份值 |
表6:日期时间列类型
类型名
|
取值范围
|
存储需求
|
date | “1000-01-01”到“9999-12-31” | 3字节 |
time | “-838:59:59”到“838:59:59” | 3字节 |
datetime | “1000-01-01 00:00:00” 到“9999-12-31 23:59:59” | 8字节 |
timestamp | 19700101000000 到2037 年的某个时刻 | 4字节 |
year | 1901 到2155 | 1字节 |
表7: 日前时间列类型的取值范围和存储需求
对于数据类型,在确定可能范围的情况下尽量选用较小的类型。对于主键和索引,最好选用int型,可以减小索引的大小;对于包含text和blob的表,肯定会保存在磁盘,相对于内存操作,到磁盘读取数据的效率也会非常低。
博客原载:http://blog.youkuaiyun.com/xifeijian/article/details/20409233