Mysql的数据类型和字段类型详解

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: Mysql的数据类型和字段类型详解

 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
)

image.gif

  定义一个列的语法如下:  

col_name col_typy [col_attributes] [general_attributes]

image.gif

     其中列名由col_name 给出。列名可最多包含64个字符,字符包括字母、数字、下划线及美元符号。列名可以名字中合法的任何符号(包括数字)开头。但列名不能完全由数字组成,因为那样可能使其与数据分不开。mysql保留诸如select、delete和create这样的词,这些词不能用做列名,但是函数名(如pos 和min)是可以使用的。

   列类型col_type表示列可存储的特定值。列类型说明符还能表示存放在列中的值的最大长度。对于某些类型,可用一个数值明确地说明其长度。而另外一些值,其长度由类型名蕴含。例如,char(10) 明确指定了10个字符的长度,而tinyblob值隐含最大长度为255个字符。有的类型说明符允许指定最大的显示宽度(即显示值时使用多少个字符)。浮点类型允许指定小数位数,所以能控制浮点数的精度值为多少。

   可以在列类型之后指定可选的类型说明属性,以及指定更多的常见属性。属性起修饰类型的作用,并更改其处理列值的方式,属性有以下类型:

    • 专用属性用于指定列。例如,unsigned 属性只针对整型,而binary属性只用于char 和varchar。
    • 通用属性除少数列之外可用于任意列。可以指定null 或not null 以表示某个列是否能够存放null。还可以用default,def_value 来表示在创建一个新行但未明确给出该列的值时,该列可赋予值def_value。def_value 必须为一个常量;它不能是表达式,也不能引用其他列。不能对blob 或text 列指定缺省值。

       如果想给出多个列的专用属性,可按任意顺序指定它们,只要它们跟在列类型之后、通用属性之前即可。类似地,如果需要给出多个通用属性,也可按任意顺序给出它们,只要将它们放在列类型和可能给出的列专用属性之后即可。

    2. mysql的列(字段)类型

       数据库中的每个表都是由一个或多个列(字段)构成的。在用create table语句创建一个表时,要为每列(字段)指定一个类型。列(字段)的类型比数据类型更为细化,它精确地描述了给定表列(字段)可能包含的值的种类,如是否带小数、是否文字很多。

    2.1数值列类型

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

    表1:数值列类型

    类型 说明
    tinyint     非常小的整数
    smallint     较小整数
    mediumint     中等大小整数
    int     标准整数
    bigint     较大整数
    float 单精度浮点数
    double     双精度浮点数
    decimal     一个串的浮点数

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

    表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

    各种类型值所需的存储量如表3所示。

    表3:数值列类型的存储大小

    类型说明  存储大小
    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 )

    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提供了几种存放字符数据的串类型,其类型如下:

    表4:字符串列类型

    类型名 说明
    char     定长字符串
    varchar     可变长字符串
    tinyblob     非常小的blob(二进制大对象)
    blob     标准blob
    mediumblob     中blob
    longblob     大blob
    tinytext     非常小的文本串
    text     标准的文本串
    mediumtext     中等的文本串
    longtext     大文本串
    enum     枚举;列可赋予某个枚举成员
    set     集合;列可赋予多个集合成员

        下表给出了mysql 定义串值列的类型,以及每种类型的最大尺寸和存储需求。对于可变长的列类型,各行的值所占的存储量是不同的,这取决于实际存放在列中的值的长度。这个长度在表中用l 表示。

    表5:串列类型最大尺寸及存储需求

    类型名 最大存储 实际存储
    char      m 字节  m 字节
    varchar      m 字节 l + 1字节
    tinyblob     28- 1字节   l + 1字节
    blob     216 - 1 字节     l + 2字节
    mediumblob     224- 1字节  l + 3字节
    longblob     232- 1字节   l + 4字节
    tinytext     28- 1字节   l + 1字节
    text     216 - 1 字节  l + 2字节
    mediumtext     224- 1字节  l + 3字节
    longtext     232- 1字节   l + 4字节
    enum     2字节  1 或2字节
    set     8字节 1、2、3、4或8字节

      l 以外所需的额外字节为存放该值的长度所需的字节数。mysql 通过存储值的内容及其长度来处理可变长度的值。这些额外的字节是无符号整数。请注意,可变长类型的最大长度、此类型所需的额外字节数以及占用相同字节数的无符号整数之间的对应关系。例如,mediumblob 值可能最多224 - 1字节长并需要3 个字节记录其结果。3 个字节的整数类型mediumint 的最大无符号值为224 - 1。这并非偶然。

       2.3日期时间列类型

       mysql 提供了几种时间值的列类型,它们分别是: date、datetime、time、timestamp和year。下表给出了mysql 为定义存储日期和时间值所提供的这些类型,并给出了每种类型的合法取值范围。

    表6:日期时间列类型

    类型名 说明
    date      “yyyy-mm-dd”格式表示的日期值
    time      “hh:mm:ss”格式表示的时间值
    datetime     “yyyy-mm-dd hh:mm:ss”格式
    timestamp      “yyyymmddhhmmss”格式表示的时间戳值
    year “yyyy”格式的年份值

    表7: 日前时间列类型的取值范围和存储大小

    类型名  取值范围 存储大小
    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字节

       下面举个例子:  

    create table student
    (
    name varchar(20) not null,
    chinese tinyint(3),
    maths tinyint(3),
    english tinyint(3),
    birthday date
    )

    image.gif

       这个例子创建一个student表,这个表中有name字段,字符类型列,不允许null(空值)。有chinese、maths和english三个整数类型列。还有个birthday日期类型列。

    相关实践学习
    如何在云端创建MySQL数据库
    开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
    全面了解阿里云能为你做什么
    阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
    相关文章
    |
    19天前
    |
    存储 关系型数据库 MySQL
    MySQL 字段类型探究:深入理解 Varchar(50) 与 Varchar(500)
    在MySQL数据库中,`VARCHAR`类型是一种常用的字符串存储类型,它允许定义一个可变长度的字符串。然而,`VARCHAR(50)`和`VARCHAR(500)`之间的差异不仅仅是长度的不同,它们在存储和性能方面也有显著的区别。本文将深入探讨这两种字段类型的区别,以及它们在实际应用中的选择。
    61 3
    |
    19天前
    |
    存储 关系型数据库 MySQL
    MySQL 字段类型深度解析:VARCHAR(50) 与 VARCHAR(500) 的差异
    在MySQL数据库中,`VARCHAR`类型是一种非常灵活的字符串存储类型,它允许存储可变长度的字符串。然而,`VARCHAR(50)`和`VARCHAR(500)`之间的差异不仅仅是长度的不同,它们在存储效率、性能和使用场景上也有所不同。本文将深入探讨这两种字段类型的区别及其对数据库设计的影响。
    35 2
    |
    3月前
    |
    存储 Oracle 关系型数据库
    Oracle和MySQL有哪些区别?从基本特性、技术选型、字段类型、事务、语句等角度详细对比Oracle和MySQL
    从基本特性、技术选型、字段类型、事务提交方式、SQL语句、分页方法等方面对比Oracle和MySQL的区别。
    564 18
    Oracle和MySQL有哪些区别?从基本特性、技术选型、字段类型、事务、语句等角度详细对比Oracle和MySQL
    |
    2月前
    |
    关系型数据库 MySQL 数据库
    MySQL数据库基础(数据库操作,常用数据类型,表的操作)
    MySQL数据库基础(数据库操作,常用数据类型,表的操作)
    36 5
    |
    2月前
    |
    存储 关系型数据库 MySQL
    MySQL支持多种数据类型
    MySQL支持多种数据类型
    111 3
    |
    2月前
    |
    存储 关系型数据库 MySQL
    什么是mysql的数据类型?
    什么是mysql的数据类型?
    47 2
    |
    2月前
    |
    存储 关系型数据库 MySQL
    MySQL数据类型
    MySQL数据类型
    53 2
    |
    3月前
    |
    SQL 关系型数据库 MySQL
    创建包含MySQL和SQLServer数据库所有字段类型的表的方法
    创建一个既包含MySQL又包含SQL Server所有字段类型的表是一个复杂的任务,需要仔细地比较和转换数据类型。通过上述方法,可以在两个数据库系统之间建立起相互兼容的数据结构,为数据迁移和同步提供便利。这一过程不仅要考虑数据类型的直接对应,还要注意特定数据类型在不同系统中的表现差异,确保数据的一致性和完整性。
    35 4
    |
    4月前
    |
    存储 关系型数据库 MySQL
    MySQL 中的 BLOB 数据类型深入解析
    【8月更文挑战第31天】
    484 0
    |
    4月前
    |
    存储 关系型数据库 MySQL