发现 mysql 定义的数据类型不管用,定义的整数 1 位,也可以插入多位数字 - V2EX
MySQL 5.5 Community Server
MySQL 5.6 Community Server
Percona Configuration Wizard
XtraBackup 搭建主从复制
Great Sites on MySQL
Percona
MySQL Performance Blog
Severalnines
推荐管理工具
Sequel Pro
phpMyAdmin
推荐书目
MySQL Cookbook
MySQL 相关项目
MariaDB
Drizzle
参考文档
http://mysql-python.sourceforge.net/MySQLdb.html
myevery
V2EX    MySQL

发现 mysql 定义的数据类型不管用,定义的整数 1 位,也可以插入多位数字

  •  
  •   myevery Oct 17, 2020 3790 views
    This topic created in 2033 days ago, the information mentioned may be changed or developed.

    发现 mysql 定义的数据类型不管用,定义的整数 1 位,也可以插入多位数字

    create table t1 (id int(1)); insert into t1 (id) values (-1); insert into t1 (id) values (-123); insert into t1 (id) values (-12345); insert into t1 (id) values (23); insert into t1 (id) values (123); insert into t1 (id) values (12345);

    完全不报错,可以正常写入! 这是为啥,这么不严谨么,难道是为了容错!

    11 replies    2020-10-18 16:17:20 +08:00
    9LCRwvU14033RHJo
        1
    9LCRwvU14033RHJo  
       Oct 17, 2020
    其实没分那么细吧。都是 unsigned int
    hbolive
        2
    hbolive  
       Oct 17, 2020   1
    你定义的是一个 int 整形的数据,其存储范围:- 2147483648 至 2147483647 或 0 至 4294967295,这个是固定的而不是你定义的,括号中的是显示长度,你把它理解为了“我定义它显示 1 位”。。
    hbolive
        3
    hbolive  
       Oct 17, 2020
    @hbolive 最后句是:你把它理解为了“我定义它只能存储 1 位的数字”
    myevery
        4
    myevery  
    OP
       Oct 17, 2020
    @hbolive 是啊,我是这样理解的,难道不是这么理解么。
    如果不是,那个 1 是不是就没意义了呢。
    lovecy
        5
    lovecy  
       Oct 17, 2020
    mysql 只有前缀带 var 的才允许你定义数量,其他的都是固定的。

    另外能学一下 markdown 语法排个版么,排版乱+感叹号看着不舒服。
    myevery
        6
    myevery  
    OP
       Oct 17, 2020
    @lovecy 好的好的,谢谢!
    hanzhao
        7
    hanzhao  
       Oct 17, 2020   1
    2 楼说的有一点纠正:int(M) M 是“最小显示长度”,可以配合 zerofill 属性使用 int(2) 1=>01 11=>11 111=>111
    tairan2006
        8
    tairan2006  
       Oct 17, 2020 via Android
    那个是显示位宽

    你应该用 tinyint smallint int bigint 这些
    lovecy
        9
    lovecy  
       Oct 17, 2020
    @myevery #2#7#8 说的都对,我查了一下,这个貌似是 MYSQL 设计留下来的没啥用的东西,只在字段有 zerofill 的时候,查询结果数字如果不足位数,前面补 0
    比如 id int(6) zerofill,你存 1,123,1234 查询出来的结果就是 000001,000012,001234
    比如 id int(2) zerofill,你存 1,123,1234 查询出来的结果就是 01,12,1234
    birdkyle79
        10
    birdkyle79  
       Oct 18, 2020
    括号里显示的是指显示的位数,不是指能存储的位数
    sockball07
        11
    sockball07  
       Oct 18, 2020
    面试常考
    About     Help     Advertise     Blog     API     FAQ     Solana     1187 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 104ms UTC 23:18 PVG 07:18 LAX 16:18 JFK 19:18
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86