Heim  >  Fragen und Antworten  >  Hauptteil

Was ist der funktionale Unterschied zwischen dem Aktualisierungsvorgang und dem Ersetzungsvorgang, wenn ein MySQL-Primärschlüsselkonflikt auftritt (wie in der Abbildung dargestellt)?

曾经蜡笔没有小新曾经蜡笔没有小新2690 Tage vor850

Antworte allen(2)Ich werde antworten

  • 世界只因有你

    世界只因有你2017-06-07 09:27:03

    INSERT ... ON DUPLICATE KEY UPDATEREPLACE是有区别的,前者INSERT失败后执行UPDATE,后者相当于DELETE再INSERT,原来整行都消失哦!

    具体而言,如果你的表有3列的话:

    id name alias
    1  王五 王二麻子
    

    这两句的效果是不一样的:

    INSERT INTO pri (id, name) VALUES (1, '李四') ON DUPLICATE KEY UPDATE name = '李四'
    
    REPLACE INTO pri (id, name) VALUES (1, '李四')
    

    前者alias没变,后者却会变成null。

    Antwort
    0
  • 迷茫

    迷茫2017-06-07 09:27:03

    insert into on duplicate update 是在原纪录上进行操作
    replace 判断如果有重复的话,先进行删除操作,再进行插入操作

    Antwort
    0
  • StornierenAntwort