做个调查:大家在 Go 项目中, MySQL 定义 varchar 类型,一般定义为 default null 还是 not null default '' 呢? (当数据允许空的时候) - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
inSpring
V2EX    Go 编程语言

做个调查:大家在 Go 项目中, MySQL 定义 varchar 类型,一般定义为 default null 还是 not null default '' 呢? (当数据允许空的时候)

  •  
  •   inSpring 147 天前 2455 次点击
    这是一个创建于 147 天前的主题,其中的信息可能已经有所发展或是发生改变。
    第 1 条附言    147 天前
    如果字段类型是 datetime ,(比如有个字段表示"签到时间")你们一般怎么定义 default 的值呢?
    14 条回复    2025-05-27 21:16:07 +08:00
    k9982874
        1
    k9982874  
       147 天前
    null 和‘’是两种类型,不能互相替换,在数据库中的存储方式及表意都不一样
    根据实际业务需求来
    lizhenda
        2
    lizhenda  
       147 天前
    如果定义为 null 在 go 还要特殊处理下,直接 not null 默认为空字符串即可。
    Configuration
        3
    Configuration  
       147 天前   1
    我们都是 not null default '',null 值在处理 != 或 not like 的时候跟实际需求不一致
    qloog
        4
    qloog  
       147 天前
    用的更多的是:not null default '',在代码里里更方便做各种判断
    Joker520
        5
    Joker520  
       147 天前
    直接空字符串''
    yinmin
        6
    yinmin  
       147 天前 via iPhone
    null 和’’是 2 个概念,例如填表字段,’’表示完成填表操作了,提交空字符串; null 表示没有完成填表操作。

    类似 decimal 的 null 和 0 ,考试成绩填 0 表示考了 0 分,填 null 表示缺考。

    有些字段不允许空缺,可以不要 null 。具体根据实际业务场景来确认是否要 null 。
    june4
        7
    june4  
       147 天前
    null 还对唯一索引不好使,特别是有联合索引用了 null 时很容易中坑
    me262
        8
    me262  
       147 天前
    not null default ''
    everhythm
        9
    everhythm  
       147 天前
    not null default ''

    大部分数据库应该都不鼓励用 null 了,在索引、计算、排序、连表的时候 null 会有各种各样的问题。

    go 里面大部分变量初始化都给了默认值,用 null 的话还得写 is null ,漏写就比较蛋疼。
    codehz
        10
    codehz  
       147 天前
    null 可以用在联合 unique 约束中表示空缺(因为比较的时候会忽略 null ),但要记得使用触发器或者静态约束来避免插入全空的值
    这种模式在表达一些很特殊的关系的时候有奇效
    zhazi
        11
    zhazi  
       147 天前   1
    @yinmin 烂代码从你开始,通过数据类型去控制业务
    CodeCodeStudy
        12
    CodeCodeStudy  
       146 天前   1
    我总结了 mysql 字段不使用 null 的理由

    1 、比如文章点击量加 1 ,column_name = column_name + 1 ,如果把字段设成 null ,并且插入数据时没指明 column_name = 0 ,那么+1 操作不起作用;
    2 、count(column_name)时,null 的列不包含在内,count(*)则包含 null 的列在里面
    3 、计算多列时,如 SELECT id, click1+click2 as click FROM `foo` 如果两个点击量有一个为 null ,那么相加结果就是 null
    4 、如果有比较条件,比如 where < 10 ,如果为 null 的话则不包含在内
    5 、min(column_name), max(column_name)如果字段有值,则用值比较,如果字段没有值,都是 null 的时候,则为 null

    总结:不能运算,不能比较,慢


    对于字符串来说,大多数情况下还是用空字符串
    changz
        13
    changz  
       146 天前 via Android
    可以类比下 optional
    kingcanfish
       
    kingcanfish  
       140 天前
    就问一个问题 比如说现在表要加一列, 现在数据很多, 考虑性能问题 新加的列设置成 null 还是 not null
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2983 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 37ms UTC 13:40 PVG 21:40 LAX 06:40 JFK 09:40
    Do have faith in what you're doing.
    ubao 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