首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Insert Insert Insert不是主键的重复项

Insert Insert Insert不是主键的重复项
EN

Stack Overflow用户
提问于 2012-03-10 01:11:07
回答 2查看 1.6K关注 0票数 1

我正在尝试寻找一个sql查询,它只会插入值,而不会在值存在的情况下执行此操作。现在我看到了很多示例,但它们都依赖于主键或表到表的移动。我只想在表中添加一个新行,并假设其中一列不具有相同的值,则将其相加。我知道下面的方法不会起作用,但如果我写的不够好的话,我认为它会很接近,而且可能会把它弄清楚。

代码语言:javascript
复制
    INSERT INTO table (txtLastName,txtEmail,txtZip)
    Values ('Tester','test@test.com','12345')
    WHERE txtLastName <> 'Tester'
    or WHERE txtEmail <> 'test@test.com'
    or WHERE txtZip <> '12345'

使用MS SQL Server。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-03-10 01:17:51

您应该创建一个由三个字段(txtLastNametxtEmailtxtZip)组成的Unique Constraint

这些链接会将您定向到SQL Server文档,但唯一约束的概念是RDBMS通用的。

只需注意,当您创建唯一约束时,您的重复插入不会静默失败:它将抛出一个错误,指出插入试图违反唯一约束。当然,它应该做到这一点!确保您的代码处理该异常。

票数 4
EN

Stack Overflow用户

发布于 2012-03-10 01:27:17

试试这个:

代码语言:javascript
复制
INSERT INTO table (txtLastName,txtEmail,txtZip) 
SELECT 'Tester','test@test.com','12345'
WHERE NOT EXISTS (SELECT *
                    FROM table
                   WHERE txtLastName = 'Tester' 
                     AND txtEmail = 'test@test.com' 
                     AND txtZip = '12345' 
)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9638185

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档