Доступ к DataTables в DataSet с именем таблицыC#

Место общения программистов C#
Ответить
Anonymous
 Доступ к DataTables в DataSet с именем таблицы

Сообщение Anonymous »

В настоящее время я пишу программу, которая получает 3 таблицы из SQL с данными из каждой таблицы, которую я использую, и строкой для создания объекта соответствующего класса.
После этапа отладки постепенно я вижу, что данные внутри набора данных действительно верны, но я не могу получить к ним доступ по имени.
Когда я получаю доступ к таблицам внутри набора данных, используя их индекс, это работает отлично, вот так -< /p>

Код: Выделить всё

DataSet ds = new ProgramProcedures().GetTestByUser(UserId);
if (ds.Tables[0].IsHasRows())
{
foreach (DataRow _dr in ds.Tables[0].Rows)
{
TestList.Add(new Test(_dr));
}
}
Когда я пытаюсь получить к нему доступ по имени, он терпит неудачу и не вводит оператор if.

Код: Выделить всё

DataSet ds = new ProgramProcedures().GetTestByUser(UserId);
if (ds.Tables["Name1"].IsHasRows())
{
foreach (DataRow _dr in ds.Tables["Name1"].Rows)
{
TestList.Add(new Test(_dr));
}
}
Внутри хранимой процедуры данные поступают из следующих строк:

Код: Выделить всё

@tables nvarchar(max)='' output
set @tables='Name1,Name2,Name3'
При отладке и проверке содержимого переменной ds данные верны, но имена таблиц — «Таблица, Таблица1, Таблица2»
Что я делаю не так? Я хотел бы получить доступ к таблицам по имени, поскольку это делает код более надежным в случае внесения каких-либо изменений в него или процедуру.
Вместо этого я попробовал использовать индексы таблицы. из их имен это сработало отлично, но я бы хотел использовать имена таблиц.

Подробнее здесь: https://stackoverflow.com/questions/776 ... table-name
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»