mysql中的map数据类型_mysql中数据类型
我们要把现实世界中的各种信息转换成计算机能理解的东西,这些转换后的信息就形成了数据。例如,某⼈的出⽣⽇期是“1987年5⽉23⽇”,他的⾝⾼是 170厘⽶,等等。数据不仅包括数字、字母、⽂字和其他特殊字符组成的⽂本形式的数据,⽽且还包括图形、图像、动画、影像、声⾳等多媒体数据。但使⽤最 多、最基本的仍然是⽂本数据。
1. mysql的数据类型
在mysql中有如下⼏种数据类型:
(1)数值型
数值是诸如32 或153.4 这样的值。mysql ⽀持科学表⽰法,科学表⽰法由整数或浮点数后跟“e”或“e”、⼀个符号(“+”或“-”)和⼀个整数指数来表⽰。1.24e+12 和23.47e-1 都是合法的科学表⽰法表⽰的数。⽽1.24e12 不是合法的,因为指数前的符号未给出。
浮点数由整数部分、⼀个⼩数点和⼩数部分组成。整数部分和⼩数部分可以分别为空,但不能同时为空。
数值前可放⼀个负号“-”以表⽰负值。
(2)字符(串)型
字符型(也叫字符串型,简称串)是诸如“hello, world!”或“⼀个馒头引起的⾎案”这样的值,或者是电话号码87398413这样的值。既可⽤单引号也可⽤双引号将串值括起来。
初学者往往分不清数值87398143和字符串87398143的区别。都是数字啊,怎么⼀个要⽤数值型,⼀个要⽤字符型呢?关键就在于:数值型的 87398143是要参与计算的,⽐如它是⾦融中的⼀个货款总额;⽽字符型的87398143是不参与计算的,只是表⽰电话号码,这样的还有街道号码、门 牌号码等等,它们都不参与计算。
(3)⽇期和时间型
⽇期和时间是⼀些诸如“2006-07-12”或“12:30:43”这样的值。mysql还⽀持⽇期/时间的组合,如“2006-07-12 12:30:43”。
(4)null值
null表⽰未知值。⽐如填写表格中通讯地址不清楚留空不填写,这就是null值。
我们⽤create table语句创建⼀个表(参看前⾯的章节),这个表中包含列的定义。例如我们在前⾯创建了⼀个joke表,这个表中有content和writer两个 列:
定义⼀个列的语法如下:
create table
(
content varchar(20) not null,
writer varchar(10) null
)
col_name col_typy [col_attributes] [general_attributes]
其中列名由col_name 给出。列名可最多包含64个字符,字符包括字母、数字、下划线及美元符号。列名可以名字中合法的任何符号(包括数字)开头。但列名不能完全由数字组成,因 为那样可能使其与数据分不开。mysql保留诸如select、delete和create这样的词,这些词不能⽤做列名,但是函数名(如pos 和min)是可以使⽤的。
列类型col_type表⽰列可存储的特定值。列类型说明符还能表⽰存放在列中的值的最⼤长度。对于某
些类型,可⽤⼀个数值明确地说明其长度。⽽另外⼀些 值,其长度由类型名蕴含。例如,char(10) 明确指定了10个字符的长度,⽽tinyblob值隐含最⼤长度为255个字符。有的类型说明符允许指定最⼤的显⽰宽度(即显⽰值时使⽤多少个字符)。浮 点类型允许指定⼩数位数,所以能控制浮点数的精度值为多少。
可以在列类型之后指定可选的类型说明属性,以及指定更多的常见属性。属性起修饰类型的作⽤,并更改其处理列值的⽅式,属性有以下类
(1)专⽤属性⽤于指定列。例如,unsigned 属性只针对整型,⽽binary属性只⽤于char 和varchar。
(2)通⽤属性除少数列之外可⽤于任意列。可以指定null 或not null 以表⽰某个列是否能够存放null。还可以⽤default,def_value 来表⽰在创建⼀个新⾏但未明确给出该列的值时,该列可赋予值def_value。def_value 必须为⼀个常量;它不能是表达式,也不能引⽤其他列。不能对blob 或text 列指定缺省值。
如果想给出多个列的专⽤属性,可按任意顺序指定它们,只要它们跟在列类型之后、通⽤属性之前即可。类似地,如果需要给出多个通⽤属性,也可按任意顺序给出 它们,只要将它们放在列类型和可能给出的列专⽤属性之后即可。
2. mysql的列(字段)类型
数据库中的每个表都是由⼀个或多个列(字段)构成的。在⽤create table语句创建⼀个表时,要为每列(字段)指定⼀个类型。列(字段)的类型⽐数据类型更为细化,它精确地描述了给定表列(字段)可能包含的值的种类, 如是否带⼩数、是否⽂字很多。
2.1数值列类型
mysql有整数和浮点数值的列类型,如表1所⽰。整数列类型可以有符号也可⽆符号。有⼀种特殊的属性允许整数列值⾃动⽣成,这对需要唯⼀序列或标识号的 应⽤系统来说是⾮常有⽤的。
类型
说明
tinyint
⾮常⼩的整数
smallint
较⼩整数
mediumint
中等⼤⼩整数
int
标准整数
bigint
较⼤整数
float
单精度浮点数
double
双精度浮点数
decimal
⼀个串的浮点数
表1:数值列类型
每种数值类型的名称和取值范围如表2所⽰。
类型说明
取值范围
tinyint[(m)]
⽆符号值:0到255(0 到28 - 1) 1个字节
smallint[(m)]
有符号值:-32768 到32767(- 215 到215 - 1)
⽆符号值:0到65535(0 到21 6 - 1) 2个字节
mediumint[(m)]
有符号值:-8388608 到8388607(- 22 3 到22 3 - 1 )
⽆符号值:0到16777215(0 到22 4 - 1) 3个字节
int[(m)]
有符号值:-2147683648 到2147683647(- 231 到231- 1)
⽆符号值:0到4294967295(0 到232 - 1) 4个字节
bigint[(m)]
有符号值:-9223372036854775808 到9223373036854775807(- 263到263-1)⽆符号值:0到18446744073709551615(0到264 – 1) 8个字节
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字节
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的,其取值范围也与整型不同,这种不同不仅在于这些类型有最⼤ 值,⽽且还有最⼩⾮零值。最⼩值提供了相应类型精度的⼀种度量,这对于记录科学数据来说是⾮常重要的(当然,也有负的最⼤和最⼩值)。
在选择了某种数值类型时,应该考虑所要表⽰的值的范围,只需选择能覆盖要取值的范围的最⼩类型即可。选择较⼤类型会对空间造成浪费,使表不必要地增⼤,处 理起来没有选择较⼩类型那样有效。对于整型值,如果数据取值范围较⼩,如⼈员年龄或兄弟妹数,则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提供了⼏种存放字符数据的串类型,其类型如下:
mysql创建表数据类型类型名
说明
char
定长字符串
varchar
可变长字符串
tinyblob
⾮常⼩的blob(⼆进制⼤对象)
blob
⼩blob
mediumblob
中等的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字节
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论