博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
如何在C#中使用存储过程(SQL Server 2000)
阅读量:5888 次
发布时间:2019-06-19

本文共 2833 字,大约阅读时间需要 9 分钟。

要在C#中使用存储过程,首先看看test表的创建sql语句:
 

create table test55

(
uid int identity(1,1),
class1 varchar(20),
class2 varchar(20),
uname varchar(20),
birth smalldatetime,
meno varchar(50)
)
 
alter table test55
add constraint primary_id primary key(uid)

创建一个有输入、输出、返回值参数的存储过程:

create proc proc_out @uid int,@output varchar(200) output

as

--select结果集

select * from test where uid>@uid

--对输出参数进行赋值

set @output='记录总数:'+convert(varchar(10),(select count(*) from test))

--使用return,给存储过程一个返回值。

return 200;

go

在C#中使用存储过程:

使用带有参数的sql语句

private void sql_param()

  {
 
  SqlConnection conn=new SqlConnection("server=.;uid=sa;pwd=1234;database=china");
    
  
//在sql语句当中引入了@myid参数
  string sql="select * from test where uid>@myid";
  SqlCommand comm=new SqlCommand(sql,conn);
           
  
//使用comm的Parameters属性的add方法,对上述的@myid参数进行定义和赋值
  
//SqlDbType类提供了与SqlServer数据类型一致的数据库类型
  SqlParameter sp=comm.Parameters.Add("@myid",SqlDbType.Int);
  sp.Value=10;
//对输入参数赋值
      
  
//Command对象默认的执行方式为Text,不写下句亦可
  comm.CommandType=CommandType.Text;
    
  
//将Command对象作为DataAdapter的参数传进
  SqlDataAdapter da=new SqlDataAdapter(comm);
  DataSet ds=new DataSet();
  da.Fill(ds);
 
        
//绑定数据到DataGrid1控件上
  this.DataGrid1.DataSource=ds;
  this.DataGrid1.DataBind();
   
  }

存储过程的使用标准版 

private void sql_proc()

   {
      
    SqlConnection conn=new SqlConnection("server=.;uid=sa;pwd=1234;database=china");
    string sql="proc_out";
    SqlCommand comm=new SqlCommand(sql,conn);
     
    
//把Command执行类型改为存储过程方式,默认为Text。
    comm.CommandType=CommandType.StoredProcedure;
 
    
//传递一个输入参数,需赋值
    SqlParameter sp=comm.Parameters.Add("@uid",SqlDbType.Int);
    sp.Value=10;
 
    
//定义一个输出参数,不需赋值。Direction用来描述参数的类型
    
//Direction默认为输入参数,还有输出参数和返回值型。
    sp=comm.Parameters.Add("@output",SqlDbType.VarChar,50);
    sp.Direction=ParameterDirection.Output;
 
    
//定义过程的返回值参数,过程执行完之后,将把过程的返回值赋值给名为myreturn的Paremeters赋值。
    sp=comm.Parameters.Add("myreturn",SqlDbType.Int);
    sp.Direction=ParameterDirection.ReturnValue;
     
    
//使用SqlDataAdapter将自动完成数据库的打开和关闭过程,并执行相应t-sql语句或存储过程
    
//如果存储过程只是执行相关操作,如级联删除或更新,使用SqlCommand的execute方法即可。
    SqlDataAdapter da=new SqlDataAdapter(comm);
    DataSet ds=new DataSet();
    da.Fill(ds);
     
     
    
//在执行完存储过程之后,可得到输出参数
    string myout=comm.Parameters["@output"].Value.ToString();
     
    
//打印输出参数:
    Response.Write("打印输出参数:"+myout);
 
    
//打印存储过程返回值
    myout=comm.Parameters["myreturn"].Value.ToString();
    Response.Write("存储过程返回值:"+myout);
 
    this.DataGrid1.DataSource=ds;
    this.DataGrid1.DataBind();
 
 
   }

存储过程的使用最简版:

private void sql_jyh()

   {
 
   
//最简写法,把存储过程当作t-sql语句来使用,语法为:exec 过程名 参数
 
   SqlConnection conn=new SqlConnection("server=.;uid=sa;pwd=1234;database=china");
   string sql="execute proc_out 10,'12'";
   SqlCommand comm=new SqlCommand(sql,conn);
    
   
//使用SqlDataAdapter将自动完成数据库的打开和关闭过程,并执行相应t-sql语句或存储过程
   
//如果存储过程只是执行相关操作,如级联删除或更新,使用SqlCommand的execute方法即可。
   SqlDataAdapter da=new SqlDataAdapter(comm);
   DataSet ds=new DataSet();
   da.Fill(ds);
    
   
//绑定数据
   this.DataGrid1.DataSource=ds;
   this.DataGrid1.DataBind();
    
   }

转载于:https://www.cnblogs.com/wwwzzg168/p/4121652.html

你可能感兴趣的文章
单点登录加验证码例子
查看>>
[T-SQL]从变量与数据类型说起
查看>>
稀疏自动编码之反向传播算法(BP)
查看>>
二叉搜索树转换成双向链表
查看>>
会员数据化运营
查看>>
WebLogic和Tomcat的区别
查看>>
java类中 获取服务器的IP 端口
查看>>
调用约定__stdcall / __cdecl
查看>>
occActiveX - ActiveX with OpenCASCADE
查看>>
redmine
查看>>
css 序
查看>>
DirectshowLib摄像头拍照的”未找到可用于建立连接的介质筛选器组合“ 解决办法...
查看>>
Django之用户认证组件
查看>>
python如何使用 os.path.exists()--Learning from stackoverflow ...
查看>>
wcf-1
查看>>
关于分区表的初探
查看>>
Xcode 6 下添加pch头文件
查看>>
三种简单排序
查看>>
curl 向远程服务器传输file文件
查看>>
[Java]读取文件方法大全
查看>>