.net 接收存储过程的返回值 。。。。
例如在向数据库添加新数据时,需要检测是否有重复
本例介绍如何把这个检测的过程放在存储过程中,并用程序调用检测的结果做出反应。
存储过程如下
CREATE PROCEDURE DInstitute_Insert
@InstituteNO nvarchar(6),@InstituteName nvarchar(40)
AS
declare @return int,@count int
if(ltrim(rtrim(@InstituteName))='' or ltrim(rtrim(@InstituteNO))='')
select @return=3--返回3表示提交的数据有空值
else
begin
select @count=count(1) from DInstitute where InstituteNO=@InstituteNO
if(@count>0)
select @return=1--返回1表示编号有重复
else
begin
insert into DInstitute (InstituteNO,InstituteName) values (@InstituteNO,@InstituteName)
if(@@error>0)
select @return=2--返回2表示数据操作错误
else
select @return=0--返回0表示数据操作成功
end
end
return @return
GO
其中DInstitute 是一个学院信息表。只有InstituteNO(学院编号)、InstituteName(学院名称)两个字段。
在C#中调用本存储过程的代码如下:
//执行插入操作
SqlCommand com1 = new SqlCommand("DInstitute_Insert", DBcon);
if (com1.Connection.State == ConnectionState.Closed)
com1.Connection.Open();
com1.CommandType = CommandType.StoredProcedure;
com1.Parameters.Add(new SqlParameter("@InstituteNO",SqlDbType.NVarChar,6));
com1.Parameters.Add(new SqlParameter("@InstituteName", SqlDbType.NVarChar, 40));
com1.Parameters.Add(new SqlParameter("@return", SqlDbType.Int));
com1.Parameters["@return"].Direction = ParameterDirection.ReturnValue;
com1.Parameters["@InstituteNO"].Value = t_NO.Text;
com1.Parameters["@InstituteName"].Value = t_name.Text;
try
{
com1.ExecuteScalar();
}
catch(SqlException ee)
{
DB.msgbox("操作失败!"+ee.Message.ToString());
return;
}
finally
{
com1.Connection.Close();
}
string temp = com1.Parameters["@return"].Value.ToString();
//返回0表示数据操作成功
//返回1表示编号有重复
//返回2表示数据操作错误
//返回3表示提交的数据有空值
switch (temp)
{
case "0":
DB.msgbox("添加成功!");
break;
case "1":
DB.msgbox("编号有重复!");
break;
case "2":
DB.msgbox("数据操作错误!");
break;
case "3":
DB.msgbox("提交的数据有空值!");
break;
}
Binding(); //刷新datagrid
---------------------------------------------- 补充其它方法。
System.Data.SqlClient.SqlConnection scon = new System.Data.SqlClient.SqlConnection("server=Netangel;uid=etopsUS;pwd=etops;database=etops");
System.Data.SqlClient.SqlCommand scom = new System.Data.SqlClient.SqlCommand("",scon);
scon.Open();
scom.CommandText="p_CorpClassAdd";
scom.CommandType = System.Data.CommandType.StoredProcedure;
scom.Parameters.Add(
new SqlParameter("ReturnValue", SqlDbType.Int, 4,
ParameterDirection.ReturnValue, false, 0, 0,
string.Empty, DataRowVersion.Default, null)) //增加存储过程的返回值参数
scom.ExecuteNonQuery();
Response.Write(scom.Parameters["ReturnValue"].Value.ToString()); //输出存储过程
cmd = New SqlCommand("sp_del_office_byID", conn)
cmd.CommandType = CommandType.StoredProcedure
cmd.Parameters.Add("@OfficeID", SqlDbType.Int)
cmd.Parameters("@OfficeID").Value = officeid_pk
cmd.Parameters.Add("s", SqlDbType.Int)
cmd.Parameters("s").Direction = ParameterDirection.ReturnValue
cmd.ExecuteNonQuery()
s = cmd.Parameters("s").Value
通用的,输入输出参数各1个,调用时只要传入参数和存储过程名即可返回结果
//程序部分
public bool Execute(string Procname,SqlParameter []parameter,out string procout)
{
SqlConnection Sqlcon=new SqlConnection(Configuration.ConnectionString);
SqlCommand Sqlcom=new SqlCommand();
Sqlcon.Open();
Sqlcom.Connection=Sqlcon;
Sqlcom.CommandText=Procname;
Sqlcom.CommandType=CommandType.StoredProcedure;
Sqlcom.Parameters.Add(new SqlParameter("@m_return",SqlDbType.Int));
for(int i=0;i<parameter.Length;i++)
Sqlcom.Parameters.Add(parameter[i]);
Sqlcom.Parameters["@m_return"].Direction=ParameterDirection.ReturnValue;
Sqlcom.ExecuteNonQuery();
procout=Sqlcom.Parameters["@m_return"].Value.ToString();
return true;
} private void button2_Click(object sender, System.EventArgs e)
{
SqlParameter[] parameter={new SqlParameter("@ID",SqlDbType.Int)};
parameter[0].Value=1;
string UC;
bool retVal=Execute("管理员_CheckExist",parameter,out UC);
button2.Text=UC.ToString();
} //存储过程部分
ALTER PROCEDURE dbo.管理员_CheckExist
@ID int
AS
declare @matchCount int
select @matchCount = count(*) from 管理员 where ID=@ID
return @matchCount
.net 接收存储过程的返回值 。。。。的更多相关文章
- JDBC和JPA调用储存过程 接收存储过程有返回值
============jdbc==========================================--java代码:一个输出参数--String connURL = null;Con ...
- SqlServer如何获取存储过程的返回值
1.Output参数返回值 1 CREATE PROCEDURE [dbo].[upInformation]( 2 @age int , 3 @id bigint OUTPUT 4 ) 5 AS 6 ...
- 关于ExecuteNonQuery执行存储过程的返回值 、、实例讲解存储过程的返回值与传出参数、、、C#获取存储过程的 Return返回值和Output输出参数值
关于ExecuteNonQuery执行存储过程的返回值 用到过ExecuteNonQuery()函数的朋友们在开发的时候肯定这么用过. if(cmd.ExecuteNonQuery("xxx ...
- C#获取执行存储过程的" 返回值"代码
以下是C#代码: /// <summary> /// 执行存储过程,返回" 返回值" /// </summary> /// <param name=& ...
- 利用SQLServer查询分析器获取存储过程的返回值,检查测试存储过程
1.存储过程没有返回值的情况(即存储过程语句中没有return之类的语句)用方法 int count = ExecuteNonQuery(..)执行存储过程其返回值只有两种情况(1)如果通过查询分析器 ...
- 在Delphi中如何获得SQL中存储过程的返回值?
示例存储过程:create procedure proc_loginusername varchar(20),password varchar(20)asdeclare @result intsele ...
- MSSQL - 存储过程Return返回值
1.存储过程中不使用外部参数. 存储过程: SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO -- ========================== ...
- Entity Framework中对存储过程的返回值的处理
很早就开始注意到EF了,但一直没有机会用,换了工作后,第一个项目就使用EF6进行开发. 项目不是很大,EF完全可以胜任. 但是开发过程中,难免还是会遇到一些复杂的运算,需要频繁访问数据库. 此时,想到 ...
- SqlServer和MySQL中存储过程out返回值处理C#代码
1.SqlServer中out处理 C#代码 #region"SqlServer中存储过程处理out返回值" //public void getdata() //{ // stri ...
随机推荐
- C++操作MYSQL遇到的一些问题
首先 我使用的是 vcpkg<不知道的可以进行百度 可以剧透一下,这个对Visual Studio使用一些C++的轮子太方便了, 上面是我装的一些库<大大安利vcpkg 安装时一定要使用p ...
- linux如何正确设置静态ip
如果是新安装的CentOS7的用户,刚开始应该是没网的,ifconfig命令在CentOS7已经被淘汰了. 1.使用ip addr 即查看分配网卡情况. 2.激活网卡 [root@localhost ...
- Codeforces Round #258 (Div. 2) D
D. Count Good Substrings time limit per test 2 seconds memory limit per test 256 megabytes input sta ...
- hdu 3622 二分+2-sat
/* 二分+2-sat 题意:在一个二维平面上给你n个炸弹,和2*n个位置,每一行的两个位置只能有一个放炸弹 现在炸弹爆炸有一个半径,当炸弹爆炸时两个炸弹的半径化成的圆不能相交,求最大半径 二分半径, ...
- 详解SpringBoot 添加对JSP的支持(附常见坑点)
序言: SpringBoot默认不支持JSP,如果想在项目中使用,需要进行相关初始化工作.为了方便大家更好的开发,本案例可直接作为JSP开发的脚手架工程 SpringBoot+War+JSP . 常见 ...
- python之练习-三层菜单
今天练习编写显示3层城市名称并可以返回上一层以及退出程序. Readme: 程序概述1:程序名称为:menu_three.py2:记录省,市,县的原始文件名为:areafile3:areafile文件 ...
- hdu - 1150 Machine Schedule (二分图匹配最小点覆盖)
http://acm.hdu.edu.cn/showproblem.php?pid=1150 有两种机器,A机器有n种模式,B机器有m种模式,现在有k个任务需要执行,没切换一个任务机器就需要重启一次, ...
- node+mongodb+win7
一.安装mongodb,参照教程,注意要先启动mongod.exe,再启动mongd.exe.
- 使用HttpClient调用第三方接口
最近项目中需要调用第三方的Http接口,这里我用到了HttpClient. 首先我们要搞明白第三方接口中需要我们传递哪些参数.数据,搞明白参数以后我们就可以使用HttpClient调用接口了. 1.调 ...
- Ubuntu 16.04安装SoapUI工具进行接口测试(Web Service/WSDL/RESTfull)
SoapUI是一个跨平台接口测试工具,官方提供开源版本和商业版本.可以用来测试WSDL/RESTfull等接口. 替代的工具有JMeter. 一般用于WSDL的接口测试比较多,基于XML的形式,且这类 ...