手机
当前位置:查字典教程网 >编程开发 >asp.net教程 >C# 调用存储过程简单完整的实例代码
C# 调用存储过程简单完整的实例代码
摘要:CREATEPROCP_TEST@NameVARCHAR(20),@RowcountINTOUTPUTASBEGINSELECT*FROMT...

CREATE PROC P_TEST@Name VARCHAR(20),

@Rowcount INT OUTPUT

AS

BEGIN

SELECT * FROM T_Customer WHERE NAME=@Name

SET @Rowcount=@@ROWCOUNT

END

GO

----------------------------------------------------------------------------------------

--存储过程调用如下:

----------------------------------------------------------------------------------------

DECLARE @i INT

EXEC P_TEST 'A',@i OUTPUT

SELECT @i

--结果

/*

Name Address Tel

---------- ---------- --------------------

A Address Telphone

(所影响的行数为 1 行)

-----------

1

(所影响的行数为 1 行)

*/

----------------------------------------------------------------------------------------

--DotNet 部分(C#)

--WebConfig 文件:

----------------------------------------------------------------------------------------

......

</system.web>

<>

<appSettings>

<add key="ConnectString" value="server=(local);User ID=sa;Password=;database=Test" />

</appSettings>

</configuration>

----------------------------------------------------------------------------------------

--C#代码:(用到两个测试控件,DataGrid1(用于显示绑定结果集合),Lable(用于显示存储过程返回单值)

代码

复制代码 代码如下:

using System.Data.SqlClient;

private void Page_Load(object sender, System.EventArgs e)

{ // 在此处放置用户代码以初始化页面

String DBConnStr; DataSet MyDataSet=new DataSet();

System.Data.SqlClient.SqlDataAdapter DataAdapter=new System.Data.SqlClient.SqlDataAdapter();

DBConnStr=System.Configuration.ConfigurationSettings.AppSettings["ConnectString"];

System.Data.SqlClient.SqlConnection myConnection = new System.Data.SqlClient.SqlConnection(DBConnStr);

if (myConnection.State!=ConnectionState.Open)

{ myConnection.Open(); }

System.Data.SqlClient.SqlCommand myCommand = new System.Data.SqlClient.SqlCommand("P_Test",myConnection);

myCommand.CommandType=CommandType.StoredProcedure; //添加输入查询参数、赋予值

myCommand.Parameters.Add("@Name",SqlDbType.VarChar);

myCommand.Parameters["@Name"].Value ="A"; //添加输出参数

myCommand.Parameters.Add("@Rowcount",SqlDbType.Int);

myCommand.Parameters["@Rowcount"].Direction=ParameterDirection.Output;

myCommand.ExecuteNonQuery();

DataAdapter.SelectCommand = myCommand;

if (MyDataSet!=null)

{ DataAdapter.Fill(MyDataSet,"table"); }

DataGrid1.DataSource=MyDataSet; DataGrid1.DataBind(); //得到存储过程输出参数

Label1.Text=myCommand.Parameters["@Rowcount"].Value.ToString();

if (myConnection.State == ConnectionState.Open) { myConnection.Close();

}

}

【C# 调用存储过程简单完整的实例代码】相关文章:

asp.net保存远程图片的代码

ASP.Net生成一个简单的图片

c# .net 生成图片验证码的代码

高仿Windows Phone QQ登录界面实例代码

获取远程网页的内容之一(downmoon原创)

C# 邮件地址是否合法的验证

在ASP.NET中调用存储过程方法新解

asp.net 获取图片高度和宽度实例代码

ASP.NET 输出缓存移除的实例代码

ASP.net 生成缩略图的实例源代码

精品推荐
分类导航