mysql数据类型详解

上传人:d****1 文档编号:117362052 上传时间:2022-07-08 格式:DOCX 页数:8 大小:24.38KB
收藏 版权申诉 举报 下载
mysql数据类型详解_第1页
第1页 / 共8页
mysql数据类型详解_第2页
第2页 / 共8页
mysql数据类型详解_第3页
第3页 / 共8页
资源描述:

《mysql数据类型详解》由会员分享,可在线阅读,更多相关《mysql数据类型详解(8页珍藏版)》请在装配图网上搜索。

1、查看文章mysql 数据类型2007-01-27 20:341. mysql 的数据类型在 mysql 中有如下几种数据类型:(1)数值型数值是诸如32或153.4这样的值mysql支持科学表示法,科学表示法由 整数或浮点数后跟“e”或“e”、一个符号(“ + ”或“-”)和一个整数指数来 表示。1.24e+12和23.47e-1都是合法的科学表示法表示的数。而1.24e12不 是合法的,因为指数前的符号未给出。浮点数由整数部分、一个小数点和小数部分组成。整数部分和小数部分可以 分别为空,但不能同时为空。数值前可放一个负号“-”以表示负值。( 2)字符(串)型字符型(也叫字符串型,简称串)是诸

2、如“hello, world!”或“一个馒头 引起的血案”这样的值,或者是电话号码 87398413 这样的值。既可用单引号也 可用双引号将串值括起来。初学者往往分不清数值 87398143 和字符串 87398143 的区别。都是数字啊, 怎么一个要用数值型,一个要用字符型呢?关键就在于:数值型的 87398143 是 要参与计算的,比如它是金融中的一个货款总额;而字符型的 87398143 是不参 与计算的,只是表示电话号码,这样的还有街道号码、门牌号码等等,它们都不 参与计算。( 3)日期和时间型日期和时间是一些诸如“2006-07-12”或“12:30:43”这样的值。 mysql 还

3、 支持日期/时间的组合,如“2006-07-12 12:30:43”。( 4) null 值null 表示未知值。比如填写表格中通讯地址不清楚留空不填写,这就是 null 值。我们用 create table 语句创建一个表(参看前面的章节),这个表中包含 列的定义。例如我们在前面创建了一个 joke 表,这个表中有 content 和 writer 两个列:create table(content varchar(20) not null, writer varchar(lO) null )定义一个列的语法如下:col_name col_typy col_attributes general

4、_attributes其中列名由 col_name 给出。列名可最多包含 64 个字符,字符包括字母、数 字、下划线及美元符号。列名可以名字中合法的任何符号(包括数字)开头。但 列名不能完全由数字组成,因为那样可能使其与数据分不开。mysql保留诸如 select、elete和create这样的词,这些词不能用做列名,但是函数名(如pos和 min)是可以使用的。列类型 col_type 表示列可存储的特定值。列类型说明符还能表示存放在列 中的值的最大长度。对于某些类型,可用一个数值明确地说明其长度。而另外一 些值,其长度由类型名蕴含。例如, char(10) 明确指定了 10 个字符的长度,

5、而 tinyblob 值隐含最大长度为 255 个字符。有的类型说明符允许指定最大的显示 宽度(即显示值时使用多少个字符)。浮点类型允许指定小数位数,所以能控制 浮点数的精度值为多少。可以在列类型之后指定可选的类型说明属性,以及指定更多的常见属性。属 性起修饰类型的作用,并更改其处理列值的方式,属性有以下类型:(1)专用属性用于指定列。例如, unsigned 属性只针对整型,而 binary 属性只用于 char 和 varchar。(2)通用属性除少数列之外可用于任意列。可以指定 null 或 not null 以 表示某个列是否能够存放null。还可以用default, def_valu

6、e来表示在创建一 个新行但未明确给出该列的值时,该列可赋予值 def_value。 def_value 必须为 一个常量;它不能是表达式,也不能引用其他列。不能对 blob 或 text 列指定 缺省值。如果想给出多个列的专用属性,可按任意顺序指定它们,只要它们跟在列类型之后、通用属性之前即可。类似地,如果需要给出多个通用属性,也可按任意顺序给出它们,只要将它们放在列类型和可能给出的列专用属性之后即可。2. mysql 的列(字段)类型 数据库中的每个表都是由一个或多个列(字段)构成的。在用 create table 语句创建一个表时,要为每列(字段)指定一个类型。列(字段)的类型比数据 类型

7、更为细化,它精确地描述了给定表列(字段)可能包含的值的种类,如是否 带小数、是否文字很多。2.1 数值列类型mysql 有整数和浮点数值的列类型,如表 1 所示。整数列类型可以有符号也 可无符号。有一种特殊的属性允许整数列值自动生成,这对需要唯一序列或标识 号的应用系统来说是非常有用的。类型说明tinyint非常小的整数smallint较小整数mediumint中等大小整数int标准整数bigint较大整数float单精度浮点数double双精度浮点数decimal一个串的浮点数表 1 :数值列类型每种数值类型的名称和取值范围如表 2 所示。类型说明取值范围tinyint (m)有符号值:-1

8、28到127 (- 27到27 - 1) 无符号值:0到255(0到28 - 1)smallint(m)有符号值:-32768 到 32767 (- 215 到 215 - 1) 无符号值:0到65535(0到21 6 - 1)mediumint(m)有符号值:-8388608 到 8388607 (- 22 3 到22 3 - 1 )无符号值:0到16777215(0到22 4 - 1)int (m)有符号值:-2147683648 到 2147683647 (- 231 到 231- 1)无符号值:0 到 4294967295(0 到 232 - 1)bigint (m)有符号值:-922

9、3372036854775808 到9223373036854775807 (- 263 到 263-1)无符号值:0 到 18446744073709551615(0 到 264 - 1)floa t (m, d)最小非零值:1.175494351e - 38double(m,d)最小非零值:2.2250738585072014e - 308decimal (m, d)可变;其值的范围依赖于m和d表 2 :数值列类型的取值范围各种类型值所需的存储量如表 3 所示。类型说明存储需求tinyint (m)1字节smallint(m)2字节mediumint(m)3字节int (m)4字节bigi

10、nt (m)8字节floa t (m, d)4字节double(m, d)8字节decimal (m, d)m 字节(mysql 3.23 )表 3 :数值列类型的存储需求mysql 提供了五种整型: tinyint、smallint、mediumint、int 和 bigint。 int 为 integer 的缩写。这些类型在可表示的取值范围上是不同的。整数列可定 义为 unsigned 从而禁用负值;这使列的取值范围为 0 以上。各种类型的存储量 需求也是不同的。取值范围较大的类型所需的存储量较大。mysql 提供三种浮点类型: float 、double 和 decimal 。与整型不同

11、,浮点 类型不能是 unsigned 的,其取值范围也与整型不同,这种不同不仅在于这些类 型有最大值,而且还有最小非零值。最小值提供了相应类型精度的一种度量,这 对于记录科学数据来说是非常重要的(当然,也有负的最大和最小值)。在选择了某种数值类型时,应该考虑所要表示的值的范围,只需选择能覆盖 要取值的范围的最小类型即可。选择较大类型会对空间造成浪费,使表不必要地 增大,处理起来没有选择较小类型那样有效。对于整型值,如果数据取值范围较 小,如人员年龄或兄弟姐妹数,则tinyint最合适。mediumint能够表示数百万 的值并且可用于更多类型的值,但存储代价较大。bigint在全部整型中取值范

12、围最大,而且需要的存储空间是表示范围次大的整型 int 类型的两倍,因此只在 确实需要时才用。对于浮点值, double 占用 float 的两倍空间。除非特别需要 高精度或范围极大的值,一般应使用只用一半存储代价的 float 型来表示数据。在定义整型列时,可以指定可选的显示尺寸m。如果这样,m应该是一个1到 255的整数。它表示用来显示列中值的字符数。例如,mediumint(4)指定了一个 具有4 个字符显示宽度的 mediumint 列。如果定义了一个没有明确宽度的整数列, 将会自动分配给它一个缺省的宽度。缺省值为每种类型的“最长”值的长度。如 果某个特定值的可打印表示需要不止 m 个

13、字符,则显示完全的值;不会将值截断 以适合 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可变长字符串tiny

14、blob非常小的blob (二进制大对象)blob小 blobmediumblob中等的bloblongblob大 blobtinytext非常小的文本串text小文本串mediumtext中等文本串longtext大文本串enum枚举;列可赋予某个枚举成员set集合;列可赋予多个集合成员表 4:字符串列类型下表给出了 mysql 定义串值列的类型,以及每种类型的最大尺寸和存储需 求。对于可变长的列类型,各行的值所占的存储量是不同的,这取决于实际存放在列中的值的长度。这个长度在表中用 l 表示。类型说明最大尺寸存储需求char( m)m字节m字节varchar(m)m字节l + 1字节tiny

15、blob, tinytext28- 1字节l + 1字节blob, text216 - 1字节l + 2字节mediumblob, mediumtext224-1字节l + 3字节longblob, longtext232- 1字节l + 4字节enum(“valuel, “value2, .)65535个成 员1或2字节set (“valuel, “value2, .)64个成员1、 2、 3、 4 或 8 字节表 5 :串列类型最大尺寸及存储需求l以外所需的额外字节为存放该值的长度所需的字节数mysql通过存储值 的内容及其长度来处理可变长度的值。这些额外的字节是无符号整数。请注意, 可变

16、长类型的最大长度、此类型所需的额外字节数以及占用相同字节数的无符号 整数之间的对应关系。例如,mediumblob值可能最多224 - 1字节长并需要3个 字节记录其结果。 3 个字节的整数类型 mediumint 的最大无符号值为 224 - 1。 这并非偶然。2.3 日期时间列类型mysql 提供了几种时间值的列类型,它们分别是: date、datetime、time、 times tamp和year。下表给出了 mysql为定义存储日期和时间值所提供的这些 类型,并给出了每种类型的合法取值范围。类型名说明da te“yyyy-mm-dd ”格式表示的日期 值time“hh:mm:ss”格

17、式表示的时间值datetime“yyyy-mm-dd hh:mm:ss格式timestamp“yyyymmddhhmmss 格式表示的 时间戳值year“yyyy ”格式的年份值表 6:日期时间列类型类型名取值范围存储需求da te“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 字 节timestamp19700101000000 到 2037 年 的某个时刻4 字 节year1901 到 21551字 节表

18、7 : 日前时间列类型的取值范围和存储需求下面举个例子:create table student(name varchar(20) not null, chinese tinyint(3), maths tinyint(3),english tinyint(3), birthday date)这个例子创建一个 student 表,这个表中有 name 字段,字符类型列,不允 许null(空值)。有chinese、maths和english三个整数类型列。还有个birthday 日期类型列。MySQL decimal 类型一般赋予浮点列的值被四舍五入到这个列所指定的十进制数。如果在一个FL0AT

19、(8, 1)的列 中存储 1. 2 3 4 5 6,则结果为 1. 2。如果将相同的值存入 FLOAT(8, 4) 的列中,则结果为 1. 2 3 4 6。这表示应该定义具有足够位数的浮点列以便得到尽可能精确的值。如果想精确到千分 之一,那就不要定义使该类型仅有两位小数。浮点值的这种处理在MySQL3.23中有例外,FLOAT 和FLOAT(8)的性能有所变化。 这两种类型现在为单精度( 4 字节)和双精度( 8 字节)的类型,在其值按给出的形式存 放(只受硬件的限制)这一点上说,这两种类型是真浮点类型。DECIMAL类型不同于FLOAT和 DECIMAL,其中DECIMAL实际是以串存放的。

20、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

21、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利用它扩充了取 值范围,使其超过

22、了 ANSI 所规范所要求的取值范围。如 DECIMAL(5, 2) 的最大值为 9 9 9 9 . 9 9,因为有 7 个字节可用。表2-了切与D对DECIMAL(M; D)取值范围的影响类型说明取值范围(MySQL 3.23)取值范围(MySQL丄323DECLMAL(4 1)-9 9 到 99-9-999.9 到 9999 9DECIMALS, 1)-99.9 到 999 9-9999 9 到 99999一9DECLMAL 1)-999一9 到 9999一9-99999.9 到 999999一9DECaiAL(6, 2)-99-99 到 999.99-9999.99 到 99999.99DECIhIAL(6, 3)-9.999 到 99.999-999.999 到 9999-999简而言之,在 MySQL3.23 及以后的版本中, DECIMAL(M, D) 的取值范围等于更早版 本中的 DECIMAL(M + 2, D) 的取值范围。在 MySQL 的所有版本中,如果某个 DECIMAL 列 的 D 为 0,则不存储小数点。这样做的结果是扩充了列的取值范围,因为过去用来存储小 数点的字节现在可用来存放其他数字了。

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!