求一个MS SQL的触发器!在新建一张表时某字段等于或少于0时,使该表不能保存!

各位好,在使用ERP时,当新建一张单据时,当某字段A的数值等于或少于0时,该笔单据新建失败!先谢谢了!... 各位好,在使用ERP时,当新建一张单据时,当某字段A的数值等于或少于0时,该笔单据新建失败!先谢谢了! 展开
 我来答
哎呀……18a91a6
2014-11-05 · TA获得超过4.2万个赞
知道大有可为答主
回答量:7246
采纳率:76%
帮助的人:3024万
展开全部

你的要求,针对你的“某字段A”建立一个约束就可以了,不必用触发器。


参考下图:

追问
直接 在表达式的框里输入 A<=0  这样吗?
追答
"当某字段A的数值等于或少于0时"不让加入,所以,在表达式的框里应输入“ A>0 ”。
图都给你截出来乐,你还看不懂么……
发生等将发生
推荐于2016-11-08 · TA获得超过478个赞
知道小有建树答主
回答量:653
采纳率:75%
帮助的人:325万
展开全部
create trigger tg_ins
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是判断是否存在
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式