C#中使用带返回值的存储过程

前端之家收集整理的这篇文章主要介绍了C#中使用带返回值的存储过程前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

<div class="date">2007-01-27 08:37 P.M.


<table style="TABLE-LAYOUT: fixed"><tr>
<td>
<div class="cnt">
<div class="postbody">

例如在向数据库添加新数据时,需要检测是否有重复本例介绍如何把这个检测的过程放在存储过程中,并用程序调用检测的结果做出反应。存储过程如下:

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表示数据操作成功 endendreturn @returnGO 名称)两个字段。在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

猜你在找的C#相关文章