V2EX = way to explore
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 · 2020-10-17 10:50:30 +08:00 · 3249 次点击
    这是一个创建于 1523 天前的主题,其中的信息可能已经有所发展或是发生改变。

    发现 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 条回复    2020-10-18 16:17:20 +08:00
    user8341
        1
    user8341  
       2020-10-17 10:57:08 +08:00
    其实没分那么细吧。都是 unsigned int
    hbolive
        2
    hbolive  
       2020-10-17 10:57:36 +08:00   ❤️ 1
    你定义的是一个 int 整形的数据,其存储范围:- 2147483648 至 2147483647 或 0 至 4294967295,这个是固定的而不是你定义的,括号中的是显示长度,你把它理解为了“我定义它显示 1 位”。。
    hbolive
        3
    hbolive  
       2020-10-17 10:58:37 +08:00
    @hbolive 最后句是:你把它理解为了“我定义它只能存储 1 位的数字”
    myevery
        4
    myevery  
    OP
       2020-10-17 11:01:03 +08:00
    @hbolive 是啊,我是这样理解的,难道不是这么理解么。
    如果不是,那个 1 是不是就没意义了呢。
    lovecy
        5
    lovecy  
       2020-10-17 11:03:43 +08:00
    mysql 只有前缀带 var 的才允许你定义数量,其他的都是固定的。

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

    你应该用 tinyint smallint int bigint 这些
    lovecy
        9
    lovecy  
       2020-10-17 14:45:41 +08:00
    @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
    bear2000
        10
    bear2000  
       2020-10-18 11:22:27 +08:00
    括号里显示的是指显示的位数,不是指能存储的位数
    sockball07
        11
    sockball07  
       2020-10-18 16:17:20 +08:00
    面试常考🤧
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1048 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 22:46 · PVG 06:46 · LAX 14:46 · JFK 17:46
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.