微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

asp.net – 如何在SQL Server 2008中的单个存储过程中编写两个更新查询

我有一个表包含绑定到gridview的几列.

在该gridview中,我有一个用于更新列的编辑选项.在那种情况下,我需要编写两个更新存储过程,这意味着我选择所有列期望AudiotoName,选择另一列所有列都更新以提出一个更新查询但是当我选择表中有AudiotoName列时只编辑选择该列它将引发第二次更新存储过程.我试过,但没有正常工作,任何人都可以帮助我.

我的代码

ALTER PROCEDURE up_file
    (@ModuleID int,@SubjectID int,@Physician varchar(500) = '',@AuditoName varchar(300) = '',@AuditoType varchar(50) = '',@AudioPath varchar(2000) = '',@BaseDocumentName varchar(500) = '',@BaseDocumentPath varchar(2000) = '',@Createddate datetime,@CreatedBy varchar(200) = '')
AS
BEGIN   
    IF @AuditoName = 'true' //select AuditoName column only raise this update query
    BEGIN
        UPDATE SubjectItems 
        SET ModuleID = @ModuleID,SubjectID = @SubjectID,Physician = '@Physician',AuditoName = '@AuditoName',AuditoType = '@AuditoType',AudioPath ='@AudioPath',BaseDocumentName = '@BaseDocumentName',BaseDocumentPath = '@BaseDocumentPath' 
         WHERE AuditoName = @AuditoName
    END
    BEGIN  //normal fields select raise this update query 
       UPDATE SubjectItems 
       SET ModuleID = @ModuleID,BaseDocumentPath = '@BaseDocumentPath' 
         WHERE ModuleID = @ModuleID
    END
END

谁能帮我吗?

解决方法

您的查询中的问题是,即使@AuditoName为true,也会运行较低的更新查询.这将重新更新表SubjectItems.您可以使用if … else块,如下所示:

ALTER PROCEDURE up_file
    (@ModuleID int,BaseDocumentPath = '@BaseDocumentPath' 
         WHERE AuditoName = @AuditoName
    END
ELSE
    BEGIN  //normal fields select raise this update query 
       UPDATE SubjectItems 
       SET ModuleID = @ModuleID,BaseDocumentPath = '@BaseDocumentPath' 
         WHERE ModuleID = @ModuleID
    END
END

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐