mysql day类型_mysql 数据类型day43

本文详细介绍了 MySQL 中的数值类型,包括整数类型(TINYINT, INT, BIGINT)、浮点型(FLOAT, DOUBLE, DECIMAL)以及字符串类型(CHAR, VARCHAR)。还提到了日期时间类型和枚举、集合类型,并探讨了不同类型在精度和存储空间上的差异。
摘要由CSDN通过智能技术生成

数据类型

一数值类型

1 整数类型 默认是有符号的

unsigned 没有符号 zerofill0t

小整数 TINYINT [(m)] 1个字节 8bit 2**8 256

m 最多3位 最低 -128 最高255 用于保存一些范围的整数数值范围

有符号-128 - 127

无符号(unsigned)

0-255

整数 INT [(m)] 4个字节 32bit 2**32 4294967295

m 最多11位包括符号 默认只能是10位

最低 -2147483648 最高4294967295

有符号 -2147483648 ~ 2147483647

无符号(unsigned)

0-4294967295

eb66cefc71b6e2f540e355f3f99be38a.png

大整数 bigint[(m)] 8字节 2**64

大整数,数据类型用于保存一些范围的整数数值范围:

有符号:

-9223372036854775808 ~ 9223372036854775807

无符号:

0 ~ 18446744073709551615

有符号和无符号的最大数字需要的显示宽度均为10,而针对有符号的最小值则需要11位才能显示完全,

所以int类型默认的显示宽度为11是非常合理的

最后:整形类型,其实没有必要指定显示宽度,使用默认的就ok

2 浮点型

float(M,D) M

定义:

单精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。m最大值为255,d最大值为30

DOUBLE[(M,D)] [UNSIGNED] [ZEROFILL]

定义:

双精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。m最大值为255,d最大值为30

有符号:

-1.7976931348623157E+308 to -2.2250738585072014E-308

2.2250738585072014E-308 to 1.7976931348623157E+308

无符号:

2.2250738585072014E-308 to 1.7976931348623157E+308

精确度:

****随着小数的增多,精度比float要高,但也会变得不准确 ****

decimal[(m[,d])] [unsigned] [zerofill]

定义:

准确的小数值,m是数字总个数(负号不算),d是小数点后个数。 m最大值为65,d最大值为30。

精确度:

**** 随着小数的增多,精度始终准确 ****

对于精确数值计算时需要用此类型

decaimal能够存储精确值的原因在于其内部按照字符串存储。

8d358962c663404d172d210d7a363d45.png

准确度一次增加

二 字符串类型

1 char类型:定长,简单粗暴,浪费空间,存取速度快 最长是10位

字符长度范围:0-255(一个中文是一个字符,是utf8编码的3个字节)

存储:

存储char类型的值时,会往右填充空格来满足长度

例如:指定长度为10,存>10个字符则报错,存<10个字符则用空格填充直到凑够10个字符存储

2 varchar类型:变长,精准,节省空间,存取速度慢

字符长度范围:0-65535(如果大于21845会提示用其他类型 。mysql行最大限制为65535字节,字符编码为utf-8:

三 日期类型

YEAR

DATE

TIME

DATETIME

TIMESTAMP

YEAR

YYYY(1901/2155)

DATE

YYYY-MM-DD(1000-01-01/9999-12-31)

TIME

HH:MM:SS('-838:59:59'/'838:59:59')

DATETIME

YYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59 Y)

TIMESTAMP

YYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某时)

四 枚举类型和集合类型

enum 单选 只能在给定的范围内选一个值,如性别 sex 男male/女female

set 多选 在给定的范围内可以选择一个或一个以上的值(爱好1,爱好2,爱好3...)

enum类型

CREATE TABLE shirts (

name VARCHAR(40),

size ENUM('x-small', 'small', 'medium', 'large', 'x-large')

);

INSERT INTO shirts (name, size) VALUES ('dress shirt','large'),

('t-shirt','medium'),

('polo shirt','small');

集合类型(set)

A SET column can have a maximum of 64 distinct members.

示例:

CREATE TABLE myset (col SET('a', 'b', 'c', 'd'));

INSERT INTO myset (col) VALUES ('a,d'), ('d,a'), ('a,d,a'), ('a,d,d'), ('d,a,d');

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值