SQLServer 中存储过程返回的三种方式( 包括存储过程的创建, 在存储过程中调用, 在VS中调用的方法)
存储过程有三种返回:   
1.   用return返回数字型数据   
2.   用返回参数返回结果,可以返回各种数据类型(通过游标来循环查询结果每一行)   
3.   直接在存储过程中用select返回结果集,可以是任意的select语句,这意味着是任意的返回结果集
 
方法一:用return返回数字型数据 
1. 创建存储过程
--SQLSERVER 2005示例数据库
USE AdventureWorks
GO
CREATE PROCEDURE checkstate 
@param VARCHAR(11)
AS
IF (
       SELECT StateProvince
       FROM   Person.vAdditionalContactInfo
       WHERE  ContactID = @param
   ) = 'WA'
    RETURN 1
ELSE
    RETURN 2;
GO
2. 在存储过程中调用
DECLARE @return_status INT;
EXEC @return_status = checkstate '9';  --将存储过程返回值赋给@return_status
SELECT 'Return Status' = @return_status;
GO
3. 在VS中调用
 List<DbParameter> para = new List<DbParameter>();
        para.Add(new SqlParameter("@param", 9));
        SqlParameter pa = new SqlParameter();
        pa.ParameterName = "@return";
        pa.SqlDbType = SqlDbType.Int;
        pa.Direction = ParameterDirection.ReturnValue;
        para.Add(pa);
        int i = DBHelper.ExecuteSql("checkstate", CommandType.StoredProcedure, para);
        Response.Write(para[1].Value.ToString());
 
 
方法二:用返回参数返回结果,可以返回各种数据类型(通过游标来循环查询结果每一行)   
1. 创建存储过程
--SQLSERVER 2005示例数据库
USE AdventureWorks
GO
CREATE PROCEDURE OutPutValue 
@param VARCHAR(11),
@param2 VARCHAR(11) OUTPUT
AS
IF (
       SELECT StateProvince
       FROM   Person.vAdditionalContactInfo
       WHERE  ContactID = @param
   ) = 'WA'
   SET @param2='Good'
ELSE
   SET @param2='Bad'
GO
2. 在存储过程中调用
DECLARE @param1 NVARCHAR(100)
DECLARE @param2 NVARCHAR(100)
SET @param1='9'
EXEC OutPutValue '9',@param2 OUTPUT
SELECT @param2
3. 在VS中调用
     List<DbParameter> para = new List<DbParameter>();
        para.Add(new SqlParameter("@param", "9"));
        SqlParameter pa = new SqlParameter();
        pa.Direction = ParameterDirection.Output;
        pa.ParameterName = "@param2";
        pa.Size = 11;
        para.Add(pa);
        int i = DBHelper.ExecuteSql("OutPutValue ", CommandType.StoredProcedure, para);
        //OutPut返回值
        Response.Write(para[1].Value.ToString());  //输出返回值
 
 
方法三:直接在存储过程中用select返回结果集,可以是任意的select语句,这意味着是任意的返回结果集  
1. 创建存储过程
--SQLSERVER 2005示例数据库
USE AdventureWorks
GO
CREATE PROCEDURE ReturnDataTable
AS
BEGIN
SELECT * FROM Person.vAdditionalContactInfo
END 
GO
2. 在存储过程中调用
EXEC ReturnDataTable
3. 在VS中调用
//存储过程返回结果集可存放在DataTable
 DataTable dt = DBHelper.GetDataTable("ReturnDataTable", CommandType.StoredProcedure);

SQLServer 中存储过程的更多相关文章

  1. Sqlserver中存储过程,触发器,自定义函数(二)

    Sqlserver中存储过程,触发器,自定义函数: 自定义函数:1.函数类型:2.函数的参数和返回值: 1.函数类型:标量值函数,返回的是一个标量值表值函数:内联表值函数:多语句表值函数. 标量值函数 ...

  2. Sqlserver中存储过程,触发器,自定义函数(一)

    Sqlserver中存储过程,触发器,自定义函数 1.存储过程有关内容存储过程的定义:存储过程的分类:存储过程的创建,修改,执行:存储过程中参数的传递,返回与接收:存储过程的返回值:存储过程使用游标. ...

  3. Sqlserver中存储过程,触发器,自定义函数

    Sqlserver中存储过程,触发器,自定义函数: 1. 触发器:是针对数据库表或数据库的特殊存储过程,在某些行为发生的时候就会被激活 触发器的分类: DML触发器:发生在数据操作语言执行时触发执行的 ...

  4. SqlServer中存储过程中将Exec的执行结果赋值给变量输出

    原文 SqlServer中存储过程中将Exec的执行结果赋值给变量输出 背景: 遇到这样一种情况:动态向存储过程中传入表名和表的某些属性(这里用到的是主键ID),然后利用这两个变量查出一条数据的某些字 ...

  5. SqlServer中存储过程 returnC#代码处理以及对应的MySQL如何改写

    一.SqlServer 中 1. 创建表 create table testuser( id int, --primary key, names ), address ), paw ) ) 2.创建存 ...

  6. sqlserver 中存储过程的基础知识记录

    1.什么是存储过程? 存储过程就是作为可执行对象存放在数据库中的一个或多个SQL命令. 通俗来讲:存储过程其实就是能完成一定操作的一组SQL语句. 2.为什么要用存储过程? 1)存储过程只在创建时进行 ...

  7. Sqlserver中存储过程和游标的一些使用例子

    /*带输入输出参数存储过程*/ ALTER PROCEDURE pro_test2 @userID INT, @maxUserID INT OUTPUT, @countUser INT OUTPUT ...

  8. SQLServer中存储过程StoredProcedure创建及C#调用(转)

    此文作为入门了解用,转自http://www.2cto.com/database/201502/378260.html 存储过程就是已经编译好的.优化过的放在数据库服务器中的一些SQL语句:可供应用程 ...

  9. SqlServer和MySQL中存储过程out返回值处理C#代码

    1.SqlServer中out处理 C#代码 #region"SqlServer中存储过程处理out返回值" //public void getdata() //{ // stri ...

随机推荐

  1. 启动eclipse出现JVM terminated. Exit code=127 错误解决办法

    https://blog.csdn.net/wpzsidis/article/details/72954387 进去第二次又错

  2. Illegal mix of collations (latin1_swedish_ci,IMPLICIT) and (utf8_general_ci...

    最近刚接触mysql,今天用mysql插入中文字符的时候,程序报错“Illegal mix of collations (latin1_swedish_ci,IMPLICIT) and (utf8_g ...

  3. 6.Srust2结果页面跳转

    1. 结果页面存在两种方式 * 全局结果页面 > 条件:如果<package>包中的一些action都返回success,并且返回的页面都是同一个JSP页面,这样就可以配置全局的结果 ...

  4. 尝试让Virtualbox的Ubuntu可以调整分辨率

    在Virtualbox安装的Ubuntu,默认不是全屏,操作起来不是很方便,网上查了资料,按照网上的教程来操作并记录下自己的操作记录. 在安装的Ubuntu的虚拟机,通过 "设备" ...

  5. No parser no filepath given问题解决

    关于 vue 项目 run dev 的时候,控制台警告: No parser and no filepath given, using 'babylon' the parser now but thi ...

  6. [转]Delphi DLL的创建、静态 以及动态调用

    第一章  DLL简单介绍 由于在目前的学习工作中,需要用到DLL文件,就学习了下,在这里作个总结. 首先装简单介绍下DLL: 1,减小可执行文件的大小 DLL技术的产生有很大一部分原因是为了减小可执行 ...

  7. Dubbox框架和Zookeeper 依赖的引入

    <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://mave ...

  8. mysql利用st_distance函数查询附近的点的功能

    随着近几年各类移动终端的迅速普及,在手机移动定位app中,附近的人,附近的地点功能十分常见,基于地理位置的服务(LBS)和相关应用也越来越多,而支撑这些应用的最基础技术之一,就是基于地理位置信息的处理 ...

  9. 树形dp换根,求切断任意边形成的两个子树的直径——hdu6686

    换根dp就是先任取一点为根,预处理出一些信息,然后在第二次dfs过程中进行状态的转移处理 本题难点在于任意割断一条边,求出剩下两棵子树的直径: 设割断的边为(u,v),设down[v]为以v为根的子树 ...

  10. C++学习 | C++ Implement的使用 | 消除 warning C4251 | 精简库接口

      在编写C++动态库的过程中,我们常常会听到某个要求:请隐藏动态库头文件里类接口里的成员变量!或者自己在编写动态库时,突然意识到自己好像让调用者看到的信息太多了,而这些信息根本无需被调用者看到,往往 ...