1>能  :只有定义多个output型    或者通过建立表存储记录集
2>自己定义一个字符串,来存储你要传出去的字符,然后在外部对该字符传进行分割

解决方案 »

  1.   

    如果要返回值的话可以通过多个output参数。
      

  2.   

    我是定义了两个OUTPUT,在DELPHI中接收,可是它提示:"不正常的定义参数对象.提供了不一致或不完整的信息".这个错在哪?
      

  3.   

    create procedure MyTest
    @ID varchar(20),@Name varchar(20),@COrP varchar(1),
    @ErrorStr varchar(200) output,@ErrorID int output
    As
    Insert into Company(ID,Name,COrP)
    Values(@ID,@Name,@COrP)
    set @ErrorID = @@Error
    if (@@Error>0)
    begin
     raiserror('insert into error',16,1)
     set @ErrorStr = 'insert into error'
    end
    select * from Company
    我的过程是这样的,可能是存储过程的问题,在查询分析器里也说:
    '过程 'MyTest' 需要参数 '@ErrorStr',但未提供该参数。'
      

  4.   

    是不是这样申明的:@ErrorStr varchar(200) output,@ErrorID int output
      

  5.   

    調用有問題
    exec MyTest @id = '1' , @name = 'aa' , @COrp = '1' , @ErrorStr = '' , @ErrorId = 0
      

  6.   

    declare @ErrorStr varchar(200) 
    declare @ErrorID int
      

  7.   


    --我想你可能也是在执行存储过程时,发生了问题,你这样做,试一下吧--在执行存储过程时,应该首先声明输出参数:declare @ErrorStr varchar(200),@ErrorID int 
    exec MyTest '给出@ID的值','给出@Name的值','给出@COrP的值 ',@ErrorStr output,@ErrorID output
    select @ErrorStr,@ErrorID
      

  8.   

    D. 使用 OUTPUT 参数
    OUTPUT 参数允许外部过程、批处理或多条 Transact-SQL 语句访问在过程执行期间设置的某个值。下面的示例创建一个存储过程 (titles_sum),并使用一个可选的输入参数和一个输出参数。首先,创建过程:USE pubs
    GO
    IF EXISTS(SELECT name FROM sysobjects
          WHERE name = 'titles_sum' AND type = 'P')
       DROP PROCEDURE titles_sum
    GO
    USE pubs
    GO
    CREATE PROCEDURE titles_sum @TITLE varchar(40) = '%', @SUM money OUTPUT
    AS
    SELECT 'Title Name' = title
    FROM titles 
    WHERE title LIKE @TITLE 
    SELECT @SUM = SUM(price)
    FROM titles
    WHERE title LIKE @TITLE
    GO接下来,将该 OUTPUT 参数用于控制流语言。 说明  OUTPUT 变量必须在创建表和使用该变量时都进行定义。
    参数名和变量名不一定要匹配,不过数据类型和参数位置必须匹配(除非使用 @SUM = variable 形式)。 DECLARE @TOTALCOST money
    EXECUTE titles_sum 'The%', @TOTALCOST OUTPUT
    IF @TOTALCOST < 200 
    BEGIN
       PRINT ' '
       PRINT 'All of these titles can be purchased for less than $200.'
    END
    ELSE
       SELECT 'The total cost of these titles is $' 
             + RTRIM(CAST(@TOTALCOST AS varchar(20)))下面是结果集:Title Name                                                               
    ------------------------------------------------------------------------ 
    The Busy Executive's Database Guide
    The Gourmet Microwave
    The Psychology of Computer Cooking(3 row(s) affected)Warning, null value eliminated from aggregate.
     
    All of these titles can be purchased for less than $200.