duoyuanyz
V2EX  ›  Java

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

  •  1
     
  •   duoyuanyz · Jul 13, 2020 · 4498 views
    This topic created in 2153 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   ·   1409 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 60ms · UTC 17:02 · PVG 01:02 · LAX 10:02 · JFK 13:02
    ♥ Do have faith in what you're doing.