拜读了孟子E章博客中一篇关于存储过程的文章,于是自己也试了试。
在SQL server中建立好新的存储过程,
然后主要就是在程序中建立链接,声明一个type为storeprocedure的cmd。
比较容易出错的地方就是设置参数。
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;
namespace testSP
{
/// <summary>
/// WebForm1 的摘要说明。
/// </summary>
public class WebForm1 : System.Web.UI.Page
{
protected System.Web.UI.WebControls.Label Label1;
protected System.Web.UI.WebControls.Label lb_message;
private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
// 在此处放置用户代码以初始化页面
SqlConnection cn;
cn=new SqlConnection("Data Source=(local);database=bbs;Trusted_Connection=yes");
SqlCommand cm=new SqlCommand("firststoreprocedure", cn);
cm.CommandType=CommandType.StoredProcedure;
cm.Parameters.Add("@UserName",SqlDbType.VarChar,50);
cm.Parameters["@UserName"].Direction=ParameterDirection.Output;
cm.Parameters.Add("@ID",SqlDbType.Int);
cm.Parameters["@ID"].Value="2";
cn.Open();
SqlDataReader dr=cm.ExecuteReader();
lb_message.Text=cm.Parameters["@UserName"].Value.ToString();
Label1.Text=cn.State.ToString();
cn.Close();
}
#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);
}
#endregion
}
}