sqlserver,获取调用存储过程返回数据的方法。
2017-08-14 15:20
681 查看
1,获取存储过程最后select返回的结果集。SELECT 数据集返回值。
因为select返回的结果是一个表。所以返回的结果需要用一个表接收。使用临时表接收。
被调用的存储过程最后是这样:返回了一个空标题的字段。
什么都不处理,调用存储过程,发现是这样:
执行结果:
会发现返回了三个数据集,不仅原来的存储过程会返回一个数据集(这里的情况是不需要那个存储过程返回,而是赋值给变量,由变量返回),这里调用原来的存储过程也并没有真正赋值给变量。所有返回的变量的值仍然为空。
我们真正的需求是只返回一个被赋值了的BATCHCODE。
修改:用临时表接收返回结果集,把临时表的相关字段赋值给变量。如下:
执行结果:
可见,被调用的存储过程没有返回一个select结果集,并且,值被成功的赋值给变量。只返回了一个数据集。
2,OUPUT参数返回值
存储过程中获得方法:
3,RETURN过程返回值
存储过程中的获取方法
因为select返回的结果是一个表。所以返回的结果需要用一个表接收。使用临时表接收。
被调用的存储过程最后是这样:返回了一个空标题的字段。
什么都不处理,调用存储过程,发现是这样:
ALTER PROCEDURE [LC0**999].[ERP_***_CreateBatchCode] ( @MaterialID varchar(50), @CompanyID varchar(50), @Flag varchar(50), @PrefixObj varchar(50) ) AS BEGIN declare @v_batchcode varchar(36); exec @v_batchcode=erp_IM_BatchesSN_CreateCode @MaterialID,@CompanyID,@Flag,@PrefixObj; select @v_batchcode BATCHCODE; END
执行结果:
会发现返回了三个数据集,不仅原来的存储过程会返回一个数据集(这里的情况是不需要那个存储过程返回,而是赋值给变量,由变量返回),这里调用原来的存储过程也并没有真正赋值给变量。所有返回的变量的值仍然为空。
我们真正的需求是只返回一个被赋值了的BATCHCODE。
修改:用临时表接收返回结果集,把临时表的相关字段赋值给变量。如下:
ALTER PROCEDURE [LC00****].[ERP_****_CreateBatchCode] ( @MaterialID varchar(50), @CompanyID varchar(50), @Flag varchar(50), @PrefixObj varchar(50) ) AS BEGIN declare @v_batchcode varchar(36); CREATE TABLE [LC0019999].[batchtemp]( batchcode varchar(36) ) INSERT batchtemp exec @v_batchcode=erp_IM_BatchesSN_CreateCode @MaterialID,@CompanyID,@Flag,@PrefixObj; SELECT @v_batchcode=batchtemp.batchcode FROM batchtemp; DROP TABLE batchtemp; select @v_batchcode BATCHCODE; END
执行结果:
可见,被调用的存储过程没有返回一个select结果集,并且,值被成功的赋值给变量。只返回了一个数据集。
2,OUPUT参数返回值
CREATE PROCEDURE [dbo].[nb_order_insert]( @o_buyerid int , @o_id bigint OUTPUT ) AS BEGIN SET NOCOUNT ON; BEGIN INSERT INTO [Order](o_buyerid ) VALUES (@o_buyerid ) SET @o_id = @@IDENTITY END END
存储过程中获得方法:
DECLARE @o_buyerid int DECLARE @o_id bigint EXEC [nb_order_insert] @o_buyerid,@o_id output
3,RETURN过程返回值
CREATE PROCEDURE [dbo].[nb_order_insert]( @o_buyerid int , @o_id bigint OUTPUT ) AS BEGIN SET NOCOUNT ON; IF(EXISTS(SELECT * FROM [Shop] WHERE [s_id] = @o_buyerid )) BEGIN INSERT INTO [Order](o_buyerid ) VALUES (@o_buyerid ) SET @o_id = @@IDENTITY RETURN 1 — 插入成功返回1 END ELSE RETURN 0 — 插入失败返回0 END
存储过程中的获取方法
DECLARE @o_buyerid int DECLARE @o_id bigint DECLARE @result bit EXEC @result = [nb_order_insert] @o_buyerid ,o_id output
相关文章推荐
- C#中的类SqlCommand对象使用方法ExecuteNonQuery()调用SQLServer存储过程时,存储过程执行成功,数据发生改变,但是返回-1
- php pdo调用SQLServer存储过程无法获取返回结果
- SQLServer 中存储过程返回的三种方式( 包括存储过程的创建, 在存储过程中调用, 在VS中调用的方法)
- 基于C#中的类SqlCommand对象调用SQLServer存储过程时,存储过程执行成功,但是对象方法ExecuteNonQuery()返回-1
- SQLServer 中存储过程返回的三种方式( 包括存储过程的创建, 在存储过程中调用, 在VS中调用的方法)
- SQLServer 中存储过程返回的三种方式( 包括存储过程的创建, 在存储过程中调用, 在VS中调用的方法)
- 使用企业库调用存储过程(带参数)完成数据获取样例
- SqlParameter设定的value值为0时、调用的存储过程获取到的值却为null解决方法
- java调用存储过程同时获取[返回参数]和[结果集]
- sqlserver 2008 存储过程调用存储过程或方法
- Java调用oracle存储过程通过游标返回临时表数据
- SqlServer获取存储过程的返回值
- (转)jdbc 调用 sql server 的存储过程时“该语句没有返回结果集”的解决方法
- .Nettiers的事件:下拉控件数据绑定,Insert,调用自定存储过程,获取新增ID,事务,DeepLoad,DeepSave,Save,Update,DeepDelete【原创】
- 存储过程返回的多结果集数据,ado 访问调用
- [转]SQLSERVER存储过程调用不同数据库的数据_存储过程中通过链接服务器访问远程服务器
- OCCI调用带有返回结果集的存储过程,获取结果集中指定列的值
- 利用SQLServer查询分析器获取存储过程的返回值,检查测试存储过程
- SQLServer和ORACLE 存储过程的调用(返回结果集)
- java 调用oracle 分页存储过程 返回游标数据集