你是不是暗恋我,那就给我发个消息呀,让我知道o(∩∩)o
分类: Mysql/postgreSQL
2014-09-05 10:07:03
http://www.cnblogs.com/zeroone/archive/2011/12/23/2298921.html
1. MySQL的数据类型
在mysql中有如下几种数据类型:
数值是诸如32 或153.4 这样的值。mysql 支持科学表示法,科学表示法由整数或浮点数后跟“e”或“e”、一个符号(“+”或“-”)和一个 整数指数来表示。1.24e+12 和23.47e-1 都是合法的科学表示法表示的数。而1.24e12 不是合法的,因为指数前的符号未给出。
浮点数由整数部分、一个小数点和小数部分组成。整数部分和小数部分可以分别为空,但不能同时为空。
数值前可放一个负号“-”以表示负值。
字符型(也叫字符串型,简称串)是诸如“hello, world!”或“一个馒头引起的血案”这样的值,或者是电话号码87398413这样的值。既可用单引号也可用双引号将串值括起来。
初学者往往分不清数值87398143和字符串87398143的区别。都是数字啊,怎么一个要用数值型,一个要用字符型呢?关键就在于:数值型的 87398143是要参与计算的,比如它是金融中的一个货款总额;而字符型的87398143是不参与计算的,只是表示电话号码,这样的还有街道号码、门 牌号码等等,它们都不参与计算。
日期和时间是一些诸如“2006-07-12”或“12:30:43”这样的值。mysql还支持日期/时间的组合,如“2006-07-12 12:30:43”。
null表示未知值。比如填写表格中通讯地址不清楚留空不填写,这就是null值。
我们用create table语句创建一个表(参看前面的章节),这个表中包含列的定义。例如我们在前面创建了一个joke表,这个表中有content和writer两个列:
create table |
col_name col_typy [col_attributes] [general_attributes] |
其中列名由col_name 给出。列名可最多包含64个字符,字符包括字母、数字、下划线及美元符号。列名可以名字中合法的任何符号(包括数字)开头。 但列名不能完全由数字组成,因为那样可能使其与数据分不开。mysql保留诸如select、delete和create这样的词,这些词不能用做列名, 但是函数名(如pos 和min)是可以使用的。
列类型col_type表示列可存储的特定值。列类型说明符还能表示存放在列中的值的最大长度。对于某些类型,可用一个数值明确地说明其长度。而另外一些 值,其长度由类型名蕴含。例如,char(10) 明确指定了10个字符的长度,而tinyblob值隐含最大长度为255个字符。有的类型说明符允许指 定最大的显示宽度(即显示值时使用多少个字符)。浮点类型允许指定小数位数,所以能控制浮点数的精度值为多少。
可以在列类型之后指定可选的类型说明属性,以及指定更多的常见属性。属性起修饰类型的作用,并更改其处理列值的方式,属性有以下类型:
如果想给出多个列的专用属性,可按任意顺序指定它们,只要它们跟在列类型之后、通用属性之前即可。类似地,如果需要给出多个通用属性,也可按任意顺序给出它们,只要将它们放在列类型和可能给出的列专用属性之后即可。
2. MySQL的列(字段)类型
数据库中的每个表都是由一个或多个列(字段)构成的。在用create table语句创建一个表时,要为每列(字段)指定一个类型。列(字段)的类型比数据类型更为细化,它精确地描述了给定表列(字段)可能包含的值的种类,如是否带小数、是否文字很多。
2.1数值列类型
mysql有整数和浮点数值的列类型,如表1所示。整数列类型可以有符号也可无符号。有一种特殊的属性允许整数列值自动生成,这对需要唯一序列或标识号的应用系统来说是非常有用的。
类型 |
说明 |
tinyint |
非常小的整数 |
smallint |
较小整数 |
mediumint |
中等大小整数 |
int |
标准整数 |
bigint |
较大整数 |
float |
单精度浮点数 |
double |
双精度浮点数 |
decimal |
一个串的浮点数 |
表1:数值列类型
每种数值类型的名称和取值范围如表2所示。
类型说明 |
取值范围 |
tinyint[(m)] |
有符号值:-128 到127(- 27 到27 - 1) |
smallint[(m)] |
有符号值:-32768 到32767(- 215 到215 - 1) |
mediumint[(m)] |
有符号值:-8388608 到8388607(- 22 3 到22 3 - 1 ) |
int[(m)] |
有符号值:-2147683648 到2147683647(- 231 到231- 1) |
bigint[(m)] |
有符号值:-9223372036854775808 到9223373036854775807(- 263到263-1) |
float[(m, d)] |
最小非零值:±1.175494351e - 38 |
double[(m,d)] |
最小非零值:±2.2250738585072014e - 308 |
decimal (m, d) |
可变;其值的范围依赖于m 和d |
表2:数值列类型的取值范围
各种类型值所需的存储量如表3所示。
类型说明 |
存储需求 |
tinyint[(m)] |
1字节 |
smallint[(m)] |
2字节 |
mediumint[(m)] |
3字节 |
int[(m)] |
4字节 |
bigint[(m)] |
8字节 |
float[(m, d)] |
4字节 |
double[(m, d)] |
8字节 |
|
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的,其取值范围也与整型不同, 这种不同不仅在于这些类型有最大值,而且还有最小非零值。最小值提供了相应类型精度的一种度量,这对于记录科学数据来说是非常重要的(当然,也有负的最大 和最小值)。
在选择了某种数值类型时,应该考虑所要表示的值的范围,只需选择能覆盖要取值的范围的最小类型即可。选择较大类型会对空间造成浪费,使表不必要地增大,处 理起来没有选择较小类型那样有效。对于整型值,如果数据取值范围较小,如人员年龄或兄弟姐妹数,则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时,如果省略了它们,则使用缺省值。
2.2字符串列类型
mysql提供了几种存放字符数据的串类型,其类型如下:
类型名 |
说明 |
char |
定长字符串 |
varchar |
可变长字符串 |
tinyblob |
非常小的blob(二进制大对象) |
blob |
小blob |
mediumblob |
中等的blob |
longblob |
大blob |
tinytext |
非常小的文本串 |
text |
小文本串 |
mediumtext |
中等文本串 |
longtext |
大文本串 |
enum |
枚举;列可赋予某个枚举成员 |
set |
集合;列可赋予多个集合成员 |
表4:字符串列类型
下表给出了mysql 定义串值列的类型,以及每种类型的最大尺寸和存储需求。对于可变长的列类型,各行的值所占的存储量是不同的,这取决于实际存放在列中的值的长度。这个长度在表中用l 表示。
类型说明 |
最大尺寸 |
存储需求 |
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 为定义存储日期和时间值所提供的这些类型,并给出了每种类型的合法取值范围。
类型名 |
说明 |
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: 日前时间列类型的取值范围和存储需求
下面举个例子:
create table student |
MySQL decimal 类型
一般赋予浮点列的值被四舍五入到这个列所指定的十进制数。如果在一个FLOAT(8, 1)的列中存储1. 2 3 4 5 6,则结果为1. 2。如果将相同的值存入FLOAT(8, 4) 的列中,则结果为1. 2 3 4 6。这表示应该定义具有足够位数的浮点列以便得到尽可能精确的值。如果想精确到千分之一,那就不要定义使该类型仅有两位小数。
浮点值的这种处理在MySQL3.23 中有例外,FLOAT(4) 和FLOAT(8) 的性能有所变化。这两种类型现在为单精度(4 字节)和双精度(8 字节)的类型,在其值按给出的形式存放(只受硬件的限制)这一点上说,这两种类型是真浮点类型。
DECIMAL 类型不同于FLOAT和DECIMAL,其中DECIMAL 实际是以串存放的。DECIMAL 可能的最大取值范围与DOUBLE 一样,但是其有效的取值范围由M 和D 的值决定。如果改变M 而固定D,则其取值范围将随M 的变大而变大。表2 - 7的前三行说明了这一点。如果固定M 而改变D,则其取值范围将随D 的变大而变小(但精度增加)。表2 - 7的后三行说明了这一点。
给定的DECIMAL 类型的取值范围取决于MySQL的版本。对于MySQL3.23 以前的版本,DECIMAL(M, D) 列的每个值占用M 字节,而符号(如果需要)和小数点包括在M 字节中。因此,类型为DECIMAL(5, 2) 的列,其取值范围为-9.99 到9 9 . 9 9,因为它们覆盖了所有可能的5 个字符的值。
正如MySQL3.23 一样,DECIMAL 值是根据ANSI 规范进行处理的,ANSI 规范规定DECIMAL(M, D) 必须能够表示M 位数字及D 位小数的任何值。例如,DECIMAL(5, 2) 必须能够表示从-999.99 到999.99 的所有值。而且必须存储符号和小数点,因此自MySQL3.23以来DECIMAL 值占M + 2 个字节。对于DECIMAL(5, 2),“最长”的值(- 9 9 9 . 9 9)需要7个字节。在正取值范围的一端,不需要正号,因此MySQL利用它扩充了取值范围,使其超过了ANSI 所规范所要求的取值范围。如DECIMAL(5, 2) 的最大值为9 9 9 9 . 9 9,因为有7 个字节可用。
简而言之,在MySQL3.23 及以后的版本中,DECIMAL(M, D) 的取值范围等于更早版本中的DECIMAL(M + 2, D) 的取值范围。在MySQL的所有版本中,如果某个DECIMAL 列的D 为0,则不存储小数点。这样做的结果是扩充了列的取值范围,因为过去用来存储小数点的字节现在可用来存放其他数字了。