错误原因
报错信息“Duplicate entry ‘1234’ for key ‘USER_INFO.PRIMARY’”,尝试插入一条数据时,主键值ID=1234,已经存在于表USER_INFO中。因为键(Primary Key)是表中的唯一标识符,每个记录必须有一个唯一的主键值,所以报错
例:
ID(主键)
USER_NAME
ADDRESS
1234
小红
武汉
5678
小白
长沙
执行如下插入sql后预期报错
INSERT INTO USER_INFO (ID, USER_NAME, ADDRESS) VALUES (1234, ‘小红’, ‘武汉’);
解决方案
1.INSERT IGNORE:忽略重复的插入操作,插入无效
机制:遇到主键冲突不进行任何操作
示例预期:
INSERT IGNORE USER_INFO (ID, USER_NAME, ADDRESS) VALUES (1234, ‘小红’, ‘武汉’);
ID(主键)
USER_NAME
ADDRESS
1234
小红
武汉
5678
小白
长沙
2.REPLACE INTO:可以在主键冲突时替换现有记录
机制</