V82.Документы.ОприходованиеТоваров.НайтиПоСсылке C# (CSharp) Method

НайтиПоСсылке() public static method

public static НайтиПоСсылке ( System.Guid _Ссылка ) : ОприходованиеТоваров
_Ссылка System.Guid
return V82.ДокументыСсылка.ОприходованиеТоваров
        public static ДокументыСсылка.ОприходованиеТоваров НайтиПоСсылке(Guid _Ссылка)
        {
            using (var Подключение = new SqlConnection(СтрокаСоединения))
            {
                Подключение.Open();
                using (var Команда = Подключение.CreateCommand())
                {
                    Команда.CommandText = @"Select top 1
                    _IDRRef [Ссылка]
                    ,_Version [Версия]
                    ,_Marked [ПометкаУдаления]
                    ,_Fld6879RRef [Организация]
                    ,_Fld6880RRef [Подразделение]
                    ,_Fld6881RRef [Склад]
                    ,_Fld6882 [ОтражатьВУправленческомУчете]
                    ,_Fld6883 [ОтражатьВБухгалтерскомУчете]
                    ,_Fld6884 [ОтражатьВНалоговомУчете]
                    ,_Fld6885RRef [ТипЦен]
                    ,_Fld6886 [СуммаДокумента]
                    ,_Fld6887 [Основание]
                    ,_Fld6888 [Комментарий]
                    ,_Fld6889RRef [ИнвентаризацияТоваровНаСкладе]
                    ,_Fld6890RRef [Ответственный]
                    ,_Fld6891 [СуммаДокументаРегл]
                    ,_Fld6892RRef [КоррСчет]
                    ,_Fld6893RRef [Субконто1]
                    ,_Fld6894RRef [Субконто2]
                    ,_Fld6895RRef [Субконто3]
                    ,_Fld6896RRef [КоррСчетНУ]
                    ,_Fld6897RRef [СубконтоНУ1]
                    ,_Fld6898RRef [СубконтоНУ2]
                    ,_Fld6899RRef [СубконтоНУ3]
                    ,_Fld6900 [УчитыватьНДС]
                    ,_Fld21711RRef [ВидОперации]
                    From _Document342(NOLOCK)
                    Where _IDRRef=@Ссылка";
                    Команда.Parameters.AddWithValue("Ссылка", _Ссылка);
                    using (var Читалка = Команда.ExecuteReader())
                    {
                        if (Читалка.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(6))[0]==1;
                            Ссылка.ОтражатьВБухгалтерскомУчете = ((byte[])Читалка.GetValue(7))[0]==1;
                            Ссылка.ОтражатьВНалоговомУчете = ((byte[])Читалка.GetValue(8))[0]==1;
                            Ссылка.СуммаДокумента = Читалка.GetDecimal(10);
                            Ссылка.Основание = Читалка.GetString(11);
                            Ссылка.Комментарий = Читалка.GetString(12);
                            Ссылка.ИнвентаризацияТоваровНаСкладе = V82.ДокументыСсылка.ИнвентаризацияТоваровНаСкладе.ВзятьИзКэша((byte[])Читалка.GetValue(13));
                            Ссылка.СуммаДокументаРегл = Читалка.GetDecimal(15);
                            Ссылка.УчитыватьНДС = ((byte[])Читалка.GetValue(24))[0]==1;
                            Ссылка.ВидОперации = V82.Перечисления/*Ссылка*/.ВидыОперацийОприходованиеТоваров.ПустаяСсылка.Получить((byte[])Читалка.GetValue(25));
                            return Ссылка;
                        }
                        else
                        {
                            return null;
                        }
                    }
                }
            }
        }