gpt4 book ai didi

sql - MS SQL Server 2012 - 如果行不存在则插入值

转载 作者:行者123 更新时间:2023-12-04 10:09:31 24 4
gpt4 key购买 nike

我是 SQL 的新手,我需要在插入它们之前检查行中的值是否存在。

我试图一次将详细信息插入多行。

我的代码如下:

insert into [Test].[Projects]([TestID], [GroupID], [TestingID], [Grade])
values
(314, 9, 77, 2)
,(314, 9, 77, 3)
,(314, 9, 77, 4)
,(329, 2, 65, 2)
,(329, 2, 65, 3)
,(329, 2, 65, 4)
go


如果有人能帮我在行值不存在的地方插入这些,我将不胜感激

最佳答案

您可以使用 insert ... select带有 not exists 的语法确保表中不存在完全相同的记录的条件:

insert into Test.Projects(TestID, GroupID, TestingID, Grade)
select v.*
from (values
(314, 9, 77, 2),
(314, 9, 77, 3),
(314, 9, 77, 4),
(329, 2, 65, 2),
(329, 2, 65, 3),
(329, 2, 65, 4)
) v(TestID, GroupID, TestingID, Grade)
where not exists (
select 1
from Test.Projects p
where
p.TestID = v.TestID
and p.GroupID = v.GroupID
and p.TestingID = v.TestingID
and p.Grade = v.Grade
)

关于sql - MS SQL Server 2012 - 如果行不存在则插入值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61398153/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com