mysql存在则更新,不存在则新增
1.存在就更新,不存在就新增
使用replace关键字,存在就更新,不存在就新增一条数据表必须有唯一索引unique,且索引所在字段值不能为空。
replace into的更新方式是先删除再插入,有自增主键时不要用
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='离散');
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现