首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >存储过程

存储过程
EN

Stack Overflow用户
提问于 2017-10-17 05:46:00
回答 1查看 25关注 0票数 0

我使用的是server 2012,这段代码在存储过程中。

这些是我的SQL查询,我想在“更新”查询未执行时执行“插入”查询。如果已执行更新查询,则不应执行insert查询。

代码语言:javascript
复制
Update tblStock Set Balance= Balance +  @ReduceRawQty 
    Where LocCode=@LocCode 
    AND ItemCode=@rawitemcode 
    and CostPrice=@rawcostprice

Insert Into tblStock(LocCode, ItemCode, CostPrice, Balance,Transfer,PCode)
    Values(@LocCode,@rawitemcode,@RawCostPrice,@RawQty,0,@PCode)    

有什么办法吗,请帮帮我

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-10-17 05:50:10

您可以检查@@ROWCOUNT以查看有多少行受到UPDATE语句的影响:

代码语言:javascript
复制
UPDATE ...

IF @@ROWCOUNT = 0
    INSERT ...

或者,您可以使用EXISTS首先检查一行并决定执行哪一项操作:

代码语言:javascript
复制
IF EXISTS (SELECT 1 FROM tblStock WHERE LocCode=@LocCode AND ItemCode=@rawitemcode and CostPrice=@rawcostprice)
    UPDATE ...
ELSE
    INSERT ...
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46783239

复制
相关文章

相似问题

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