MYSQL 数据类型

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

标签:MYSQL/数据库/DBA/整形/字符串/

概述  

当你学习一门数据库语言的时候了解其数据类型尤为的重要,接下来会详细讲解MYSQL支持的每一种数据类型。

所有的测试基于MYSQL 5.6以上版本。

 

目录

数据类型

整形

 

以TINYINT为例,该数据类型是1个字节长度,一个字节=8bit,所以对于无符号存储的数值最大=11111111=2的8次方-1=255,对于有符号就是[-128-127]

 

在整形数值类型中比较常用到的有INT、BIGINT这两种类型,可以指定在数据类型后面加上类型的长度例如INT(3),默认INT数据类型是11位长度,即INT(11)。

CREATE TABLE Tb(ID INT,ID1 INT(3));

DESC Tb;

 

 

还可以在定义数据类型的时候使用zerofill,即以0填充不够的空间。语法如下:

ALTER TABLE Tb modify ID1 INT(5) zerofill;

INSERT INTO Tb VALUES(1,1);

SELECT * FROM Tb;

DESC Tb;

 如果插入的数据长度大于数据类型的长度会不会截断呢?

INSERT INTO Tb VALUES(2,2222222);

SELECT * FROM Tb;

如果不是填充字段,插入的数据长度大于字段数据类型的长度则无法插入。

INSERT INTO Tb VALUES(222222222222222,2222222);

整形中的AUTO_INCREMENT属性:一个表中只能存在一个AUTO_INCREMENT列,该列默认是非空,且该列必须定义成PRIMARY KEY 或者UNIQUE建,AUTO_INCREMENT值默认从1开始。

CREATE TABLE Ta(
ID INT AUTO_INCREMENT  NOT NULL ,PRIMARY KEY(ID));

DESC Ta;

INSERT INTO Ta VALUES();

 

浮点型

浮点数如果不写精度和标度(M,D)【数值总长M位(不包含小数点),小数点后D位】,会按照实际精度值显示,如果存在精度和标度,如果小数点的位数超过D会自动插入四舍五入的结果不会返回错误,如果总长度超过M-D位会插入失败。

 

CREATE TABLE TP(ID1 FLOAT,ID2 FLOAT(4,2),ID3 DOUBLE,ID4 DOUBLE(4,2));

INSERT INTO TP VALUES(1.5678,1.5678,1.5678,1.5678);

SELECT * FROM TP;

定点类型

定点数如果不写精度和标度会以默认值decimal(10,0)来存储,写精度和标度(M,D)【数值总长M位(不包含小数点),小数点后D位】,会按照实际精度值显示,如果存在精度和标度,如果小数点的位数超过D会自动插入四舍五入的结果并返回错误,如果总长度超过M-D位会插入失败。。

CREATE TABLE TP1(ID1 DECIMAL,ID2 DECIMAL(4,2));

INSERT INTO TP1 VALUES(1.5678,1.5678);

SELECT * FROM TP1;

插入的过程中会报数据被截断“You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'warning' at line 1”


位类型

位类型主要主要用来存放二进制数,SELECT查询默认显示10进制,可以使用bin()(显示二进制格式)、hex()(显示十六进制格式)函数来进行查询.

CREATE TABLE T(ID BIT(4));

INSERT INTO T VALUES(2);

SELECT BIN(ID),hex(ID) FROM T;

字符串类型

 

1、char(n)和varchar(n)中括号中n代表字符的个数,并不代表字节个数,所以当使用了中文的时候(UTF8)意味着可以插入m个中文,但是实际会占用m*3个字节。

 

2、同时char和varchar最大的区别就在于char不管实际value都会占用n个字符的空间,而varchar只会占用实际字符应该占用的空间+1,并且实际空间+1<=n。

 

3、超过char和varchar的n设置后,字符串会被截断。

 

4、char的上限为255字节,varchar的上限65535字节,text的上限为65535。

 

5、char在存储的时候会截断尾部的空格,varchar和text不会。

 

6、varchar会使用1-3个字节来存储长度,text不会。

 

在mysql5.6中varchar数据类型默认一个中文算一个长度,一个英文也算一个长度。而函数length()默认一个英文算一个长度,一个中文算三个长度。

时间日期类型

默认系统日期:CURRENT_TIMESTAMP,当前日期now(),

时间值类型默认有两个属性,分别是CURRENT_TIMESTAMP 和ON UPDATE CURRENT_TIMESTAMP两种,使用情况分别如下:

复制代码
1. CURRENT_TIMESTAMP 

当要向数据库执行insert操作时,如果有字段属性设为 CURRENT_TIMESTAMP,则无论这个字段有木有set值都插入当前系统时间。

2. ON UPDATE CURRENT_TIMESTAMP

当当前行有UPDATE操作时无论该操作是否是更新包含‘ON UPDATE CURRENT_TIMESTAMP’数学的字段,该字段的值也会被更改。
复制代码

总结

每个版本的数据类型在长度上面可能会存在差异,如果没把握可以使用help 命令查询当前版本的数据类型的信息,使用help 'data types'查询当前版本的所有数据类型,使用help 'char'可以查询char数据类型的信息。

注意:类似char(m)、varchar(m)、binary(m)这里的m指的不是字节而是字符个数,在utf8中一个中文也算一个字符,所以可以存储m个中文,但是实际的物理存储还是根据官方规定的数据类型占用的字节来存储,而不是这里的字符数,具体的数据类型存储锁占用的字节参考:http://dev.mysql.com/doc/refman/5.7/en/storage-requirements.html

 

 






本文转自pursuer.chen(陈敏华)博客园博客,原文链接:http://www.cnblogs.com/chenmh/p/4565986.html,如需转载请自行联系原作者

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2月前
|
关系型数据库 MySQL 数据库
MySQL数据库基础(数据库操作,常用数据类型,表的操作)
MySQL数据库基础(数据库操作,常用数据类型,表的操作)
38 5
|
7月前
|
存储 关系型数据库 MySQL
MySQL数据类型详解及实例应用
MySQL数据类型详解及实例应用
|
6月前
|
存储 关系型数据库 MySQL
MySQL数据库的数据类型、语法和高级查询
MySQL数据库的数据类型、语法和高级查询
81 0
|
2月前
|
存储 关系型数据库 MySQL
MySQL支持多种数据类型
MySQL支持多种数据类型
126 3
|
2月前
|
存储 关系型数据库 MySQL
什么是mysql的数据类型?
什么是mysql的数据类型?
49 2
|
2月前
|
存储 关系型数据库 MySQL
MySQL数据类型
MySQL数据类型
55 2
|
7月前
|
SQL 存储 关系型数据库
RDS for MySQL的SQL分类与数据类型
小明需在MySQL中管理商品信息,使用SQL完成业务操作。SQL分为DQL(查询)、DML(增删改)、DDL(定义)、DCL(权限控制)和TCL(事务)五大类。DDL用于创建、修改和删除数据库结构,DML处理数据,DCL控制权限,TCL管理事务,DQL则用于查询数据。MySQL有多种数据类型,如数值型(整数、小数)、日期型和字符串型等,选择合适的数据类型是高效开发的关键。
77 0
|
4月前
|
关系型数据库 MySQL Linux
数据类型和运算符(MySQL服务器的安装,MySQL客户端,数据类型,运算符,MySQL的语法规范)
无论是对于初学者还是有经验的开发者,了解MySQL的安装、客户端使用、数据类型、运算符和语法规范都是至关重要的。这不仅有助于高效地管理和查询数据,而且对于设计和实现数据库解决方案来说是基础工作。通过深入学习和实践这些知识,您可以更好地发挥MySQL数据库的强大功能。
36 2
|
4月前
|
存储 关系型数据库 MySQL
MySQL 中的 BLOB 数据类型深入解析
【8月更文挑战第31天】
543 0
|
4月前
|
存储 关系型数据库 MySQL