• MySQL类型属性Unsigned与ZeroFill


    1. Unsigned 就是将数字类型无符号化。

    int的类型范围是-2147483648~2147483647, int unsigned的类型范围是0~4294967295

    Unsigned也可能带来负面的影响,例如:

    CREATE TABLE T(a int unsigned,b int unsigned)

    INSERT INTO T SELECT 1,2

    SElECT a-b FROM T会是什么结果呢,会是-1吗,答案是不确定的,在MAC系统中会报错,

    在linux系统中结果为4294967295,所以尽量不要使用unsigned,但是这并不算是bug,可以参考MySQL技术内幕的解释

    怎样获得-1值呢,只要对SQL_Mode这个参数设置即可

    SET SQL_Mode='NO_UNSIGNED_SUBTRACTION';

    2. ZeroFill,如果宽度小于设定的值则自动填充0

    ALTER TABLE T CHANGE a a int(4) unsigned zerofill;

    select a from T

    结果为0001

  • 相关阅读:
    2001.3.9 每日总结
    2021.3.5
    2021.3.4每日总结
    2021.3.3每日总结
    每日总结2021.3.2
    2021.1.13
    2021.1.12
    PodPreset
    ingress-nginx安装
    RBAC
  • 原文地址:https://www.cnblogs.com/qianlixing/p/4472234.html
Copyright © 2020-2023  润新知