public static ДокументыВыборка.ИсполнительныйЛист ВыбратьПоНомеру(int Первые,string Мин,string Макс)
{
using (var Подключение = new SqlConnection(СтрокаСоединения))
{
Подключение.Open();
using (var Команда = Подключение.CreateCommand())
{
Команда.CommandText = string.Format(@"Select top {0}
_IDRRef [Ссылка]
,_Version [Версия]
,_Marked [ПометкаУдаления]
,_Fld5341RRef [Физлицо]
,_Fld5342RRef [Организация]
,_Fld5343 [ВидИсполнительногоДокумента]
,_Fld5344 [РеквизитыИсполнительногоДокумента]
,_Fld5345RRef [Получатель]
,_Fld5346 [ДатаНачала]
,_Fld5347 [ДатаОкончания]
,_Fld26788RRef [СпособРасчетаУдержания]
,_Fld5349 [Размер]
,_Fld5350 [Предел]
,_Fld26789RRef [ПрожиточныйМинимум]
,_Fld5354 [ДатаДействия]
,_Fld5355 [ПроцентПочтовогоСбора]
,_Fld26790RRef [Тариф]
,_Fld26791RRef [СпособПеречисленияПоИсполнительномуЛисту]
,_Fld26792RRef [ТарифБанкаНаДенежныеПереводы]
,_Fld26793 [ПочтовыйСборРассчитыватьПроцентом]
,_Fld26794 [ДанныеПрошлойВерсии]
,_Fld5352RRef [Ответственный]
,_Fld5353 [Комментарий]
,_Fld5348 [УдалитьСпособРасчетаИЛ]
,_Fld26795 [УдалитьСпособРасчетаПС]
,_Fld5351 [УдалитьУчитыватьБольничныеЛисты]
From _Document294(NOLOCK)
Where _Code between @Мин and @Макс
Order by _Code", Первые);
Команда.Parameters.AddWithValue("Мин", Мин);
Команда.Parameters.AddWithValue("Макс", Макс);
var Выборка = new V82.ДокументыВыборка.ИсполнительныйЛист();
using (var Читалка = Команда.ExecuteReader())
{
while (Читалка.Read())
{
var Ссылка = new ДокументыСсылка.ИсполнительныйЛист();
//ToDo: Читать нужно через GetValues()
Ссылка.Ссылка = new Guid((byte[])Читалка.GetValue(0));
var ПотокВерсии = ((byte[])Читалка.GetValue(1));
Array.Reverse(ПотокВерсии);
Ссылка.Версия = BitConverter.ToInt64(ПотокВерсии, 0);
Ссылка.ВерсияДанных = Convert.ToBase64String(ПотокВерсии);
Ссылка.ПометкаУдаления = ((byte[])Читалка.GetValue(2))[0]==1;
Ссылка.ВидИсполнительногоДокумента = Читалка.GetString(5);
Ссылка.РеквизитыИсполнительногоДокумента = Читалка.GetString(6);
Ссылка.ДатаНачала = Читалка.GetDateTime(8);
Ссылка.ДатаОкончания = Читалка.GetDateTime(9);
Ссылка.СпособРасчетаУдержания = V82.Перечисления/*Ссылка*/.СпособыРасчетаУдержанийПоИЛ.ПустаяСсылка.Получить((byte[])Читалка.GetValue(10));
Ссылка.Размер = Читалка.GetDecimal(11);
Ссылка.Предел = Читалка.GetDecimal(12);
Ссылка.ДатаДействия = Читалка.GetDateTime(14);
Ссылка.ПроцентПочтовогоСбора = Читалка.GetDecimal(15);
Ссылка.СпособПеречисленияПоИсполнительномуЛисту = V82.Перечисления/*Ссылка*/.СпособыПеречисленийПоИсполнительномуЛисту.ПустаяСсылка.Получить((byte[])Читалка.GetValue(17));
Ссылка.ПочтовыйСборРассчитыватьПроцентом = ((byte[])Читалка.GetValue(19))[0]==1;
Ссылка.ДанныеПрошлойВерсии = ((byte[])Читалка.GetValue(20))[0]==1;
Ссылка.Комментарий = Читалка.GetString(22);
Ссылка.УдалитьСпособРасчетаИЛ = Читалка.GetDecimal(23);
Ссылка.УдалитьСпособРасчетаПС = Читалка.GetDecimal(24);
Ссылка.УдалитьУчитыватьБольничныеЛисты = ((byte[])Читалка.GetValue(25))[0]==1;
Выборка.Add(Ссылка);
}
return Выборка;
}
}
}
}