mysql 添加一条数据,需要判断数据是否重复。用组合索引好,还是查询数据后代码判断比较好,还是说有其他方法 - V2EX
duoyuanyz
V2EX    Java

mysql 添加一条数据,需要判断数据是否重复。用组合索引好,还是查询数据后代码判断比较好,还是说有其他方法

  •  1
     
  •   duoyuanyz Jul 13, 2020 4493 views
    This topic created in 2152 days ago, the information mentioned may be changed or developed.
    19 replies    2020-07-14 09:25:38 +08:00
    qsbaq
        1
    qsbaq  
       Jul 13, 2020
    感觉用异常处理方便些,只管插入就行了。
    qsbaq
        2
    qsbaq  
       Jul 13, 2020
    当然得设置唯一键
    playniuniu
        3
    playniuniu  
       Jul 13, 2020 via Android
    设置唯一索引,如果数据可以覆盖,就用 sql 里面的 replace into,否则就 insert into,看然后抓报错
    takemeaway
        4
    takemeaway  
       Jul 13, 2020
    不对吧,用异常那得是唯一索引啊,数据不可能都做索引吧。

    再说了重复分很多种,单 KEY 还是多 KEY 重复呢?
    zsdroid
        5
    zsdroid  
       Jul 13, 2020   1
    有逻辑删除需求的,唯一键会特别坑。
    1018ji
        6
    1018ji  
       Jul 13, 2020
    判断是否重复,然后的业务逻辑是啥?
    rr41ns
        7
    rr41ns  
       Jul 13, 2020
    联合唯一索引?
    jugelizi
        8
    jugelizi  
       Jul 13, 2020 via iPhone
    伪删除的坑埋了
    raysmond
        9
    raysmond  
       Jul 13, 2020   1
    得是数据库唯一索引才行。代码单个线程逻辑判断不行的,多线程和分布式环境下不适用。
    VictorJing94
        10
    VictorJing94  
       Jul 13, 2020
    unique 约束啊
    passerbytiny
        11
    passerbytiny  
       Jul 13, 2020 via Android
    看业务复杂度,简单的就主键 /唯一+捕获“唯一性冲突”异常,复杂点的就要先查出来再判断。但你问得是组合索引,说明不是单个字段,那业务复杂度就不会简单,必须选后者。
    littlewing
        12
    littlewing  
       Jul 13, 2020 via iPhone
    数据重复的定义是啥?是只要 key 重复就算还是整行数据所有字段都相等?
    realpg
        13
    realpg  
    PRO
       Jul 13, 2020
    unique index
    insert ignore
    获取 insert id
    FFFire
        14
    FFFire  
       Jul 13, 2020
    不是特别要求效率的话还是查一下吧,业务上的事别埋坑
    Yuicon
        15
    Yuicon  
       Jul 13, 2020
    加全局锁 然后查一遍插入
    Tokiomi
        16
    Tokiomi  
       Jul 13, 2020
    互联网没有物理删除
    wangsilence
        17
    wangsilence  
       Jul 13, 2020
    建议使用逻辑,唯一索引不会使用 change buffer, 会影响插入效率
    cs3230524
        18
    cs3230524  
       Jul 13, 2020 via Android
    About     Help     Advertise     Blog     API     FAQ     Solana     5370 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 96ms UTC 07:01 PVG 15:01 LAX 00:01 JFK 03:01
    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