zoukankan      html  css  js  c++  java
  • 用SQL语句获得一个存储过程返回的表

    定义一个存储过程如下:

    create proc [dbo].[test1]
    @id int
    as
    select 1 as id,'abc' as name union all
    select @id as id,'zzz' as name

    返回两行数据.
    现在想用SQL语句来调用这个存储过程,并把他返回的表放入变量中.可以如下做:

    declare @table table(id   int,name varchar(50))--定义表变量来存放存储过程返回的内容
    insert into @table exec test1 2--将存储过程执行的结果放入表变量中
    select *
    from @table --查看表变量中的结果

    -------------------------------------------------------------------------------------------------

    使用心得:

    原先准备直接通过存储过程的output变量返回table,发现失败,

    换成函数可以返回,但函数内部禁用了很多系统函数,例如exec,无法实现复杂的sql,

    最终,通过存储过程直接

    “insert into @table exec test1 2--将存储过程执行的结果放入表变量中”

    的方式,将存储过程的返回值放入临时表变量,间接实现返回表变量

  • 相关阅读:
    函数的有用信息,装饰器 day12
    函数名、闭包、装饰器 day11
    函数的动态参数与命名空间 day10
    函数 day9
    集合 day8
    文件操作 day8
    基础数据类型补充,及capy daty7
    day7 回顾
    编码补充 daty 6
    字典的增删改查 daty 5
  • 原文地址:https://www.cnblogs.com/jx270/p/5114349.html
Copyright © 2011-2022 走看看