SQLServerを使用しています。別のストアドプロシージャからストアドプロシージャを呼び出しています。
最初のストアドプロシージャから複数の値を返したい。
例:から電話をかけSub_SP
ていMaster_SP
ます。Sub_SP
複数の値をに返しますMaster_SP
。
誰かがOUTPUTパラメータの例を挙げられますか?
ありがとうございました。
SQLServerを使用しています。別のストアドプロシージャからストアドプロシージャを呼び出しています。
最初のストアドプロシージャから複数の値を返したい。
例:から電話をかけSub_SP
ていMaster_SP
ます。Sub_SP
複数の値をに返しますMaster_SP
。
誰かがOUTPUTパラメータの例を挙げられますか?
ありがとうございました。
ALTER procedure ashwin @empid int,@empname varchar(20) output,@age int output
as
select @empname=ename,@age=age
from emp where empid=@empid;
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();
}
}
これはどう:
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
テストマスターストアドプロシージャ:
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
これは機能しますか?これで問題は解決しますか?そうでない場合:どこで立ち往生していますか、問題は正確には何ですか?
私は同じ問題を抱えていて、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(New SqlParameter( "@ age"、SqlDbType.Int、20、ParameterDirection.Output、false、0、10、 "age"、DataRowVersion.Default、Nothing))の最後のパラメーターは、次のような初期値です。これらの変数を提供します(ここでは何もありません)。