考虑以下sql
一个名为myProc的存储过程,它返回两个结果集。结果集1返回column1,column2。结果集2返回第3列第4列第5列。
以下sql将失败,因为临时表只定义了2个int列。
Create Table #temp1(
Column1 int,
Column2 int)
insert into #temp1 exec myProc
我的问题是是否可以将第一个结果集插入#temp1?
答案 0 :(得分:3)
旧帖子,但是我遇到了同样的问题,虽然上面提到的答案有点相关,但OP的问题是关于返回多组的SP。除了重写SP以将其拆分为更小的SP之外,我能找到的唯一解决方案是编写执行SP的SQL CLR
过程并仅返回所需的结果集。该过程获取所需结果集的索引,执行SqlCommand
以运行初始T-SQL
SP,然后遍历SqlDataReader
结果,直到找到所需的结果集并返回相应的记录。以下代码是SQL CLR
过程的一部分:
SqlDataReader rdr = command.ExecuteReader();
int index = 0;
bool bContinue = true;
while (index < resultSetIndex.Value)
{
if (!rdr.NextResult())
{
bContinue = false;
break;
}
index++;
}
if (!bContinue)
throw new Exception("Unable to read result sets.");
.......
List<SqlMetaData> metadataList = new List<SqlMetaData>();
for (int i = 0; i < rdr.FieldCount; i++)
{
string dbTypeName = rdr.GetDataTypeName(i);
SqlMetaData metadata;
if (dbTypeName.ToLower().Contains("char"))
metadata = new SqlMetaData(rdr.GetName(i), (SqlDbType)Enum.Parse(typeof(SqlDbType), dbTypeName, true), 50);
else
metadata = new SqlMetaData(rdr.GetName(i), (SqlDbType)Enum.Parse(typeof(SqlDbType), dbTypeName, true));
metadataList.Add(metadata);
}
SqlDataRecord record = new SqlDataRecord(metadataList.ToArray());
object[] values = new object[rdr.FieldCount];
if (rdr.HasRows)
{
SqlContext.Pipe.SendResultsStart(record);
while (rdr.Read())
{
rdr.GetValues(values);
record.SetValues(values);
SqlContext.Pipe.SendResultsRow(record);
}
SqlContext.Pipe.SendResultsEnd();
}
答案 1 :(得分:2)
还有另一种方式
SELECT * into #temp
from OPENROWSET('SQLNCLI', 'Server=(local)\\(instance);Trusted_Connection=yes;',
'EXEC (database).(schema).(sproc)')
这会将第一个结果集插入到#temp
中