sql 触发器 防止插入重复数据

短短的 2017-04-06 09:07:33
CREATE TRIGGER [chonfu] ON [dbo].[caiji]
FOR INSERT
AS

if not exists(select 1 from caiji where dz=(select dz from inserted))
begin
print '数据重复'
rollback tran
end



没反应一直添加
...全文
854 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
MA4A1 2021-01-11
  • 打赏
  • 举报
回复 1
可以试一试我这个

create TRIGGER flx_isexist
ON book_style
for INSERT
AS
begin
declare @string varchar(50)
select @string=bookstyle from inserted
IF ((select count(*) from book_style where book_style.bookstyle = @string)>1)
begin
rollback tran
raiserror ('该类型以存在!',16,1)
return
end
end
go
卖水果的net 版主 2017-04-06
  • 打赏
  • 举报
回复
贴出你的建表语句,和你执行的 insert 语句;
二月十六 版主 2017-04-06
  • 打赏
  • 举报
回复
给dz设置唯一约束,就行了,不用触发器
http://www.w3school.com.cn/sql/sql_unique.asp
短短的 2017-04-06
  • 打赏
  • 举报
回复
数据还是重复,没作用

34,590

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧