表要求:有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), )如果我们希望插入一条新记录(INSERT),但如果记录已经存在,就先删除原记录,再插入新记录。此时,可以使用REPLACE语句,这样就不必先查询,再决定是否先删除再插入:
REPLACE INTO students (id, class_id, name, gender, score) VALUES (1, 1, '小明', 'F', 99);若id=1的记录不存在,REPLACE语句将插入新记录,否则,当前id=1的记录将被删除,然后再插入新记录。
如果我们希望插入一条新记录(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指定。
如果我们希望插入一条新记录(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