MySql_数据存在就更新或不操作,不存在就新增

  • 当在数据库里执行新增操作时,往往会出现插入的数据在表中已存在的问题,除了在后台代码中对数据进行重复判断外,还可使用SQL来判断。
CREATE TABLE `subject`  (
  `subjectId` int NOT NULL AUTO_INCREMENT COMMENT '自增,科目编号',
  `subjectName` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '科目名称',
  PRIMARY KEY (`subjectId`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci COMMENT = '科目表' ROW_FORMAT = Dynamic;

1.存在就更新,不存在就新增

  • 使用replace关键字,存在就更新,不存在就新增一条数据表必须有唯一索引unique,且索引所在字段值不能为空。
replace into 'subject' (subjectId,subjectName) 
values (1,'离散');
  • 根据主键判断是否存在,执行新增(insert)或修改(update)操作;on duplicate key
    update为mysql独有语法。
insert into `subject`(subjectId,subjectName) 
values('7','离散') 
on duplicate key update subjectName='离散数学';

2.存在则不操作,不存在则新增

  • insert ignore,必须有唯一键unique。
insert ignore 'subject'(subjectId,subjectName) 
values (1,'离散');
  • 使用insert…select…语句;使用 dual 做表名可以让你在 select
    语句后面直接跟上要插入字段的值,而且这些值还可以不存在当前表中。
INSERT INTO `subject`(subjectId,subjectName) 
SELECT 2,'离散数学'
FROM dual 
WHERE not exists (select subjectId,subjectName from `subject` 
where subjectId='1' and subjectName='离散');

# 与主键无关
INSERT INTO `subject`(subjectName) 
SELECT '离散数学'
FROM dual 
WHERE not exists (select subjectName from `subject` 
where subjectName='离散');
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值