sql - 从存储过程返回多个值

标签 sql sql-server stored-procedures

我正在使用 SQL Server。我正在从另一个存储过程调用一个存储过程。

我想从第一个存储过程返回多个值。

例如:我打电话 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();
        }
    }

关于sql - 从存储过程返回多个值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10911249/

相关文章:

c# - 在同一个 SqlDataReader 上混合异步和非异步调用是否存在任何已知问题?

c# - .NET Core 无法连接到 SQL DB

MySQL 存储过程权限

SQL 先按 0 排序,然后按数字/值降序

sql - 选择具有命名空间的列作为 XML

sql - SQL 过程可以返回表吗?

SQL Server 如何将3个查询合并为1个?

sql - Sybase ASE : "Your server command encountered a deadlock situation"

java - Oracle 嵌套表作为 Mybatis 存储过程的输入参数

mysql - #1052 - where 子句中的列 'syear' 不明确