public static СправочникиВыборка.Контрагенты Выбрать()
{
using (var Подключение = new SqlConnection(СтрокаСоединения))
{
Подключение.Open();
using (var Команда = Подключение.CreateCommand())
{
Команда.CommandText = @"Select top 1000
_IDRRef [Ссылка]
,_Version [Версия]
,_Marked [ПометкаУдаления]
,_IsMetadata [Предопределенный]
,_ParentIDRRef [Родитель]
,_Folder [ЭтоГруппа]
,_Code [Код]
,_Description [Наименование]
,_Fld1266 [НаименованиеПолное]
,_Fld1264 [Комментарий]
,_Fld1260 [ДополнительноеОписание]
,_Fld1258RRef [ГоловнойКонтрагент]
,_Fld1262RRef [ИсточникИнформацииПриОбращении]
,_Fld1263 [КодПоОКПО]
,_Fld1261 [ИНН]
,_Fld1265 [КПП]
,_Fld1276RRef [ЮрФизЛицо]
,_Fld1268RRef [ОсновнойБанковскийСчет]
,_Fld1270RRef [ОсновнойДоговорКонтрагента]
,_Fld1269RRef [ОсновнойВидДеятельности]
,_Fld1259 [ДокументУдостоверяющийЛичность]
,_Fld1271RRef [ОсновнойМенеджерПокупателя]
,_Fld1272 [Покупатель]
,_Fld1273 [Поставщик]
,_Fld1274 [РасписаниеРаботыСтрокой]
,_Fld1275 [СрокВыполненияЗаказаПоставщиком]
,_Fld1267RRef [ОсновноеКонтактноеЛицо]
,_Fld1277 [НеЯвляетсяРезидентом]
,_Fld1278RRef [ОКОПФ]
,_Fld1279RRef [Регион]
,_Fld21240RRef [ГруппаДоступаКонтрагента]
From _Reference78(NOLOCK) Where _Folder = 0x01 ";
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;
Ссылка.Предопределенный = ((byte[])Читалка.GetValue(3))[0]==1;
Ссылка.Родитель = V82.СправочникиСсылка.Контрагенты.ВзятьИзКэша((byte[])Читалка.GetValue(4));
Ссылка.ЭтоГруппа = ((byte[])Читалка.GetValue(5))[0]==0;
Ссылка.Код = Читалка.GetString(6);
Ссылка.Наименование = Читалка.GetString(7);
Ссылка.Комментарий = Читалка.GetString(9);
if(!Ссылка.ЭтоГруппа)
{
Ссылка.НаименованиеПолное = Читалка.GetString(8);
Ссылка.ДополнительноеОписание = Читалка.GetString(10);
Ссылка.ГоловнойКонтрагент = V82.СправочникиСсылка.Контрагенты.ВзятьИзКэша((byte[])Читалка.GetValue(11));
Ссылка.ИсточникИнформацииПриОбращении = V82.СправочникиСсылка.ИсточникиИнформацииПриОбращенииПокупателей.ВзятьИзКэша((byte[])Читалка.GetValue(12));
Ссылка.КодПоОКПО = Читалка.GetString(13);
Ссылка.ИНН = Читалка.GetString(14);
Ссылка.КПП = Читалка.GetString(15);
Ссылка.ЮрФизЛицо = V82.Перечисления/*Ссылка*/.ЮрФизЛицо.ПустаяСсылка.Получить((byte[])Читалка.GetValue(16));
Ссылка.ОсновнойБанковскийСчет = V82.СправочникиСсылка.БанковскиеСчета.ВзятьИзКэша((byte[])Читалка.GetValue(17));
Ссылка.ОсновнойДоговорКонтрагента = V82.СправочникиСсылка.ДоговорыКонтрагентов.ВзятьИзКэша((byte[])Читалка.GetValue(18));
Ссылка.ОсновнойВидДеятельности = V82.СправочникиСсылка.ВидыДеятельностиКонтрагентов.ВзятьИзКэша((byte[])Читалка.GetValue(19));
Ссылка.ДокументУдостоверяющийЛичность = Читалка.GetString(20);
Ссылка.ОсновнойМенеджерПокупателя = V82.СправочникиСсылка.Пользователи.ВзятьИзКэша((byte[])Читалка.GetValue(21));
Ссылка.Покупатель = ((byte[])Читалка.GetValue(22))[0]==1;
Ссылка.Поставщик = ((byte[])Читалка.GetValue(23))[0]==1;
Ссылка.РасписаниеРаботыСтрокой = Читалка.GetString(24);
Ссылка.СрокВыполненияЗаказаПоставщиком = Читалка.GetDecimal(25);
Ссылка.ОсновноеКонтактноеЛицо = V82.СправочникиСсылка.КонтактныеЛицаКонтрагентов.ВзятьИзКэша((byte[])Читалка.GetValue(26));
Ссылка.НеЯвляетсяРезидентом = ((byte[])Читалка.GetValue(27))[0]==1;
Ссылка.ОКОПФ = V82.СправочникиСсылка.КлассификаторОКОПФ.ВзятьИзКэша((byte[])Читалка.GetValue(28));
Ссылка.Регион = V82.СправочникиСсылка.Регионы.ВзятьИзКэша((byte[])Читалка.GetValue(29));
Ссылка.ГруппаДоступаКонтрагента = V82.СправочникиСсылка.ГруппыДоступаКонтрагентов.ВзятьИзКэша((byte[])Читалка.GetValue(30));
}
Выборка.Add(Ссылка);
}
return Выборка;
}
}
}
}