Mysql 插入去重

    科技2022-07-13  164

    插入去重1. 插入或替换2. 插入或更新3. 插入或忽略

    插入去重

    表要求:有PrimaryKey,或者unique索引 结果:表id都会自增

    CREATE TABLE names( id INT(10) PRIMARY KEY AUTO_INCREMENT, class_id INT(10), name VARCHAR(255) UNIQUE, score INT(10), gender VARCHAR(255), )

    1. 插入或替换

    如果我们希望插入一条新记录(INSERT),但如果记录已经存在,就先删除原记录,再插入新记录。此时,可以使用REPLACE语句,这样就不必先查询,再决定是否先删除再插入:

    REPLACE INTO students (id, class_id, name, gender, score) VALUES (1, 1, '小明', 'F', 99);

    若id=1的记录不存在,REPLACE语句将插入新记录,否则,当前id=1的记录将被删除,然后再插入新记录。

    2. 插入或更新

    如果我们希望插入一条新记录(INSERT),但如果记录已经存在,就更新该记录,此时,可以使用INSERT INTO ... ON DUPLICATE KEY UPDATE ...语句:

    INSERT INTO students (id, class_id, name, gender, score) VALUES (1, 1, '小明', 'F', 99) ON DUPLICATE KEY UPDATE name='小明', gender='F', score=99;

    若id=1的记录不存在,INSERT语句将插入新记录,否则,当前id=1的记录将被更新,更新的字段由UPDATE指定。

    3. 插入或忽略

    如果我们希望插入一条新记录(INSERT),但如果记录已经存在,就啥事也不干直接忽略,此时,可以使用INSERT IGNORE INTO ...语句:

    INSERT IGNORE INTO students (id, class_id, name, gender, score) VALUES (1, 1, '小明', 'F', 99);

    若id=1的记录不存在,INSERT语句将插入新记录,否则,不执行任何操作。

    如果在项目中使用的是druid连接池,需要在 .yml文件里配置

    datasource: druid: # 记录慢SQL log-slow-sql: true slow-sql-millis: 1000 # 将该项设为false,不然会将 INSERT IGNORE 拦截 merge-sql: false
    Processed: 0.009, SQL: 8