您好我被困在以下存储过程中。这是我想要做的。
我有两个表:TableA 和 TableB。
- TableA 具有称为 silo、slow 和 close 的列。
 - 表 B 有名为 silo、partno、slow 和 close 的列。
 
.
- 我有一个 HMI 程序正在向我发送筒仓和 partno,而我正在发送慢速和关闭。
 - 我首先需要查看 TableA 并查看 tableA 中是否有与 HMI 发送给我的内容相匹配的筒仓和 partno。
 - 如果是这样,我只需将慢速并靠近 HMI(输出)发送回。
 - 如果 TableA 没有筒仓和零件号,那么我需要 
- 仅在筒仓中查看 TableB 并选择前 1 个(可能有多行具有相同的筒仓编号,所以我需要前 1 个)并将慢速和接近 HMI 的发送回。
 - 我还需要将筒仓、partno(hmi 发送给我)、慢速和关闭(来自 TableB)插入到 TableA 中的新行中。
 
 - 如果多次触发此过程,则不应继续在 tableA 中插入行。
 
我知道 if exists 或 where not exists 可以应用在这个过程中;但我只是不知道如何成功地做到这一点。代码如下。我很感激你的时间。非常感谢
ps errorout是通知hmi如果tableA和tableB没有现有silo,slow,close,然后弹出消息框。就这样。仅用于验证和通知目的。
USE [Product]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER Proc  [Controls].[spSiloSettings]
    @Silo int
    ,@PartNo Varchar (50)
    ,@Slow float output 
    ,@Close  float output 
    ,@errorout int output
AS
if  exists (select slow, close from controls.TableA where  @silo = silo and @partno= partno)
set @errorout = 0
select @slow= slow, @close = close 
    from TableA
    where @silo = silo  
if not exists(select  top 1 @silo = silo,  @slow= slow, @close = close)
    From controls.TableB
    Where silo = @silo
insert into controls.TableA (silo, partno, slow, close) 
    values (@silo, @partno ,@slow, @close)
end