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 [ПометкаУдаления]
                    ,_Fld10732 [ПериодРегистрации]
                    ,_Fld10733RRef [Организация]
                    ,_Fld10734 [Комментарий]
                    ,_Fld10735RRef [Ответственный]
                    ,_Fld21973RRef [Сотрудник]
                    ,_Fld10736RRef [Физлицо]
                    ,_Fld10738 [ДатаУвольнения]
                    ,_Fld10739 [ДнейЧасовВыходногоПособия]
                    ,_Fld10740 [ДнейЧасовКомпенсацииУдержанияОтпуска]
                    ,_Fld10741 [ДнейЧасовСохраненияСреднегоЗаработка]
                    ,_Fld10742 [ПризнакКомпенсацииОтпуска]
                    ,_Fld10743RRef [ДокументОснование]
                    ,_Fld10744RRef [ПорядокРасчетаОтпуска]
                    ,_Fld10745RRef [ПерерассчитываемыйДокумент]
                    ,_Fld10746 [РабочийГодС]
                    ,_Fld10747 [РабочийГодПо]
                    ,_Fld18527 [ИспользоватьСреднеЧасовойЗаработок]
                    ,_Fld10737RRef [УдалитьПриказ]
                    ,_Fld27269 [ПериодРасчетаСреднегоЗаработкаНачало]
                    ,_Fld27270 [ПериодРасчетаСреднегоЗаработкаОкончание]
                    From _Document427(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;
                            Ссылка.ПериодРегистрации = Читалка.GetDateTime(3);
                            Ссылка.Комментарий = Читалка.GetString(5);
                            Ссылка.ДатаУвольнения = Читалка.GetDateTime(9);
                            Ссылка.ДнейЧасовВыходногоПособия = Читалка.GetDecimal(10);
                            Ссылка.ДнейЧасовКомпенсацииУдержанияОтпуска = Читалка.GetDecimal(11);
                            Ссылка.ДнейЧасовСохраненияСреднегоЗаработка = Читалка.GetDecimal(12);
                            Ссылка.ПризнакКомпенсацииОтпуска = ((byte[])Читалка.GetValue(13))[0]==1;
                            Ссылка.ДокументОснование = V82.ДокументыСсылка.УвольнениеИзОрганизаций.ВзятьИзКэша((byte[])Читалка.GetValue(14));
                            Ссылка.ПорядокРасчетаОтпуска = V82.Перечисления/*Ссылка*/.ПорядокРасчетаОтпуска.ПустаяСсылка.Получить((byte[])Читалка.GetValue(15));
                            Ссылка.ПерерассчитываемыйДокумент = V82.ДокументыСсылка.РасчетПриУвольненииРаботникаОрганизаций.ВзятьИзКэша((byte[])Читалка.GetValue(16));
                            Ссылка.РабочийГодС = Читалка.GetDateTime(17);
                            Ссылка.РабочийГодПо = Читалка.GetDateTime(18);
                            Ссылка.ИспользоватьСреднеЧасовойЗаработок = ((byte[])Читалка.GetValue(19))[0]==1;
                            Ссылка.УдалитьПриказ = V82.ДокументыСсылка.ПриемНаРаботуВОрганизацию.ВзятьИзКэша((byte[])Читалка.GetValue(20));
                            Ссылка.ПериодРасчетаСреднегоЗаработкаНачало = Читалка.GetDateTime(21);
                            Ссылка.ПериодРасчетаСреднегоЗаработкаОкончание = Читалка.GetDateTime(22);
                            return Ссылка;
                        }
                        else
                        {
                            return null;
                        }
                    }
                }
            }
        }