INSERT EXEC 语句

INSERT EXEC语句可以把存储过程或动态SQL批处理返结果集插入目标数据表中,下面例子是以存储过程返回结果集插入一个表变量中,

演示例子,首选创建一个存储过程,这个存储过程需要传入一个参数,是否在职的Member。

代码
IF   OBJECT_ID ( ' dbo.usp_Member_Job ' , ' p ' IS   NOT   NULL
DROP   PROCEDURE  dbo.usp_Member_Job
GO

CREATE   PROCEDURE  dbo.usp_Member_Job
    
@IsJob   BIT
AS
IF   @IsJob   =   1
    
SELECT   [ MemberId ] , [ Name ] , [ Job ]   FROM   [ dbo ] . [ Member ]   WHERE   [ Job ]   =   @IsJob
ELSE
    
SELECT   [ MemberId ] , [ Name ] , [ Job ]   FROM   [ dbo ] . [ Member ]   WHERE   [ Job ]   =   @IsJob   OR   [ Job ]   IS   NULL

  

创建一个表变量,

DECLARE   @IsJobMember   AS   TABLE
(
[ MemberId ]   [ int ]   NOT   NULL ,
    
[ Name ]   [ nvarchar ] ( 100 NOT   NULL ,
    
[ Job ]   [ bit ]   NULL
);

  

最后是真正使用INSERT EXEC来把存储过程结果插入表变量中,

INSERT   INTO   @IsJobMember   EXECUTE  dbo.usp_Member_Job  1 ;

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值