转自:http://tech.itzero.com/2006/1015/1202.html
我们要把现实世界中的各种信息转换成计算机能理解的东西,这些转换后的信息就形成了数据。例
如,某人的出生日期是“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:字符串列类型
分享到:
相关推荐
2. 数据类型:MySQL支持多种数据类型,如整数类型(TINYINT、INT、BIGINT)、浮点类型(FLOAT、DOUBLE)、字符串类型(CHAR、VARCHAR、TEXT)、日期和时间类型(DATE、TIME、DATETIME、TIMESTAMP)等。 3. SQL语言...
本文将深入探讨MySQL的基础知识,包括安装、数据类型、表的创建、查询语句、索引以及事务处理等核心概念。 1. **安装与配置** MySQL的安装过程通常包括下载适合操作系统的安装包,按照向导进行安装,然后配置...
【MySQL数据类型】 MySQL支持多种数据类型,包括数值型(整型、浮点型)、decimal浮点型(用于精确存储小数)、字符串(如char、varchar、text)、枚举和时间类型。选择合适的数据类型有助于节省存储空间和提高查询...
2. 数据类型:MySQL支持多种数据类型,如整数类型(INT、BIGINT等)、浮点数类型(FLOAT、DOUBLE)、字符串类型(VARCHAR、CHAR)、日期时间类型(DATE、TIME、TIMESTAMP)等,选择合适的数据类型对于存储和检索数据...
以上是对MySQL基础知识的总结,涵盖了数据库管理系统的各个方面,从基础的数据类型到复杂的查询语句和事务处理,再到数据库的日常管理和性能优化。掌握这些知识对于在IT行业中进行数据库开发和管理是必不可少的。
├─10、课程:进阶数据类型(上).1、复杂数据类型及操作.mp4 ├─10、课程:进阶数据类型(上).2、空间.mp4 ├─10、课程:进阶数据类型(上).3、几何形状.mp4 ├─10、课程:进阶数据类型(上).4、Touch.mp4 ...
2. 表:表是数据的结构化存储,创建表使用`CREATE TABLE`语句,包含列名、数据类型和约束条件。 四、SQL基础 1. DDL(Data Definition Language):用于定义数据库结构,包括创建、修改、删除表等操作。 2. DML...
- 同一列下的数据必须具有相同的数据类型。 - 每一行都是唯一的。 - 列没有固定的顺序。 - 行没有固定的顺序。 - 每一列都有一个唯一的名称。 通过以上内容的学习,我们不仅可以更好地理解MySQL的基础知识,还能够...
**数据库MySQL基础知识...以上就是对“数据库MySQL基础知识总结”的详细解读,涵盖了MySQL的基础概念、数据类型、常用操作以及一些数据库设计和管理的基本常识。通过这些知识,可以为初学者构建一个坚实的学习基础。
MySQL基础数据生成工具是一款实用程序,专为学习和练习MySQL基础语法而设计。这款工具能够帮助用户快速创建一系列虚拟的数据,这些数据对于理解和掌握数据库操作非常有帮助,尤其是在没有实际生产环境的情况下。以下...
MySQL是世界上最受欢迎的关系型数据库管理系统之一,用于存储和管理各种类型的数据。在“数据库数据文件”这个主题中,我们将深入探讨MySQL如何管理和组织其数据文件,以及如何利用这些知识进行有效的数据库操作。 ...
Python 与 MySQL 基础知识点 Python 是一种流行的编程语言,而 MySQL 是一种关系型数据库...本文介绍了 Python 与 MySQL 基础知识,包括 MySQL 的基本概念、数据类型、约束和 Python 中操作 MySQL 数据库的基本步骤。
接下来,我们深入到核心主题——MySQL数据类型。MySQL是一个流行的开源关系型数据库管理系统,其支持多种数据类型,包括: 1. **数值类型**:如`INT`(整数)、`FLOAT`(浮点数)、`DOUBLE`(双精度浮点数)、`...
在这个“mysql数据类型共2页.pdf.zip”压缩包中,很显然,我们能够获取到关于MySQL数据类型的简要介绍。尽管实际内容并未在此提供,但我们可以基于通用知识来详细阐述这个主题。 MySQL的数据类型大致可以分为以下几...
这个名为"mysql基础知识2.zip"的压缩包文件显然包含了关于MySQL基础概念、操作和管理的一些教学材料或教程。接下来,我们将深入探讨MySQL的基础知识。 1. **数据库和表的概念**:在MySQL中,数据库是一个组织数据的...
康师傅mysql基础pdf可能是一份教程或教材,涵盖了MySQL的基础知识,包括安装、配置、基本操作以及一些核心概念。在这里,我们将深入探讨MySQL的一些关键点。 1. **安装与配置**: MySQL的安装通常涉及下载安装包,...
### MySQL数据库基础知识点总结 #### 数据库概念理解 数据库是一种按照特定格式存储数据的仓库,其目的是为了方便数据的存取操作。在IT领域中,数据库是存储与管理大量数据的关键工具之一,它能有效组织数据,使得...