c oracle存储过程返回值,C#调用存储过程详解(带返回值、参数输入输出等)

本文详细介绍了如何在C#中调用Oracle存储过程,包括设置输入参数、输出参数、返回值,并通过实例展示了处理带有返回值和输入输出参数的存储过程的方法。
摘要由CSDN通过智能技术生成

本文实例讲述了C#调用存储过程的方法。分享给大家供大家参考,具体如下:

CREATE PROCEDURE [dbo].[GetNameById]

@studentid varchar(8),

@studentname nvarchar(50) OUTPUT

AS

BEGIN

SELECT @studentname=studentname FROM student

WHERE studentid=@studentid

if @@Error<>0

RETURN -1

else

RETURN 0

END

using (SqlConnection conn = new SqlConnection(connStr))

{

try

{

SqlCommand cmd = new SqlCommand("GetNameById", conn);

cmd.CommandType = CommandType.StoredProcedure;

cmd.Parameters.AddWithValue("@studentid", "09888888");  //给输入参数赋值

SqlParameter parOutput =cmd.Parameters.Add("@studentname", SqlDbType.NVarChar, 50);  //定义输出参数

parOutput.Direction = ParameterDirection.Output;  //参数类型为Output

SqlParameter parReturn = new SqlParameter("@return", SqlDbType.Int);

parReturn.Direction = ParameterDirection.ReturnValue;   //参数类型为ReturnValue

cmd.Parameters.Add(parReturn);

conn.Open();

cmd.ExecuteNonQuery();

MessageBox.Show(parOutput.Value.ToString()); //显示输出参数的值

MessageBox.Show(parReturn.Value.ToString());  //显示返回值

}

catch (System.Exception ex)

{

MessageBox.Show(ex.Message);

}

}

Create PROCEDURE AddOrderTran

@country nvarchar(100),

@adds nvarchar(100),

@ynames nvarchar(100),

@pids nvarchar(100),

@cellp nvarchar(100),

@cphone nvarchar(100),

@amounts nvarchar(100),

@cartnumber nvarchar(100)

as

Declare @id int

BEGIN TRANSACTION

insert into Orders(Order_Country,Order_Adress,Order_UserName,Order_PostID,Cells,Order_Phone,Total_pay,CartNumber,IsPay)

values (@country,@adds,@ynames,@pids,@cellp,@cphone,@amounts,@cartnumber,'0')

Select @id=@@identity

insert into Orders_Item (OrderNumber,ProductsID,Products_Color,Products_Price,Order_Qty,Item_Total)

select @id,Carts_Item.ProductsID,Carts_Item.Products_Color,Carts_Item.Products_Price,Carts_Item.Item_Qty,Carts_Item.Total_Pay

from Carts_Item where Carts_Item.CartNumber=@cartnumber

delete Carts_Item where CartNumber=@cartnumber

IF @@error <> 0 --发生错误

BEGIN

ROLLBACK TRANSACTION

RETURN 0

END

ELSE

BEGIN

COMMIT TRANSACTION

RETURN @id --执行成功

END

#region 执行存储过程

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值