zoukankan      html  css  js  c++  java
  • mysql数据库字段bigint使用

    Mysql里有个数据类型bigint
    在java转换成实体对象时,处理不当容易出现以下异常:
    java.lang.ClassCastException: java.lang.Long cannot be cast to java.math.BigInteger

    只需要注意以下情况,就可避免此类异常:
    当数据库中该属性添加unsigned,则在对象中对应的属性类型应该为BigInteger;
    当数据库中该属性未添加unsigned,则在对象中对应的属性类型应该为Long。

    可以成功映射为Long的表用的是BIGINT(20),但是出问题的表使用的是BIGINT(20) UNSIGNED。如果不是无符号类型,BIGINT(20)的取值范围为-9223372036854775808~9223372036854775807。与Java.lang.Long的取值范围完全一致,mybatis会将其映射为Long;而BIGINT(20) UNSIGNED的取值范围是0 ~ 18446744073709551615,其中一半的数据超出了Long的取值范围,Mybatis将其映射为BigInteger。

    mysql中int、bigint、smallint 和 tinyint的区别详细介绍

    int(M) M指最大显示宽度。最大有效显示宽度是255。显示宽度与存储大小或类型包含的值的范围无关。

    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 字节。
    定义时需要注意是否使用 unsigned 符号类型,再就是显示补齐宽度值zerofill

    (M)  指定了 int 型数值显示的宽度,如果字段数据类型是 int(4),则:当显示数值 10 时,在左边要补上 “00”;

      当显示数值 100 是,在左边要补上“0”;

      当显示数值 1000000 时,已经超过了指定宽度“(4)”,不能输出,必须小于指定长度的值,不是位数是int对应的大小

      

      

  • 相关阅读:
    Vuex的使用
    vue的props属性,vue的插槽
    ES6 Promise对象
    ES6 Map对象以及Set对象
    函数作用域以及块级作用域
    组件之间的传值-$refs&$parent
    Vue中父子组件的传值
    v-on 以及v-model的修饰符以及vue的常用指令
    时间线
    readline和xreadline的区别
  • 原文地址:https://www.cnblogs.com/h-c-g/p/10007354.html
Copyright © 2011-2022 走看看