求一个MS SQL的触发器!在新建一张表时某字段等于或少于0时,使该表不能保存!
各位好,在使用ERP时,当新建一张单据时,当某字段A的数值等于或少于0时,该笔单据新建失败!先谢谢了!...
各位好,在使用ERP时,当新建一张单据时,当某字段A的数值等于或少于0时,该笔单据新建失败!先谢谢了!
展开
2个回答
展开全部
create trigger tg_ins
on table
for insert
if(select a from inserted) <= 0
begin
--小于等于0时,回滚
rollback transaction
end
on table
for insert
if(select a from inserted) <= 0
begin
--小于等于0时,回滚
rollback transaction
end
更多追问追答
追问
先谢谢你的回答!
不需用变量的吗?
还有,如果我想加多个条件的,格式 是怎样写啊?如1:A字段少于或等于0的且C字段等于‘Y’ 才阻止新建 !!如2:字段B等于‘OK’时,A字段少于或等于0的 一样可以成功地新建单据!
再谢了!
追答
if exists(select 1 from inserted where (a<0 or a = 0) and c = 'Y')
begin
rollback tran
return
end
if not exists(select 1 from inserted where (a<0 or a = 0) and B = 'OK')
begin
rollback tran
return
end
--1、阻止
--2、反过来看,就是阻止新建
--exists是判断是否存在
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询