要在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)

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

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();
    
   }

如何在C#中使用存储过程(SQL Server 2000)的更多相关文章

  1. 在易语言中调用MS SQL SERVER数据库存储过程方法总结

    Microsoft SQL SERVER 数据库存储过程,根据其输入输出数据,笼统的可以分为以下几种情况或其组合:无输入,有一个或多个输入参数,无输出,直接返回(return)一个值,通过output ...

  2. 存储过程系列之调试存储过程 SQL Server 2005

    在数据库中直接调试  在数据库中直接调试是调试SQL Server 2005的存储过程的最简单的方法. 在Visual Stuido的IDE中你可以选择单步执行存储过程,然后就可以一条语句一条语句地单 ...

  3. 数据库存储过程 — Sql Server

    Mysql.Oracle等主流关系型数据库基本都支持存储过程,这里使用Sql Server为例进行说明. 存储过程的概念: Sql Server存储过程 SQL Server 中的存储过程是由一个或多 ...

  4. SQL Server 2000 系统存储过程

    SQL Server 2000 系统存储过程 在 Microsoft? SQL Server? 中,许多管理和信息活动可以通过系统存储过程执行.系统存储过程按这些分类分组. 分类 描述 Active ...

  5. 配置sql server 2000以允许远程访问 及 连接中的四个最常见错误

    地址:http://www.cnblogs.com/JoshuaDreaming/archive/2010/12/01/1893242.html 配置sql server 2000以允许远程访问适合故 ...

  6. SQL Server 2000中的完整备份、差异备份操作

    在SQL Server 2000中,假定我们拥有一个数据库为:Test, 现在需要它每天19:00自动进行一次备份,并且以后一旦发生数据库错误,我们都可以通过备份文件将数据库恢复到任何一个备份过的时刻 ...

  7. 如何在64位系统上安装SQL Server 2000

    如何在64位系统上安装SQL Server 2000? 现在用SQL Server 2000数据库的人少了吧?大都是SQL Server 2005/2008了.不过还是有需求的,今天一朋友就让我在他的 ...

  8. 在打包程序中自动安装SQL Server数据库 .

    原文:在打包程序中自动安装SQL Server数据库 . 1.创建安装项目“Setup1”安装项目 在“文件”菜单上指向“添加项目”,然后选择“新建项目”. 在“添加新项目”对话框中,选择“项目类型” ...

  9. 在Spring中配置SQL server 2000

    前言 Lz主要目的是在Spring中配置SQL server 2000数据库,但实现目的的过程中参差着许多SQL server 2000的知识,也包罗在本文记载下来!(Lz为什么要去搞sql serv ...

随机推荐

  1. Redhat 5上OPENLDAP的安装备份和恢复

    1. 安装 1.1. 安装环境 查看当前操作系统版本: [root@vmw9181-app ~]# cat /etc/issue Red Hat Enterprise Linux Server rel ...

  2. 用shell脚本新建shell文件并自动生成头说明信息

    目标: 新建文件后,直接给文件写入下图信息 代码实现: [root@localhost test]# vi AutoHead.sh #!/bin/bash#此程序的功能是新建shell文件并自动生成头 ...

  3. webpack2使用ch5-多页面设置 内部js和引入js

    1 当前目录 2 webpack.config.js 配置 const webpack = require('webpack'), htmlWebpackPlugin = require('html- ...

  4. netconf选用秘钥登录

    #! /usr/bin/python2.7import ncclientfrom ncclient import managerwith manager.connect(\ host="19 ...

  5. plsql部分字段中文乱码,sqlplus中文乱码

    PLSQL中文乱码 问题: 解决: 思路1:设置 export NLS_LANG="SIMPLIFIED CHINESE_CHINA.ZHS16GBK" 结果:并不能解决问题!   ...

  6. 知识树杂谈Android面试(3)

    一.Activity生命周期? a. Activity四种状态? Running.Paused(透明无焦点).Stopped.killed. b. OnStart() OnRusume区分? 是否可以 ...

  7. Python 中的装饰器

    说到装饰器是我们每个学Python人中的心痛. 装饰器作用:是用来装饰其他函数的,为其他函数添加新功能. 原则:1.不能改变被修饰函数的源代码. 2.不能修改被修饰函数的调用方式. 学装饰器前还需要了 ...

  8. win10 UWP 标签

    本文主要翻译:http://visuallylocated.com/post/2015/02/20/Creating-a-WrapPanel-for-your-Windows-Runtime-apps ...

  9. DOS常用命令及进制转换

    DOS是一种用户单任务磁盘操作系统.在DOS中,我们可以通过DOS命令来管理设备和文件,如打印文件.删除文件,复制文件,创建新的文件夹和文档并编写内容等功能同时也是JAVA编程基础的一个入门.进入DO ...

  10. eclipse+fileSyncPlugin+svn+jenkins+tomcat

    实现一个想法,把项目部署在linux服务器上,在本地的eclipse代码更新后,通过svn+jenkins自动同步到服务器, 然后通过eclipse远程debug项目.这样是不是就解决了在本地跑项目, ...