В Microsoft SQL Server Managment Studio большой запрос возвращает все выборки. Как сделать что б после Command.Execute получить програмно все выбранные таблицы. Т.е.
create PROCEDURE [dbo].p1 begin
select 1 select 2,3 -- выборка
end
/*results:
1
2 3*/
Что б дало две таблицы а не одну. Да запрос можно "разделить" на два, но до тех пор пока нет связи между ними через локальные переменные. Можно конечно и их передать, но Studio ловит две три таблицы из выполняемой хранимой процедуры.
1) Пробовал OleDb - там дополнительных курсоров не получилось получить. Думаю что поддержка нескольких таблиц заложена в sqlncli.dll. 2) Возможно как-то можно средствами sql сделать такую выборку, что б сложить таблицы в таблицу (курсорное поле), или например с помощью sp_msforeachtable.
Ответ
Попробуйте поработать с объектом ADO Recordset для С++.
Пример работы с Recordset в VBA:
Dim rsTree As ADODB.Recordset
Dim rsTreeGrp As ADODB.Recordset
Dim rsGrp As ADODB.Recordset
Set rsTree = ExecuteRS("usp_pct_CatList", 2, 0, "")
Set rsTreeGrp = rsTree.NextRecordset()
Set rsGrp = rsTreeGrp.NextRecordset()
Процедура usp_pct_CatList возвращает три выборки.
Комментариев нет:
Отправить комментарий