`
xwood
  • 浏览: 103796 次
  • 性别: 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日期数据类型、MySQL时间类型使用总结

    为了更好地理解和运用这些数据类型,本篇将对MySQL中的日期数据类型和时间类型进行详细的分析和总结。 #### 一、MySQL日期数据类型 MySQL提供了多种用于存储日期值的数据类型,包括`DATE`、`DATETIME`、`TIMESTAMP...

    Oracle与MySQL数据类型深入比较及代码示例

    数据库数据类型是构建数据库和进行数据存储的基础。Oracle和MySQL作为两个主流的关系型数据库...通过本文的分析和代码示例,读者应该能够更好地理解Oracle与MySQL在数据类型方面的差异,并在实际开发中做出合适的选择。

    mysql数据类型描述

    很不错的数据类型分析 DECIMAL 用户自定义精度的浮点型数据 变量;取决于精度与长度 以特别高的精度存储小数数据。 例如:货币数额,科学数据

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

    1. **MySQL数据类型**: MySQL提供了广泛的数据类型,如数值类型(整数、浮点数、定点数)、字符串类型(CHAR、VARCHAR、TEXT)、日期和时间类型(DATE、TIME、DATETIME、TIMESTAMP)以及二进制类型(BLOB、BINARY...

    Mysql的数据集 Mysql的数据集 Mysql的数据集

    MySQL 数据集是数据库管理系统中一个重要的概念,它指的是在 SQL 查询语句中形成的临时或永久性的数据集合。在本篇文章中,我们将深入探讨 MySQL 数据集的相关知识点,包括数据集的生成、操作以及优化策略。 首先,...

    MySQL数据库应用实战教程第2章教案MySQL数据类型.pdf

    在本章"MySQL数据库应用实战教程"中,主要讲解了MySQL数据类型,这是数据库设计的基础。数据类型决定了数据的存储方式、占用空间以及可以存储的数据范围。以下是详细的知识点解析: 1. 数值类型: - MySQL支持严格...

    java_mysql_数据类型对照.doc

    根据提供的文件信息,我们可以深入探讨这一主题,解析Java与MySQL数据类型间的对应关系及其应用场景。 ### 数据类型对照表概览 首先,我们来看一下Java与MySQL之间数据类型的基本对照情况: 1. **VARCHAR**:在...

    mysql数据抽取,自动生成hive建表语句

    总的来说,“mysql数据抽取,自动生成hive建表语句”是大数据环境下的一个关键环节,它涉及到数据库间的数据迁移、数据类型转换、ETL流程等多个方面。通过使用`AutoCreateTable`这样的工具,我们可以更便捷地构建起...

    Mysql数据字典导出工具

    总结来说,MySQL数据字典导出工具对于数据库的管理和维护至关重要,它提供了对数据库结构的详细洞察,便于备份、恢复、分析和优化。使用适当的查询、工具和策略,可以有效地管理和导出这些关键信息。

    如何统计MySQL数据量大小

    在数据库管理中,了解MySQL数据量的大小是至关重要的,这有助于优化性能、规划存储空间以及进行容量规划。本文将详细讲解如何统计MySQL数据库的数据量大小,并涉及CONCAT函数的解读,以及对information_schema和...

    Mysql中类型转换

    在MySQL中,类型转换是一项非常实用的功能,它可以帮助我们处理不同数据类型之间的转换,尤其是在处理如日期、数字与字符串等类型的相互转换时尤其有用。本文将详细介绍MySQL中常用的类型转换函数及其具体用法,帮助...

    MySQL基础数据生成工具

    1. **MySQL简介**:MySQL是一个开源、免费的关系型数据库管理系统,广泛应用于Web应用开发、数据分析等领域。它支持SQL语言,具有高效、稳定和易于扩展的特点。 2. **SQL基础**:SQL(结构化查询语言)是用于管理...

    分析MySQL的数据类型以及建库策略

    本文将深入分析MySQL中的主要数据类型,并探讨如何根据实际需求来选择合适的数据类型。 首先,我们来看数字类型。MySQL中的数字类型主要包括整数类、小数类和数字类。整数类包括TINYINT、SMALLINT、MEDIUMINT、INT...

    mysql 测试数据集,单表200万条数据

    - 数据类型:正确选择数据类型可以节省存储空间,如INT、VARCHAR、DATE等。 - 约束:设置NOT NULL、UNIQUE、FOREIGN KEY等约束,保证数据的有效性。 - 主键:每张表应有一个主键,用于唯一标识每条记录,如自动...

    Access 导入MySQL 数据文件

    3. **数据类型映射**:Access和MySQL的数据类型可能存在差异,工具会自动尝试最佳匹配。检查并确认这些映射以确保数据完整性。 4. **预览和迁移**:在实际迁移前,预览数据转换的效果,确认无误后,点击“迁移”...

    MySQL协议解析MysqlProtocolAnalyzer.zip

    MysqlProtocolAnalyzer 是一个对... 能解析客户端与mysql服务交互的所有包,例如客户端与服务器连接的握手协议的包,所有COM_QUERY类型的语句,COM_STMT_PREPARE和COM_STMT_EXECUTE,还有ok包,以及resultset包等。

    全球国家地区大洲mysql数据文件

    标题中的“全球国家地区大洲mysql数据文件”指的是一个包含全球各国、地区和大洲信息的MySQL数据库数据文件。这个数据文件是由用户自行整理的,主要用于存储地理信息,便于在MySQL数据库环境中进行查询和分析。 ...

    五款常用mysql slow log分析工具

    描述:本文对五款常用的MySQL慢查询日志分析工具进行深入解析,旨在帮助DBA、开发者和运维人员更有效地定位和优化数据库性能瓶颈。 ### MySQL Slow Log概念 MySQL慢查询日志(Slow Query Log)是一种用于记录执行...

    mysql数据字典生成工具

    MySQL数据字典生成工具是一种实用程序,用于帮助数据库管理员和开发者整理并理解MySQL数据库的结构。数据字典在IT行业中是数据库管理系统中的一个重要组成部分,它提供了关于数据库对象(如表、视图、索引等)的详细...

Global site tag (gtag.js) - Google Analytics