项目场景:

最近在开发过程中,看见表设计中是thinyint字段,但对于它的范围产生了好奇


问题描述:

当我们填写超过128数值的时候,该字段就会报以下错误

Cause:com.mysql.jdbc.MysqlDataTruncation:Data truncation:Out of range value for column 'priority' at row 1;

原因分析:

从 -2^7 (-128) 到 2^7 - 1 (127) 的整型数据。存储大小为 1 个字节(不设置为UNSIGNED 无符号类型)。
所以建表的时候,真实效果其实只为tinyint(3),哪怕你建tinyint(100),他最大还是3位这么多。


在这里给大家科普一下tinyint为什么会产生这样的限制

在MySQL的数据类型中,Tinyint的取值范围是:带符号的范围是-128到127。无符号的范围是0到255(可参考官方《MySQL 5.1参考手册》

Tinyint占用1字节的存储空间,即8位(bit)。那么Tinyint的取值范围怎么来的呢?
先看无符号的情况。无符号的最小值即全部8位(bit)都为0,换算成十进制就是0,所以无符号的Tinyint的最小值为0.无符号的最大值即全部8bit都为1,11111111,换算成十进制就是255.这很好理解。
有符号的Tinyint的取值范围是怎么来的呢?在计算机中,用最高位表示符号。0表示正,1表示负,剩下的表示数值。那么有符号的8bit
最小值:
  1  1  1  1  1  1  1  1 = -127 (表示负值)
最大值:
  0  1  1  1  1  1  1  1 = +127(表示正值)

怎么有符号的最小值是-127,而不是-128呢?这就是本文要说的关键地方了,在计算机中,表示负值是用补码
为什么有符号的TINYINT的最小值是-128?虽然“-0”也是“0”,但根据正、反、补码体系,“-0”的补码和“+0”是不同的,这样就出现两个补码代表一个数值的情况。为了将补码与数字一一对应,所以人为规定“0”一律用“+0”代表。同时为了充分利用资源,就将原来本应该表示“-0”的补码规定为代表-128。


额外进行知识点拓展
mysql中int、bigint、smallint 和 tinyint的主要区别简单介绍

最近使用mysql数据库的时候遇到了多种数字的类型,主要有int,bigint,smallint和tinyint。其中比较迷惑的是int和smallint的差别,写在博客中做个记录:
使用整数数据的精确数字数据类型。
bigint
从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字)。存储大小为 8 个字节。

int
从 -2^31 (-2,147,483,648) 到 2^31 – 1 (2,147,483,647)
的整型数据(所有数字)。存储大小为 4 个字节。int 的 SQL-92 同义字为 integer。

smallint
从 -2^15 (-32,768) 到 2^15 – 1 (32,767) 的整型数据。存储大小为 2 个字节。

tinyint
从 0 到 255 的整型数据。存储大小为 1 字节。
补充:
在支持整数值的地方支持 bigint 数据类型。但是,bigint 用于某些特殊的情况,当整数值超过 int 数据类型支持的范围时,就可以采用 bigint。在 SQL Server 中,int 数据类型是主要的整数数据类型。
在数据类型优先次序表中,bigint 位于 smallmoney 和 int 之间。
只有当参数表达式是 bigint 数据类型时,函数才返回 bigint。SQL Server 不会自动将其它整数数据类型(tinyint、smallint 和 int)提升为 bigint。
int(M) 在 integer 数据类型中,M 表示最大显示宽度。在 int(M) 中,M 的值跟 int(M) 所占多少存储空间并无任何关系。和数字位数也无关系 int(3)、int(4)、int(8) 在磁盘上都是占用 4 btyes 的存储空间。

解决方案:

解决方法主要有三个
1.修改数据表字段(改为int或者其他类型)
2.前端输入框进行校验,超过数值则进行弹框提示(不友好)
3.后端数值进行校验,不符合则抛出异常提示(我用的第三种方式)

Assert.isTrue(!(rule.getPriority()!= null && rule.getPriority()>100),"支持最大优先级数为100!");

mysql中TINYINT的取值范围相关推荐

  1. tinyint 范围 mysql_MySQL中Tinyint的取值范围

    在MySQL的数据类型中,Tinyint的取值范围分两种情况:带符号的范围是-128到127,无符号的范围是0到255. Tinyint占用1字节的存储空间,即8位.那么Tinyint的取值范围怎么来 ...

  2. Mysql中bigint、int、mediumint、smallint 和 tinyint的取值范围

    Mysql中bigint.int.mediumint.smallint 和 tinyint的取值范围 引言 社区这边的业务就遇到过这个坑,由于是用的开源框架,很多表id的字段用的mediumint类型 ...

  3. mysql mediumint(8)_mysql中bigint、int、mediumint、smallint与tinyint的取值范围

    https://blog.csdn.net/github_39110707/article/details/74277381 mysql数据库设计,其中对性能优化,字段类型很重要,下面对bigint. ...

  4. mysql 中tinyint(1)

    工作中碰到了一个奇怪的问题: 创建的mysql数据表中的一个status字段 为tinyint类型,长度为1 ,comment为:0未审核 1 审核通过  -1 审核失败', 后台代码中,查询的sql ...

  5. MySql中 tinyint ,smallint,mediumint,int,bigint 与 decimal

    MySql中 tinyint,smallint,mediumint,int 与 bigint 一.容纳数据范围不同 1.tinyint(M) M默认为4,存储占1个字节 带符号的范围是-128到127 ...

  6. vue 取数组第一个值_vue遍历对象中的数组取值示例

    前几天小项目,没考虑周全,让后端改接口,改成数组中包含对象中包含数组的形式,后来越琢磨越不对,后台把所有数据放在了一个对象里,我拿弹窗数据不好拿,索性又改了回来,把后端折腾够呛,自己也折腾够呛,发上来 ...

  7. datetime 比较_Python 字典中key命中取值的两种方法性能比较!

    起步 从字典中取值有两个方法,一个是先判断key是否在字典中再取值:另一个是包裹try块中直接去取值: Python资源共享群:484031800 def use_in(d, key):if key ...

  8. python在json文件中查找指定数据_Python中json的取值 如何使用python提取json中指定字段的数据...

    python中为什么用json有什么作用 如何用python读取json里面的值啊我爱你,所以我给了你伤害我的权力,只要我能忍受,我会一直陪伴着你,但你不能伤害我太多. 数据如下,我想要读取name. ...

  9. mysql两个空值相同吗_你知道mysql中空值和null值的区别吗

    前言 最近发现带的小伙伴写sql对于空值的判断方法不正确,导致程序里面的数据产生错误,在此进行一下整理,方便大家以后正确的判断空值.以下带来示例给大家进行讲解. 建表 create table tes ...

最新文章

  1. 25个常用Matplotlib图的Python代码,收藏收藏!
  2. iOS failed to get the task for process 169
  3. HDU - 3364 Lanterns(高斯消元解方程(取模))
  4. 03 HttpServletRequest_HttpServletResponse
  5. 数据库知识:SQLServer变量相关知识介绍
  6. Linux中文件复制、删除、移动、压缩、解压命令
  7. Python Windows安装
  8. JMETER Debug Sampler
  9. python中bd是什么属性_python数据类型及其特有方法
  10. 自然语言处理——词性标注实战
  11. bootstrap 使用总结
  12. Bias and Variance with Mismatched Distributions
  13. html空格折叠原因,html – 使用Bootstrap列折叠空白
  14. 基于android端计步器软件的尝试
  15. Cookie加密10
  16. 单点登录(4):单点登录实现(附源码)
  17. python大学生信息管理系统_基于Python的高等学校社团信息管理系统
  18. 关于 Linux中系统调优的一些笔记
  19. 今天项目报错: No operations allowed after connection closed
  20. java图片不失真压缩_(转)图片等比压缩,确保不失真

热门文章

  1. jQuery框架介绍
  2. PS长图快速切片_ps基础(PS常用工具详解一)
  3. 关于one-hot编码
  4. 关于我自己 a propos de moi
  5. #c拉普拉斯展开求行列式的值
  6. python的多任务处理
  7. 可视化搭建平台的参考网格线设计
  8. UOJ#310. 【UNR #2】黎明前的巧克力
  9. violate 修饰的用法
  10. [Mysql]查看mysql默认密码