#c_sharp #cpp #sql #sql_server #oledb
В 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.
Ответы
Ответ 1
Попробуйте поработать с объектом 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 возвращает три выборки.
Комментариев нет:
Отправить комментарий