2012-06-06 3 views
8

Я использую SQL Server. Я вызываю хранимую процедуру из другой хранимой процедуры.Возвращение нескольких значений из хранимой процедуры

Я хочу вернуть несколько значений из первой хранимой процедуры.

Ex: Я звоню Sub_SP от Master_SP. Sub_SP вернет несколько значений до Master_SP.

Может ли кто-нибудь привести пример с параметрами OUTPUT?

спасибо.

+0

массив, например, первая идея. – Sajmon

+0

только параметр OUTPUT – Shami

+0

Я считаю, что @Mithrandir предлагал вам опубликовать свой код .... –

ответ

16
ALTER procedure ashwin @empid int,@empname varchar(20) output,@age int output 
as 
select @empname=ename,@age=age 
from emp where [email protected]; 

declare @ename varchar(20),@age int 
execute ashwin 101,@ename out,@age out 
select @ename,@age; 

// ------------

namespace sqlserver 
{ 
    class Program 
    { 
     static void Main(string[] args) 
     { 

      createconnection(); 
     } 
     public static void createconnection() 
     { 
      SqlConnection con=new SqlConnection("Data Source=ASHWIN\\SQLEXPRESS;Initial Catalog=employee;Integrated Security=True;Pooling=False"); 
      con.Open(); 

      SqlCommand cmd=new SqlCommand("ashwin",con); 
      cmd.CommandType=CommandType.StoredProcedure; 
      cmd.Parameters.Add(new SqlParameter("@empid",SqlDbType.Int,10,"empid")); 
      cmd.Parameters.Add(new SqlParameter("@empname", SqlDbType.VarChar, 20,ParameterDirection.Output,false,0,20,"ename",DataRowVersion.Default,null)); 
      cmd.Parameters.Add(new SqlParameter("@age", SqlDbType.Int, 20, ParameterDirection.Output, false, 0, 10, "age", DataRowVersion.Default, null)); 
      cmd.Parameters[0].Value = 101; 
      cmd.UpdatedRowSource = UpdateRowSource.OutputParameters; 
      cmd.ExecuteNonQuery(); 
      string name = (string)cmd.Parameters["@empname"].Value; 
      int age = Convert.ToInt32(cmd.Parameters["@age"].Value); 
      Console.WriteLine("the name is {0}--and age is {1}", name,age); 


      Console.ReadLine(); 
     } 
    } 
7

Как об этом:

CREATE PROCEDURE dbo.SubSP 
    @Value1 INT OUTPUT, @Value2 INT OUTPUT 
AS 
    -- just return two values into the OUTPUT parameters somehow.... 
    SELECT @Value1 = 42, @Value2 = 4711 

Протестируйте dbo.SubSP:

DECLARE @Out1 INT, @Out2 INT 

EXEC dbo.SubSP @Out1 OUTPUT, @Out2 OUTPUT -- int 

SELECT @Out1, @Out2 

дает выход:

@Out1 @Out2 
    42  4711  

Затем создать "мастер" хранимую процедуру:

CREATE PROCEDURE dbo.MasterSP 
    @SomeValue1 INT OUTPUT, @SomeValue2 INT OUTPUT, @SomeValue3 INT OUTPUT 
AS BEGIN 
    DECLARE @Out1 INT, @Out2 INT 

    -- call the "sub" stored procedure and capture OUTPUT values 
    EXEC dbo.SubSP @Out1 OUTPUT, @Out2 OUTPUT 

    -- return those values - plus some others - from master stored procedure 
    SELECT @SomeVAlue1 = @Out1, @SomeVAlue2 = @Out2, @SomeValue3 = 9901 
END 

Test мастер ХП:

DECLARE @Some1 INT, @Some2 INT, @Some3 INT 

EXECUTE dbo.MasterSP @Some1 OUTPUT, @Some2 OUTPUT, @Some3 OUTPUT 

SELECT @Some1, @Some2, @Some3 

дает выход:

(No column name) (No column name) (No column name) 
     42    4711   9901 

ли эта работа? Помогает ли это решить вашу проблему? Если нет: где вы застряли, то что точно есть проблема?

0

У меня была такая же проблема, и я работаю в VB. Я попробовал ответить @ Scorpian275. Это то же самое решение, что и @ Scorpian275, но это для VB. Часть sql такая же.

Public Shared Sub createConnection() 
     Dim con As SqlConnection = New SqlConnection("Data Source=ASHWIN\\SQLEXPRESS;Initial Catalog=employee;Integrated Security=True;Pooling=False") 
     con.Open 
     Dim cmd As SqlCommand = New SqlCommand("ashwin", con) 
     cmd.CommandType = CommandType.StoredProcedure 
     cmd.Parameters.Add(New SqlParameter("@empid", SqlDbType.Int, 10, "empid")) 
     cmd.Parameters.Add(New SqlParameter("@empname", SqlDbType.VarChar, 20, ParameterDirection.Output, false, 0, 20, "ename", DataRowVersion.Default, Nothing)) 
     cmd.Parameters.Add(New SqlParameter("@age", SqlDbType.Int, 20, ParameterDirection.Output, false, 0, 10, "age", DataRowVersion.Default, Nothing)) 
     cmd.Parameters(0).Value = 101 
     cmd.UpdatedRowSource = UpdateRowSource.OutputParameters 
     cmd.ExecuteNonQuery 
     Dim name As String = CType(cmd.Parameters("@empname").Value,String) 
     Dim age As Integer = Convert.ToInt32(cmd.Parameters("@age").Value) 
     Console.WriteLine("the name is {0}--and age is {1}", name, age) 
     Console.ReadLine 
    End Sub 

Последний параметр в cmd.Parameters.Add (Новый SqlParameter ("@ возраст", SqlDbType.Int, 20, ParameterDirection.Output, ложь, 0, 10, "возраст", DataRowVersion.Default, Nothing)) - это начальное значение, которое мы предоставляем для этих переменных (здесь Nothing).

Смежные вопросы