Как найти форму найти в 1с
Поиск в коллекциях значений
Область применения: управляемое приложение, мобильное приложение, обычное приложение.
1. При двух и более операциях поиска в объекте ТаблицаЗначений с большим количеством строк (*) рекомендуется:
- Индексировать колонки, по которым выполняется поиск;
- Но только те из них, которые обладают хорошей селективностью (т.е. каждому значению этой колонки должно соответствовать небольшое количество строк). В противном случае, индексирование не даст эффекта, либо он будет отрицательным (потрачено лишнее время на индексирование).
* Примечание: следует ориентироваться на 1000 строк и более, а также учитывать не только размер таблицы, в которой выполняется поиск, но и сколько раз он выполняется. Например, даже если таблица относительно небольшая в 100 строк, но поиск по ней выполняется 100 раз, ее тоже имеет смысл индексировать. В то же время, нет смысла индексировать таблицу из-за только одной единственной операции поиска.
2. Для поиска значений предусмотрены два метода объекта ТаблицаЗначений :
При поиске значения в одной колонке таблицы значений оба метода одинаково эффективно используют индекс, если он был задан (см. п.1).
Однако при поиске значения сразу по нескольким (или по всем) колонкам необходимо учитывать следующие ограничения.
2.1. Не следует использовать метод Найти для поиска по нескольким колонкам в таблицах значений с большим количеством строк, даже если проиндексированы все колонки, обладающие хорошей селективностью. Это ограничение вызвано тем, что метод Найти выполняет поиск с применением индекса только по одному полю.
Например:
ТЗ.Индексы.Добавить("Колонка1");
ТЗ.Индексы.Добавить("Колонка2");
. = ТЗ.Найти("найдется все", "Колонка1, Колонка2"); // Индекс НЕ используется!
В этом примере, несмотря на наличие индекса для колонок Колонка1 и Колонка2 , поиск все равно будет выполняться перебором всех строк в таблице значений (что очень ресурсоемко на больших объемах данных).
2.2. При использовании метода НайтиСтроки в таблицах значений с большим количеством строк следует обеспечить, чтобы список полей индекса был точно таким же, как он задан в структуре поиска (порядок полей не важен). В противном случае, индекс не будет задействован, и поиск будет выполняться перебором всех строк в таблице значений (что очень ресурсоемко на больших объемах данных).
Например:
ТЗ.Индексы.Добавить("Колонка1"); // Индекс1
ТЗ.Индексы.Добавить("Колонка2"); // Индекс2
. = ТЗ.НайтиСтроки(Новый Структура("Колонка1, Колонка2 ", "Ищу1","Ищу2")); // Индекс НЕ используется!
. = ТЗ.НайтиСтроки(Новый Структура("Колонка1", "Ищу1") ); // OK - используется Индекс1
. = ТЗ.НайтиСтроки(Новый Структура("Колонка2", "Ищу2") ); // OK - используется Индекс2
. = ТЗ.НайтиСтроки(Новый Структура("Колонка1, Колонка2", "Ищу1","Ищу2")); // OK - индекс используется
. = ТЗ.НайтиСтроки(Новый Структура("Колонка2, Колонка1", "Ищу2","Ищу1")); // OK - индекс используется
. = ТЗ.НайтиСтроки(Новый Структура("Колонка1", "Ищу1") ); // Индекс НЕ используется!
. = ТЗ.НайтиСтроки(Новый Структура("Колонка2", "Ищу2") ); // Индекс НЕ используется!
2.3. Аналогичное ограничение действует и для метода Скопировать таблицы значений при вызове с параметром ПараметрыОтбора ( Структура ).
3. В тех случаях, когда для таблицы значений применяется сортировка по колонкам, содержащим ссылочные значения, необходимо учитывать, что при этом для каждой из этих колонок для всех строк таблицы значений системой будет выполнено обращение к информационной базе за представлением этой ссылки.
- В тех случаях, когда требуется сортировка по наименованию – сразу, на этапе заполнения, добавлять в таблицу дополнительные колонки с представлениями, и сортировку выполнять уже по ним. Если, конечно, это не вызовет аналогичных многократных обращений к информационной базе;
- В остальных случаях – сортировать «по ссылке», а не по представлению. Для этого в методе Сортировать следует использовать объект СравнениеЗначений :
ОбъектСравнения = Новый СравнениеЗначений;
ТаблицаДокументов.Сортировать("Дата,Ссылка", ОбъектСравнения);
Особенно это важно для таблиц с большим количеством (несколько сотен и тысяч) строк, в алгоритмах критических ко времени исполнения.
3.1. При поиске в объекте Массив с большим количеством элементов(*) следует отказаться от массива в пользу:
- объекта Соответствие , если не важен порядок элементов;
- индексированной ТаблицаЗначений , если порядок элементов значим.
Это обусловлено тем, что в указанных случаях поиск занимает в большинстве случаев константное время, а в массиве поиск выполняется перебором и поэтому пропорционален количеству элементов.
* Примечание: следует ориентироваться на 1000 элементов и более, а также учитывать не только размер массива, но и сколько раз выполняется поиск. Например, если поиск выполняется многократно, в частности, в цикле, то эта рекомендация также действительна для массивов меньшего размера (до 1000 элементов). Особого внимания требуют универсальные механизмы, которые могут применяться на сколь угодно больших объемах данных.
3.2. При необходимости обеспечить уникальность элементов в большом массиве следует однократно в конце алгоритма вызвать функцию СвернутьМассив или процедуру ДополнитьМассив с параметром ТолькоУникальныеЗначения = Истина (модуль ОбщегоНазначения Библиотеки стандартных подсистем).
4. Аналогичный недостаток существует и у объекта ДеревоЗначений , в котором не предусмотрено индексов и поиск выполняется перебором (как в массиве). В указанных выше случаях объект ДеревоЗначений следует заменять индексированным объектом ТаблицаЗначений .
Т.е. пользователь из формы списка открывает документ X, затем вводит на основании него документ Y.
Далее перед проведением документа Y надо убедиться, что закрыта форма документа основания (X) и если не закрыта, то принудительно ее закрыть. Как это сделать?
Пробовал так:
ВладелецФормы=Документы.X.ПолучитьФормуСписка().ЭлементыФормы.ТабличноеПоле;
Форма=ДокументОснование.ПолучитьФорму(,ВладелецФормы);
Не работает, смотрел в отладчике - разница в том что при моем вызове:
ВладелецФормы - содержит свойства: ТабличногоПоля + Расширения табличного поля списка документов + Расширение элементов управления, расположенных в форме.
А при стандартном вызове 1с передает только свойства: ТабличногоПоля + Расширения табличного поля списка документов.
Расширение элементов управления, расположенных в форме - почему-то не передается!
Кто сталкивался? Подскажите как разрешить?
P.S. Вариант подменить параметр ВладелецФормы при стандартном открытии из спика документа X не удобен т.к. документов вида X много.
1 - Вариант в общем-то. Но это не совсем то, что я хотел. Я хотел именно получить открытую форму - как это делает 1с (если ты откроешь форму документа X из кода через ПолучитьФорму() с любыми параметром ВладелецФормы, а потом в форме списка документа X - откроешь тот же документ - то 1с активизирует уже открытую форму, а не создаст новую) Недостаток предложенного тобой метода - что мне придется прописывать ОбработкаОповещения во многих документах.
2 - И как это использовать?
3 - Значение ЭтаФорма.ВладелецФормы - Неопределено
(5) - Будет получена форма нового документа. Форма.Открыта() - будет всегда ЛОЖЬ.
Мне надо найти открытую форму конкретного документа-объекта (например Документ.X N 15. А открытая форма другого документа, например Документ.X N 5 - мне не нужна)
ДокумантОбъектXN15.ПолучитьФорму();
или
ДокумантСсылкаXN15.ПолучитьФорму();
Синтаксис:
ПолучитьФорму(<Форма>, <Владелец>, <Ключ уникальности>)
Параметры:
.
<Ключ уникальности> (необязательный)
Тип: Произвольный. В данном параметре может быть задан некоторый ключ, значение которого будет использоваться для поиска уже открытых форм.
При поиске учитываются значения свойств открытых форм соответствующим значениям параметров метода. Если найдена открытая форма (по совпадению всех параметров), то она будет возвращена вместо новой формы.
.
Попробуй просто для ссылки на док выполнить ПолучитьФорму("ФормаИлиКакТамОнаНазывается"). Если для данного дока форма открыта, то её и получишь. Я так делал
КлючУникальности - тот параметр, который нужен отцу демократии
Получаю новое окно, а не то которое открыл пользователь! У меня 8.1. А ты в какой верси пробовал что у тебя открытая пользователем форма получается?
Попробуй к качестве ключаУникальности послать ОбъектОснование. Он должен быть в свойствах открытой формы.
Спецально смоделировал.
Из формы документа вызывается внешняя обработка со своей формой, в которую отправляю ссылку на этот документ.
Во внешней обработке код на кнопке:
Никакой новой формы не открываетсо.
Версия 8. Как и написано в заголовке ветки.
Читайте также: