mysql字段类型基础知识详解

发布时间:2020-06-29编辑:脚本学堂
本文介绍了mysql字段类型的基础知识,实例学习mysql字段类型的用法,包括日期类型、数值类型、字符串类型等,需要的朋友参考下。

mysql建表初步知识及字段类型

一、如何登录phpmyadmin环境
phpMyAdmin可以对mysql数据库进行完全管理。在IE地址中输入地址,输入数据库帐号和密码,登录phpMyAdmin。

二、几个概念
1、数据库:在MySQL中,要存储数据,必须从数据库开始,因此首先要创建数据库,但由于学校的MySQL服务器对学生数据帐号有限止,学生不得创建数据库,故每个学生的帐号中已事先由信息中心为大家建立了一个名为帐号名的数据库。但我们必须了解创建数据库的语句为
CREATE DATABASE <数据库名>

2、数据表:是构成数据库的一个基本单位,在一个数据库中用户可以建立多张数据表。这是我们有权力建立的。

3、数据表结构:创建一个数据表的第一步即为创建数据表结构,在数据表结构中的内容包括:有几个字段,每个字段的名称,字段的类型,字段的长度,字段的属性。

4、字段:它是构成数据表结构的必须元素,一列数据就是一个字段。

5、字段名:用来描述字段的名称,它可以用中文、英文字母、数字等字符来描述。

6、字段类型:用来限定数据的一种方式,即每一个字段下的数据必定类型是相同的。

7、字段长度:即每一列字段中的数据位数。

三、建立第一张数据表

1、在左窗口中点击数据库名,
2、在右窗口中输入数据表的名称如number1,输入字段数6,单击执行,
3、按如下要求建立一张数据表:

字段名field

字段类型(列类型)
type 属性 说明
name Char(8) 姓名
xb Char(2) 性别
csrq  Date 出生日期
address Text 住址
Byxx Char(20) 毕业学校
zip Int(6) 邮政编码

注意其下的sql语句
 

复制代码 代码示例:
CREATE TABLE `number1` (
`name` CHAR( 8 ) NOT NULL ,
`xb` CHAR( 2 ) NOT NULL ,
`csrq` DATE NOT NULL ,
`address` TEXT,
`byxx` CHAR( 20 ) ,
`zip` INT( 6 ) NOT NULL
);

以上命令即是建立第一张数据表的命令,注意理解。建立数据表,我们也可以直接在代码窗口中输入命令也可以建立数据表。

四、字段类型(列类型)

1、字段的大类型有三种:数值型、字符型、日期/时间型,每一种大类型中也可以分成若干个列类型。
2、每种列类型均有以下几个特性:
(1)其中可以存放什么类型的值。
(2)值要占据多少空间,以及该值是否是定长或可变长的。
(3)该类型的值是否比较和存储
(4)此类型是否可以索引

五、学习几种常用的列类型

1、数值类型

(1)INT[ (M) ]
 说明:标准大小的整数
 允许的属性:不选(可以取正负数),UNSIGNED(无符号,取值范围增大一倍),UNSIGED ZEROFILL(在数值前自动填0),auto_increment(自动递增)
 取值范围:-2147483648 到2147483647(-231 到231-1),或者如果为UNSIGNED,则0 到4294967295(0 到232-1)
 缺省值:如果列为NULL,则为NULL;如果列为NOT FULL,则为0
 存储需求:4 字节
 同义词:INTEGER[ (M) ]

(2)FLOAT[(M,D)](M表示显示宽度,在D表示小数位数)
 说明:小浮点数;单精度(精度小于DOUBLE)
 允许的属性:ZEROFILL
 取值范围:最小非零值为±1.75494351E-38;最大非零值为±3.402823466E+38
 缺省值:如果列可为NULL,则为NULL;如果列为NOTNULL,则为0
 存储需求:4字节
 同义词:MySQL3.23版以前,FLOAT(4)为具有缺省M和D值的FLOAT的同义词。
 注释:在MySQL3.23以后,FLOAT(4)为真浮点类型(值存储为硬件所允许的完整精度,而不四舍五入为缺省的小数位数)。

(3)DOUBLE[(M,D)]
 说明:大浮点数;双精度(比FLOAT更精确)
 允许的属性:ZEROFILL
 取值范围:最小非零值为±2.2250738585072014E-308;最大非零值为±1。79769313-48623157E+308
 缺省值:如果列可为NULL,则为NULL;如果列为NOTNULL,则为0
 存储需求:8字节
 同义词:DOUBLEPRECISION[(M,D)]和REAL[(M,D)]为DOUBLE[(M,D)]的同义词。MySQL3.23版以前,FLOAT(8)为具有缺省M和D值的FLOAT的同义词。
 注释:在MySQL3.23以后,FLOAT(8)为真浮点类型(值存储为硬件所允许的完整精度,而不四舍五入为缺省的小数位数)。

2、串类型
MySQL的串类型常用来存储文本,它不但是通用的而且还能存储任何数据。可用串类型来存储最大长度可变的值,而且可以选择在处理值时是否区分大小写。

(1)CHAR(M)
 说明:0到M字节长的定长字符串。在MySQL3.23版以前,M应该为一个1到255之间的整数。而MySQL3.23版以后,M应该为一个0到255之间的整数。短于M个字符的串存储进右边补空格。长于M个字符的串存储时剪断为长度是M的串。在检索值时,去掉后跟的空格。
 允许的属性:BINARY
 允许的长度:0到M字节
 缺省值:如果列可为NULL,则为NULL;如果列为NOTNULL,则为“”
 存储需求:M字节
 比较:不区分大小写(如果具有BINARY属性,则区分大小写)

(2)VARCHAR(M)
 说明:0到M字节长的可变长字符串。M应该为1到255之间的一个整数,或者自MySQL3.23后为0到255之间的一个整数。存储时后跟的空格被去掉。存储时,大于M个字符的串剪断为M个字符。
 允许的属性:BINARY
 允许的长度:0到M字节
 缺省值:如果列可为NULL,则为NULL;如果列为NOTNULL,则为“”
 存储需求:值的长度,加上1字节用来记录长度
 比较:不区分大小写(如果具有BINARY属性,则区分大小写)

(3)TEXT
 说明:常规大小的TEXT值
 允许的属性:除通用属性外无其他属性
 允许的长度:0到65535(0到216-1)字节
 缺省值:如果列可为NULL,则为NULL;如果列为NOTNULL,则为“”
 存储需求:值的长度加上用于记录长度的2个字节
 比较:不区分大小写

(4)ENUM(“value1”,“value2”,...)
 说明:枚举,列值可赋予值列表中的某个成员
 允许的属性:除通用属性外无其他属性
 缺省值:如果列可为NULL,则为NULL;如果列为NOTNULL,则为第一个枚举值
 存储需求:对1到255个成员的枚举1个字节,对255到65535个成员的枚举2个字节
 比较:不区分大小写(MySQL3.22.1版以前区分大小写)

(5)SET(“value1”,“value2”,...)
 说明:集合,列值可赋予值列表中的零个或多个成员
 允许的属性:除通用属性外无其他属性
 缺省值:如果列可为NULL,则为NULL;如果列为NOTNULL,则为“”(空集)
 存储需求:1字节(1到8个成员的集合),2字节(9到16个成员的集合),3字节(17到24个成员的集合),4字节(25到32个成员的集合)或8字节(33到64个成员的集合)
 比较:不区分大小写(MySQL3.22.1版以前区分大小写)

3、日期和时间类型
MySQL提供以各种形式表示时间数据的类型。这些数据有日期和时间类型。有一种特殊的时间类型,它在记录更改时自动更新。还有一种用于存储年份的类型,在不需要完全的日期时使用。

(1)DATE
 说明:“YYYY-MM-DD”格式的日期
 允许的属性:除通用属性外无其他属性
 取值范围:“1000-01-01”到“9999-12-31”
 零值:“0000-00-00”
 缺省值:如果列可为NULL,则为NULL;如果列为NOTNULL,则为“0000-00-00”
 存储需求:3字节(MySQL3.22版以前为4字节)

(2)TIME
 说明:“HH:MM:SS”格式的时间(负值为“-HH:MM:SS”);表示占用的时间,但也可
 以作为日常时间
 允许的属性:除通用属性外无其他属性
 取值范围:“-838:59:59”到“838:59:59”
 零值:“00:00:00”
 缺省值:如果列可为NULL,则为NULL;如果列为NOTNULL,则为“00:00:00”
 存储需求:3字节
 注释:虽然在非法值插入TIME列时,“00:00:00”用作零值,但它也作为一个合法的值出现在正常的取值范围内

(3)YEAR
 说明:YYYY格式表示的年份
 允许的属性:除通用属性外无其他属性
 取值范围:1900到2155
 零值:0000
 缺省值:如果列可为NULL,则为NULL;如果列为NOTNULL,则为0000
 存储需求:1字节

(4)DATETIME
 说明:以“YYYY-MM-DDhh:mm:ss”格式表示的日期和时间(两个部分都需要)
 允许的属性:除通用属性外无其他属性
 取值范围:“1000-01-0100:00:00”到“9999-12-3123:59:59”
 零值:“0000-00-0000:00:00”
 缺省值:如果列可为NULL,则为NULL;如果列为NOTNULL,则为“0000-00-00 00:00:00”
 存储需求:8字节

六、输入记录
单击右窗口中的插入按钮,在出现的记录输入界面下输入数据,并选择“插入新的一行”,再单击“执行”。即可连续输入多条记录,直到选择“后退到上一页”,再单击“执行”,则结束记录的输入。

MySQL 字段数据类型/长度

1、数值类型

列类型 需要的存储量

TINYINT 1 字节

SMALLINT 2 个字节

MEDIUMINT 3 个字节

INT 4 个字节

INTEGER 4 个字节

BIGINT 8 个字节

FLOAT(X) 4 如果 X < = 24 或 8 如果 25 < = X < = 53

FLOAT 4 个字节

DOUBLE 8 个字节

DOUBLE PRECISION 8 个字节

REAL 8 个字节

DECIMAL(M,D) M字节(D+2 , 如果M < D)

NUMERIC(M,D) M字节(D+2 , 如果M < D)

MySQL 的数值数据类型可以大致划分为两个类别,一个是整数,另一个是浮点数或小数。许多不同的子类型对这些类别中的每一个都是可用的,每个子类型支持不同大小的数据,并且 MySQL 允许我们指定数值字段中的值是否有正负之分或者用零填补。

表列出了各种数值类型以及它们的允许范围和占用的内存空间。

类型 大小 范围(有符号) 范围(无符号) 用途

TINYINT 1 字节 (-128,127) (0,255) 小整数值

SMALLINT 2 字节 (-32 768,32 767) (0,65 535) 大整数值

MEDIUMINT 3 字节 (-8 388 608,8 388 607) (0,16 777 215) 大整数值

INT或INTEGER 4 字节 (-2 147 483 648,2 147 483 647) (0,4 294 967 295) 大整数值

BIGINT 8 字节 (-9 233 372 036 854 775 808,9 223 372 036 854 775 807) (0,18 446 744 073 709 551 615) 极大整数值

FLOAT 4 字节 (-3.402 823 466 E+38,1.175 494 351 E-38),0,(1.175 494 351 E-38,3.402 823 466 351 E+38) 0,(1.175 494 351 E-38,3.402 823 466 E+38) 单精度

浮点数值

DOUBLE 8 字节 (1.797 693 134 862 315 7 E+308,2.225 073 858 507 201 4 E-308),0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308) 0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308) 双精度

浮点数值

DECIMAL 对DECIMAL(M,D) ,如果M>D,为M+2否则为D+2 依赖于M和D的值 依赖于M和D的值 小数值

INT 类型

在 MySQL 中支持的 5 个主要整数类型是 TINYINT,SMALLINT,MEDIUMINT,INT 和 BIGINT。这些类型在很大程度上是相同的,只有它们存储的值的大小是不相同的。

MySQL 以一个可选的显示宽度指示器的形式对 SQL 标准进行扩展,这样当从数据库检索一个值时,可以把这个值加长到指定的长度。例如,指定一个字段的类型为 INT(6),就可以保证所包含数字少于 6 个的值从数据库中检索出来时能够自动地用空格填充。需要注意的是,使用一个宽度指示器不会影响字段的大小和它可以存储的值的范围。

万一我们需要对一个字段存储一个超出许可范围的数字,MySQL 会根据允许范围最接近它的一端截短后再进行存储。还有一个比较特别的地方是,MySQL 会在不合规定的值插入表前自动修改为 0。

UNSIGNED(未签署) 修饰符规定字段只保存正值。因为不需要保存数字的正、负符号,可以在储时节约一个“位”的空间。从而增大这个字段可以存储的值的范围。

ZEROFILL(零填充) 修饰符规定 0(不是空格)可以用来真补输出的值。使用这个修饰符可以阻止 MySQL 数据库存储负值。

FLOAT、DOUBLE 和 DECIMAL 类型

MySQL 支持的三个浮点类型是 FLOAT、DOUBLE 和 DECIMAL 类型。FLOAT 数值类型用于表示单精度浮点数值,而 DOUBLE 数值类型用于表示双精度浮点数值。

与整数一样,这些类型也带有附加参数:一个显示宽度指示器和一个小数点指示器。比如语句 FLOAT(7,3) 规定显示的值不会超过 7 位数字,小数点后面带有 3 位数字。

对于小数点后面的位数超过允许范围的值,MySQL 会自动将它四舍五入为最接近它的值,再插入它。

DECIMAL 数据类型用于精度要求非常高的计算中,这种类型允许指定数值的精度和计数方法作为选择参数。精度在这里指为这个值保存的有效数字的总个数,而计数方法表示小数点后数字的位数。比如语句 DECIMAL(7,3) 规定了存储的值不会超过 7 位数字,并且小数点后不超过 3 位。

忽略 DECIMAL 数据类型的精度和计数方法修饰符将会使 MySQL 数据库把所有标识为这个数据类型的字段精度设置为 10,计算方法设置为 0。

UNSIGNED(未签署) 和 ZEROFILL(零填充) 修饰符也可以被 FLOAT、DOUBLE 和 DECIMAL 数据类型使用。并且效果与 INT 数据类型相同。