当前位置: 首页 > news >正文

Mysql中数据类型括号中的数字代表的含义

相信大家不管是看别人的代码,还是自己的代码总会在定义表的数据类型时,会需要在数据类型后面加一个括号,里面写一个参数,例如int(3),smallint(5),char(5)等,但是括号里面的数字到底是什么意思呢?我以前也是只会用,但是感觉自己是在瞎用,根本没有注意到重点,今天写个博客记录下重点。

 

首先我们先来讲讲字符和字节的概念。

字节(Byte)是一种计量单位,表示数据量多少,它是计算机信息技术用于计量存储容量的一种计量单位。

 字符是指计算机中使用的文字和符号,比如1、2、3、A、B、C、~!·#¥%……—*()——+、,中,国等等。

 字符和字节不存在绝对的关系,只是在不同的编码格式里,对应的比值不一样。比如:

1.UTF-8编码中,一个英文字符等于一个字节,一个中文(含繁体)字符等于三个字节。

2.Unicode编码中,一个英文等于两个字节,一个中文(含繁体)字符等于两个字节。

符号:英文标点占一个字节,中文标点占两个字节。举例:英文句号“.”占1个字节的大小,中文句号“。”占2个字节的大小。

3.UTF-16编码中,一个英文字母字符或一个汉字字符存储都需要2个字节(Unicode扩展区的一些汉字存储需要4个字节)。

4.UTF-32编码中,世界上任何字符的存储都需要4个字节。

 

所有你看见的单个字:a,啊,都叫字符。

 

char和varchar括号中的数字含义。

char的列长度是固定的,char的长度可选范围在0-255字符之间。也就是char最大能存储255个字符.

varchar的列长度是可变的,在mysql5.0.3之前varchar的长度范围为0-255字符,mysql5.0.3之后varchar的长度范围为0-65535个字节.

CHAR(M)定义的列的长度为固定的,M取值可以为0-255之间,当保存CHAR值时,在它们的右边填充空格以达到指定的长度。当检索到CHAR值时,尾部的空格被删除掉。在存储或检索过程中不进行大小写转换。CHAR存储定长数据很方便,CHAR字段上的索引效率级高,比如定义char(10),那么不论你存储的数据是否达到了10个字符,都要占去10个字符的空间,不足的自动用空格填充。

VARCHAR(M)定义的列的长度为可变长字符串,VARCHAR的最大有效长度由最大行大小和使用的字符集确定。整体最大长度是65,532字节。VARCHAR值保存时不进行填充。当值保存和检索时尾部的空格仍保留,符合标准SQL。varchar存储变长数据,但存储效率没有CHAR高。如果一个字段可能的值是不固定长度的,我们只知道它不可能超过10个字符,把它定义为 VARCHAR(10)是最合算的。VARCHAR类型的实际长度是它的值的实际长度+1。为什么"+1"呢?这一个字节用于保存实际使用了多大的长度。从空间上考虑,用varchar合适;从效率上考虑,用char合适,关键是根据实际情况找到权衡点。

简单来说:varchar(m)里面表示的是长度,例如:varchar(5)表示最大可存储5个中文或5个英文字母。 

 

int smallint等数据类型括号中的数字含义。

类型  
大小范围(有符号)范围(无符号)用途
TINYINT1字节(-128,127)(0,255)小整数值
SMALLINT2字节(-32 768,32 767)(0,65535)大整数值
MEDIUMINT3字节(-8 388 608,8 388 607)
(0,16 777 215)
大整数值
INT4字节
(-2 147 483 648,2 147 483 647) (0,4 294 967 295) 
(0,4 294 967 295) 
大整数值
BIGINT8字节
(-9 233 372 036 854 775 808,9 223 372 036 854 775 807)
(0,18 446 744 073 709 551 615)
极大整数值

这些类型,是定长的,其容量是不会随着后面的数字而变化的,比如int(11)和int(8),都是一样的占4字节。tinyint(1)和tinyint(10)也都占用一个字节。

那么后面的11和8,有啥用呢。

数据类型(m)中的m不是表示的数据长度,而是表示数据在显示时显示的最小长度。tinyint(1) 这里的1表示的是 最短显示一个字符。tinyint(2) 这里的2表示的是 最短显示两个字符。

当字符长度(m)超过对应数据类型的最大表示范围时,相当于啥都没发生;

当字符长度(m)小于对应数据类型的表示范围时,就需要指定拿某个字符来填充,比如zerofill(表示用0填充),

设置tinyint(2) zerofill 你插入1时他会显示01;设置tinyint(4) zerofill 你插入1时他会显示0001。

即使你建表时,不指定括号数字,mysql会自动分配长度:int(11)、tinyint(4)、smallint(6)、mediumint(9)、bigint(20)。

 

推荐两篇博客:

实际验证varchar和char括号中数字表示的是字符

关于int smallint中括号中数字表示的是显示宽度

转载于:https://www.cnblogs.com/loren-Yang/p/7512258.html

相关文章:

  • python 正则匹配字母数字中的任意数字,字母
  • 大保健就是做公益?马云的一招让这个特殊群体赞不绝口
  • 儿童做家务年龄对照表,80%的父母都后悔看晚了…
  • Windows Embedded Standard CTP发布!
  • 阿布扎比有一个“智慧港口”
  • 4000余台ElasticSearch服务器遭PoS恶意软件感染
  • Docker for Mac配置Sock5代理
  • Vue.js 上传文件(后台使用.net)
  • 微商新手如何选产品?史上最详细操作指南!
  • 深入理解javascript原型和闭包(4)——隐式原型
  • Android Studio 插件简单介绍
  • MySQL安装操作指引
  • ASP.NET中ListBox控件的使用
  • 王建宙谈互联网两大趋势:云计算和移动化
  • java反射学习一
  • Android Studio:GIT提交项目到远程仓库
  • Angular4 模板式表单用法以及验证
  • Angular6错误 Service: No provider for Renderer2
  • axios 和 cookie 的那些事
  • Java面向对象及其三大特征
  • MQ框架的比较
  • mysql 5.6 原生Online DDL解析
  • Octave 入门
  • PAT A1017 优先队列
  • React的组件模式
  • redis学习笔记(三):列表、集合、有序集合
  • 好的网址,关于.net 4.0 ,vs 2010
  • 理清楚Vue的结构
  • 面试遇到的一些题
  • 算法-图和图算法
  • 吐槽Javascript系列二:数组中的splice和slice方法
  • 微信小程序设置上一页数据
  • 一个普通的 5 年iOS开发者的自我总结,以及5年开发经历和感想!
  • 因为阿里,他们成了“杭漂”
  • 用jQuery怎么做到前后端分离
  • 3月7日云栖精选夜读 | RSA 2019安全大会:企业资产管理成行业新风向标,云上安全占绝对优势 ...
  • Semaphore
  • 长三角G60科创走廊智能驾驶产业联盟揭牌成立,近80家企业助力智能驾驶行业发展 ...
  • 我们雇佣了一只大猴子...
  • ​LeetCode解法汇总1276. 不浪费原料的汉堡制作方案
  • ​LeetCode解法汇总307. 区域和检索 - 数组可修改
  • # Apache SeaTunnel 究竟是什么?
  • (1)Map集合 (2)异常机制 (3)File类 (4)I/O流
  • (1/2) 为了理解 UWP 的启动流程,我从零开始创建了一个 UWP 程序
  • (C++)八皇后问题
  • (Redis使用系列) Springboot 使用redis实现接口Api限流 十
  • (附源码)springboot家庭财务分析系统 毕业设计641323
  • (官网安装) 基于CentOS 7安装MangoDB和MangoDB Shell
  • (三) diretfbrc详解
  • ***linux下安装xampp,XAMPP目录结构(阿里云安装xampp)
  • .net core 实现redis分片_基于 Redis 的分布式任务调度框架 earth-frost
  • .Net MVC4 上传大文件,并保存表单
  • .NET 程序如何获取图片的宽高(框架自带多种方法的不同性能)
  • .NET 设计一套高性能的弱事件机制
  • .NET设计模式(11):组合模式(Composite Pattern)