`
iwebcode
  • 浏览: 2008404 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
文章分类
社区版块
存档分类
最新评论

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两个列:

    定义一个列的语法如下:

    其中列名由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语句创建一个表时,要为每列(字段)指定一个类型。列(字段)的类型比数据类型更为细化,它精确地描述了给定表列(字段)可能包含的值的种类,如是否带小数、是否文字很多。

    MySQL有整数和浮点数值的列类型,如表1所示。整数列类型可以有符号也可无符号。有一种特殊的属性允许整数列值自动生成,这对需要唯一序列或标识号的应用系统来说是非常有用的。

    类型

    说明

    TINYINT

    非常小的整数

    SMALLINT

    较小整数

    MEDIUMINT

    中等大小整数

    INT

    标准整数

    BIGINT

    较大整数

    FLOAT

    单精度浮点数

    DOUBLE

    双精度浮点数

    DECIMAL

    一个串的浮点数

    表1:数值列类型

    每种数值类型的名称和取值范围如表2所示。

    类型说明

    取值范围

    TINYINT[(M)]

    有符号值:-128 到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)]

    有符号值:-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的,其取值范围也与整型不同,这种不同不仅在于这些类型有最大 值,而且还有最小非零值。最小值提供了相应类型精度的一种度量,这对于记录科学数据来说是非常重要的(当然,也有负的最大和最小值)。

    在选择了某种数值类型时,应该考虑所要表示的值的范围,只需选择能覆盖要取值的范围的最小类 型即可。选择较大类型会对空间造成浪费,使表不必要地增大,处理起来没有选择较小类型那样有效。对于整型值,如果数据取值范围较小,如人员年龄或兄弟姐妹 数,则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: 日前时间列类型的取值范围和存储需求

    下面举个例子:

    这个例子创建一个student表,这个表中有name字段,字符类型列,不允许NULL(空值)。有Chinese、Maths和English三个整数类型列。还有个Birthday日期类型列。

    CREATE TABLE student
    (
    Name varchar(20) NOT NULL,
    Chinese TINYINT(3),
    Maths TINYINT(3),
    English TINYINT(3),
    Birthday DATE
    )

分享到:
评论

相关推荐

    MySQL常用数据类型.pdf

    MySQL常用数据类型.pdf

    MySql数据库的列类型(字段类型).

    MySql数据库的列类型(字段类型).MySql数据库的列类型(字段类型).MySql数据库的列类型(字段类型).MySql数据库的列类型(字段类型).

    mysql中插入多text类型问题

    mysql中插入多text类型问题,可以让mysql数据库插入多个大存储类型

    Mysql支持的数据类型(列类型总结)

    MySQL支持大量的列类型,它可以被分为3类:数字类型、日期和时间类型以及字符串(字符)类型。本节首先给出可用类型的一个概述,并且总结每个列类型的存储需求,然后提供每个类中的类型性质的更详细的描述

    MySQL数据表添加字段

    一个完整的字段包括字段名、数据类型和约束条件。MySQL 添加字段的语法格式如下: ALTER TABLE &lt;表名&gt; ADD &lt;新字段名&gt;&lt;数据类型&gt;[约束条件]; 对语法格式的说明如下: &lt;表名&gt; 为数据表的名字; &lt;新字段名&gt; 为所要...

    MySQL数据类型和常用字段属性总结

    MySQL提供了一组可以赋给表中各个列的数据类型,每个类型都强制数据满足为该数据类型预先确定的一组规则,例如大小、类型及格式。 这里先总结数据类型。MySQL中的数据类型大的方面来分,可以分为:日期和时间、数值...

    MySql数据类型和运算符总结

    1 数据类型 1.1 数值类型 1.2 日期和事件类型 1.3 字符串类型 1.4 enum枚举类型和set集合类型 2 运算符 2.1 算术运算符 2.2 逻辑运算符 2.3 比较运算符   1 数据类型 数据类型分为数值类型、日期和时间类型、字符...

    MYSQL 数据类型

    ==================== 数值列类型 ==================== TINYINT 非常小的整数 SMALLINT 较小整数 MEDIUMINT 中等大小整数 INTEGER 标准整数 BIGINT 较大整数 FLOAT 单精度浮点数

    各种数据库的数据类型对比

    NULL 博文链接:https://vivus.iteye.com/blog/1750981

    MySQL数据类型中DECIMAL的用法实例详解

    MySQL数据类型中DECIMAL的用法实例详解 在MySQL数据类型中,例如INT,FLOAT,DOUBLE,CHAR,DECIMAL等,它们都有各自的作用,下面我们就主要来介绍一下MySQL数据类型中的DECIMAL类型的作用和用法。 一般赋予浮点列的值被...

    mysql优化及基础面试题

    mysql优化及基础面试题。 什么是慢查询 慢查询日志,顾名思义,就是查询慢的日志,是指 mysql 记录所有执行超过 long_query_time 参数设定的时间阈值的 SQL 语句的日志。...当一个列可以选择多种数据类型时 。

    MySql于Java数据类型对应列表

    本Pdf文件列出了mysql和java的各种数据对应,以方便开发者使用时,能很快的对应起来。

    SQL标准数据类型-mysql

    介绍的sql的数据类型、、、一看就会用,方便!!类型、名称、描述都一 一 列出

    MYSQL

    1.6 顺应2000年 1.7 SQL一般信息和教程 1.8 有用的MySQL相关链接 2 MySQL 邮件列表及如何提问或报告错误 2.1 MySQL邮件列表 2.2 提问或报告错误 2.3 怎样报告错误或问题 2.4 在...

    mysql varchar类型求和实例操作

    有的小伙伴在学习数据库的时候,创建表结构的时候不小心把某字段设置成了varchar但是在统计求和的时候就傻眼了,接下来跟着小编学习一下,不用改该列数据类型也能求和的方法吧! 1、打开 数据库连接客户端Navicat ...

    MySql 5.1 参考手册.chm

    前言 1. 一般信息 1.1. 关于本手册 1.2. 本手册采用的惯例 1.3. MySQL AB概述 1.4. MySQL数据库管理系统概述 1.4.1. MySQL的历史 1.4.2. MySQL的的主要特性 1.4.3. MySQL稳定性 ...11.6. 选择正确的列类型

    mysql创建表方法.zip

    MySQL 创建表是一个基础的数据库操作,它涉及到定义表的结构,包括列名、数据类型、约束等。下面我将详细解释如何在 MySQL 中创建表,并给出一个完整的例子。 • 表名:你想要创建的表的名称。 • 列名:表中的列...

    169集全新MySQL课程 MySQL技能全面探索 MySQL核心特训教程 MySQL零基础实战班视频

    ├─10、课程:进阶数据类型(上).1、复杂数据类型及操作.mp4 ├─10、课程:进阶数据类型(上).2、空间.mp4 ├─10、课程:进阶数据类型(上).3、几何形状.mp4 ├─10、课程:进阶数据类型(上).4、Touch.mp4 ...

    21分钟MySQL入门教程

    四、MySQL中的数据类型 五、使用MySQL数据库 • 登录到MySQL • 创建一个数据库 • 选择所要操作的数据库 • 创建数据库表 六、操作MySQL数据库 • 向表中插入数据 • 查询表中的数据 • 更新表中的数据 • 删除...

Global site tag (gtag.js) - Google Analytics