fixin (fixin) wrote,
fixin
fixin

Нюанс открывашки



У меня есть обработка "Открывашка", которая открывает документ по его текстовому представлению. http://infostart.ru/public/272914/


Обнаружил, что иногда она открывает не тот документ. Настолько привык ею пользоваться, что сперва даже не понимал, почему не выходит то, что хочу, а оказывается, открывался не тот документ. Только и всего.


Начал разбираться, оказывается встроенный метод 1С "НайтиПоНомеру" ищет в интервале уникальности номеров документа первый документ с указанным номером. А если таких номеров два, т.е. нарушена уникальность, выдает первый попавшийся. Т.е. вместо этого метода нужно использовать запрос! Такой вот нюанс.



Было:


СсылкаДокумента=Документы[ИмяДокумента].НайтиПоНомеру(НомерДокумента,ДатаДокумента);


Стало:


 З = Новый Запрос(
 "ВЫБРАТЬ
 | Т.Ссылка
 |ИЗ
 | Документ.ЧекККМ КАК Т
 |ГДЕ
 | Т.Номер = &НомерДокумента
 | И Т.Дата = &ДатаДокумента");
 З.УстановитьПараметр("НомерДокумента", НомерДокумента);
 З.УстановитьПараметр("ДатаДокумента", ДатаДокумента);
 З.Текст = СтрЗаменить(З.Текст, "ЧекККМ", ИмяДокумента);
 
 ТЗ = З.Выполнить().Выгрузить();
 Если ТЗ.Количество() = 0 Тогда
  Возврат Неопределено;
 Иначе
 
  Возврат ТЗ[0].Ссылка;
 КонецЕсли

Tags:
Subscribe
promo fixin december 31, 2037 16:57 1417
Buy for 30 tokens
UPD: Друзья, в августе 2019 года блог переехал на http://fixinchik.ru. Welcome! Добро пожаловать в журнал Осипова Сергея Александровича, известного также как Fixin и Гений 1С. Рекомендую ознакомиться с Часто Задаваемыми Вопросами обо мне. Что я хочу в подарок - список. Мой проект "…
  • Post a new comment

    Error

    default userpic

    Your reply will be screened

    Your IP address will be recorded 

    When you submit the form an invisible reCAPTCHA check will be performed.
    You must follow the Privacy Policy and Google Terms of use.
  • 32 comments