asp.net – 如何在SQL Server 2008中的单个存储过程中编写两个更
发布时间:2020-12-16 03:24:21 所属栏目:asp.Net 来源:网络整理
导读:我有一个表包含绑定到gridview的几列. 在该gridview中,我有一个用于更新列的编辑选项.在那种情况下,我需要编写两个更新存储过程,这意味着我选择所有列期望AudiotoName,选择另一列所有列都更新以提出一个更新查询但是当我选择表中有AudiotoName列时只编辑选择
我有一个表包含绑定到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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- 在asp.net控件的style属性中使用DataBinder.Eval()
- rest – ASP.NET Web API身份验证选项
- 在asp.net中找不到richtext框控件
- I am a passionate coder ^_^
- asp.net-mvc – Asp.Net MVC3 RC Razor视图:在块内嵌入代码
- asp.net-mvc – 如何使用ASP.NET MVC 5和OWIN获取Facebook的
- 使用asp.net统计在线用户
- asp.net core 核心对象解析
- asp.net – 无法将“ASP._Page__ViewStart_cshtml”类型的对
- asp.net – 无法找到类型或命名空间名称’ProfileCommon