关闭

小试存储过程

标签: 存储webformsql serverasp.netdatabaseobject
398人阅读 评论(0) 收藏 举报

 

拜读了孟子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
 }
}
 

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:35864次
    • 积分:549
    • 等级:
    • 排名:千里之外
    • 原创:15篇
    • 转载:11篇
    • 译文:0篇
    • 评论:11条
    文章分类