Как найти количество элементов справочника

Как подсчитать количество элементов в справочнике?

goro_ivan
28.01.2011 15:54 Прочитано: 31293

есть встроенная функция подсчитать количество элементов в справочнике с условием???
не выборка, не запрос

Yandex
Возможно, вас также заинтересует

Реклама на портале

E_Migachev
28.01.2011 16:24 Ответ № 1

(0) goro_ivan, нет, только запросом!

E_Migachev
31.01.2011 10:59 Ответ № 2

Вот пример подсчета количества элементов в справочнике Номенклатура:
Код 1C v 8.х

  Запрос = Новый Запрос("ВЫБРАТЬ
| СУММА(1) КАК ВсегоЭлементов
|ИЗ
| Справочник.Номенклатура КАК Номенклатура
|ГДЕ
| (НЕ Номенклатура.ЭтоГруппа)");

Выборка = Запрос.Выполнить().Выгрузить();
ЭлементыФормы.Индикатор.МаксимальноеЗначение = Выборка.ВсегоЭлементов;

Пример вывода количества элементов в каждом справочнике конфигурации:

Код 1C v 8.х

    Всего = 0;
Для Каждого Спр Из Метаданные.Справочники Цикл
Запрос = Новый Запрос;
Запрос.Текст = "ВЫБРАТЬ
| КОЛИЧЕСТВО(ССЫЛКА) КАК ВсегоЭлементов
|ИЗ
| Справочник." + Спр.Имя + " КАК Спр";
Выборка = Запрос.Выполнить().Выгрузить();
Всего = Всего + Выборка[0].ВсегоЭлементов;
КонецЦикла;
Сообщить("Всего " + Всего);
goro_ivan
01.02.2011 10:49 Ответ № 3

спс

goro_ivan
01.02.2011 10:49 Ответ № 4

Вопрос закрыт!

siniks7
07.03.2023 14:05 Ответ № 5

Здравствуйте! 

Странно, что никто не предложил более простой способ решения без использования языка запросов. 

Мое решение:

Выборка = Справочники. Номенклатура. Выбрать();

Сумма = 0;

Пока Выборка. Следующий Цикл

Сумма = Сумма + 1;

КонецЦикла;

Сообщить(Сумма) ;

Элементарное же решение, но пришлось подумать)) 

Подсказка: Для быстрого поиска ответов – используйте ‘Поиск’

Узнать количество элементов в справочнике Номенклатура:

Запрос = Новый Запрос(“ВЫБРАТЬ

| СУММА(1) КАК ВсегоЭлементов

|ИЗ

| Справочник.Номенклатура КАК Номенклатура

|ГДЕ

| (НЕ Номенклатура.ЭтоГруппа)”);

Выборка = Запрос.Выполнить().Выгрузить();

ЭлементыФормы.Индикатор.МаксимальноеЗначение = Выборка[0].ВсегоЭлементов;

Пример вывода количества элементов в каждом справочнике конфигурации:

Всего = 0;

Для Каждого Спр Из Метаданные.Справочники Цикл

Запрос = Новый Запрос;

Запрос.Текст = “ВЫБРАТЬ

| КОЛИЧЕСТВО(ССЫЛКА) КАК ВсегоЭлементов

|ИЗ

| Справочник.” + Спр.Имя + ” КАК Спр”;

Выборка = Запрос.Выполнить().Выгрузить();

Всего = Всего + Выборка[0].ВсегоЭлементов;

КонецЦикла;

Сообщить(“Всего “ + Всего);


Как получить количество элементов в справочнике

Я
   vde69

19.07.06 – 17:09

Предлогаю ОЧЕНЬ быстрый вариант 20000 поз = 0.05 сек

   Запрос = Новый Запрос(“ВЫБРАТЬ

                         |    СУММА(1) КАК ВсегоЭлементов

                         |ИЗ

                         |    Справочник.Номенклатура КАК Номенклатура

                         |ГДЕ

                         |    (НЕ Номенклатура.ЭтоГруппа)”);

                         
   Выборка = Запрос.Выполнить().Выгрузить();

   ЭлементыФормы.Индикатор.МаксимальноеЗначение = Выборка.ВсегоЭлементов;

У кого есть другие предложения?

   vde69

1 – 19.07.06 – 17:18

(0) сори.. последняя строка:

ЭлементыФормы.Индикатор.МаксимальноеЗначение = Выборка[0].ВсегоЭлементов;

   ZolotarevAA

2 – 19.07.06 – 17:19

(19) Колумб?

   ZolotarevAA

3 – 19.07.06 – 17:19

(2) – > (0)

   dimoff

4 – 19.07.06 – 17:23

А Выбрать Количество(Ссылка) будет медленнее?

   vde69

5 – 19.07.06 – 17:24

(2) может это и велосипед но допер сам… интересуют кто как еще делает

(4) думаю, что около 1 секунды будет

   dimoff

6 – 19.07.06 – 17:25

фига се разница

   vde69

7 – 19.07.06 – 17:25

(4) кроме того в моем случае можно накладывать условия в запросе (у меня не считаються группы, а только элементы)

   Defender aka LINN

8 – 19.07.06 – 17:32

(7) А таки кто Вам сказал, что в (4) этого нельзя?

Кроме того, замер производительности прямо-таки вопит о том, что (4) быстрее.

Так что велосипед-то неисправный 😉

   vde69

9 – 19.07.06 – 17:37

(8) на сколько я понял в (4) обьектная модель, а там условия фильтра очень куцые, или мы говорим тоже о запросе???

   dimoff

10 – 19.07.06 – 17:38

Хаха, а я уж подывился, как это такая разница между 4 и 0, а оказалось vde69 просто не въехал 🙂

   dimoff

11 – 19.07.06 – 17:39

(9) Имелось ввиду “ВЫБРАТЬ

                         |    КОЛИЧЕСТВО(ССЫЛКА) КАК ВсегоЭлементов

                         |ИЗ

                         |    Справочник.Номенклатура КАК Номенклатура

                         |ГДЕ

                         |    (НЕ Номенклатура.ЭтоГруппа)”);

   Defender aka LINN

12 – 19.07.06 – 17:42

(11) Совершенно верно. И быстрее это будет примерно в 1,5 раза 🙂

   vde69

13 – 19.07.06 – 17:43

все равно замер на ФАЙЛОВОЙ версии

вариант (0) = 0,079

вариант (12) = 0,089

На серверной версии не проверял

   dimoff

14 – 19.07.06 – 17:49

щас и я проверю на файловой и на серверной

   dimoff

15 – 19.07.06 – 17:50

Не, не проверю, футбол через час

   Defender aka LINN

16 – 19.07.06 – 17:57

(13) Я проверял на серверной. Разница примерно в 1,5 раза.

За 10 проходов:

Вариант (0) – 0,0832

Вариант (11) – 0,0577, т.е. в 1,44 раза быстрее.

   vde69

17 – 19.07.06 – 18:02

(16) спасибо, это то-же дело (вполне понятно, что встроенная скульная команда работает быстрее)

вообще мне был интересен запрос который не использует поля таблицы а только цифровые констнанты

   vde69

18 – 19.07.06 – 18:04

(16) кстати а какой размер справочника??

   Defender aka LINN

19 – 19.07.06 – 18:09

(18) около 8000 элементов, но много групп. (около 700)

На файловой таки да, работает немного медленнее – в 1,2 раза примерно (0,304 вариант (11) и 0,256 вариант (0))

   acsent

20 – 19.07.06 – 18:14

Можно еще так

ВЫБРАТЬ
    КОЛИЧЕСТВО(*) КАК ВсегоЭлементов
ИЗ
    Справочник.Номенклатура КАК Номенклатура
ГДЕ
    (НЕ Номенклатура.ЭтоГруппа)
   MikleV

21 – 19.07.06 – 18:17

(21) имхо так дольше будет.

   Neco

22 – 19.07.06 – 18:20

(0) Плагиат, Гончаров и Габец:

Как подсчитать количество одинаковых элементов в выбираемых данных? 
ВЫБРАТЬ 
    РеализацияТоваровУслугТовары.Номенклатура КАК Номенклатура, 
    СУММА(РеализацияТоваровУслугТовары.Количество) КАК Количество 
ИЗ 
    Документ.РеализацияТоваровУслуг.Товары КАК РеализацияТоваровУслугТовары 
СГРУППИРОВАТЬ ПО 
    РеализацияТоваровУслугТовары.Номенклатура
  

acsent

23 – 19.07.06 – 18:27

(22) совсем не в тему

  • Как создать элемент (группу) справочника?
  • Как найти элемент справочника?
  • Как удалить элемент справочника?
  • Как перебрать элементы справочника?
  • Как выбрать все элементы из определенной группы?
  • Как перебрать элементы подчиненного справочника с помощью запроса?
  • Как перебрать элементы подчиненного справочника с помощью выборки справочника?
  • Как открыть форму списка (элемента) справочника?
  • Как добавить запись в табличную часть элемента справочника?
  • Как удалить строки из табличной части справочника?
  • Как перебрать строки табличной части справочника?
  • Как создать элемент в нужной группе?
  • Как узнать, есть ли у текущего элемента подчиненные?
  • Как узнать количество подчиненных элементов у выбранного элемента справочника?
  • Как узнать количество подчиненных элементов у выбранного элемента справочника, если подчиненных справочников нексолько?
  • Как получить всех родителей выбранного элемента справочника?
  • Как получить запросом «полный» код элементов справочника, если тип кода — Строка?
  • Как получить все элементы справочника, содержащие в наименовании определенную подстроку, со всей иерархией, в которую они входят?
  • Как найти все элементы справочника, в которых не заполнен строковый реквизит?
  • Как перенести все элементы справочника «Контрагенты» из одной группы в другую?
  • Как организовать программный выбор элемента справочника?
  • Как сохранить фотографию сотрудника в справочнике «Сотрудники»?

Как создать элемент (группу) справочника?

НовыйЭлемент = Справочники.ДокументыУдостоверяющиеЛичность.СоздатьЭлемент();
НовыйЭлемент.Наименование = "военный билет"; 
// Установить другие реквизиты.  
// .....
НовыйЭлемент.Записать(); 

НовыйЭлемент = Справочники.Банки.СоздатьЭлемент(); 
// Получить ссылку на группу, в которой будет находиться новый элемент
Родитель = Справочники.Банки.НайтиПоКоду("000000001"); 
НовыйЭлемент.Наименование = "АКБ"; 
НовыйЭлемент.Код = "000000011"; 
НовыйЭлемент.Родитель = Родитель; 
// Установить другие реквизиты 
// .....
НовыйЭлемент.Записать(); 

НоваяГруппа = Справочники.Номенклатура.СоздатьГруппу(); 
// Получить ссылку на группу, в которой должна находиться создаваемая группа
Родитель = Справочники.Номенклатура.НайтиПоНаименованию("Обувь", Истина); 
НоваяГруппа.Наименование = "Модельная обувь"; 
НоваяГруппа.Родитель = Родитель; 
// Установить другие реквизиты  
// .....
НоваяГруппа.Записать(); 

// Создать новый элемент в корне справочника
НовыйЭлемент = Справочники.Подразделения.СоздатьЭлемент(); 
НовыйЭлемент.Наименование = "IT отдел";  
НовыйЭлемент.Записать(); 

// Получить ссылку на родителя для добавляемых элементов
Родитель = НовыйЭлемент.Ссылка; 
// Создать дочерний элемент. 
НовыйЭлемент = Справочники.Подразделения.СоздатьЭлемент(); 
НовыйЭлемент.Наименование = "Группа разработки"; 
НовыйЭлемент.Родитель = Родитель;  
НовыйЭлемент.Записать();

Как найти элемент справочника?

// Поиск по коду
РезультатПоиска = Справочники.Номенклатура.НайтиПоКоду("00030"); 
Если РезультатПоиска.Пустая() Тогда 
    // Выполнить действия, предусмотренные в случае, когда элемент не найден.  
КонецЕсли; 

// Поиск по наименованию
РезультатПоиска = Справочники.Номенклатура.НайтиПоНаименованию("Кроссовки"); 

// Поиск по реквизиту
РезультатПоиска = Справочники.Номенклатура.НайтиПоРеквизиту("Артикул", "К-120002");

Как удалить элемент справочника?

// Найти ссылки на удаляемый элемент. 
МассивСсылок = Новый Массив; 
МассивСсылок.Добавить(СсылкаНаУдаляемыйЭлемент); 
НайденныеСсылки = НайтиПоСсылкам(МассивСсылок); 

Если НайденныеСсылки.Количество() > 0 Тогда 
    Сообщить("Нельзя удалять элемент, на него имеются ссылки"); 
Иначе 
    УдаляемыйЭлемент = СсылкаНаУдаляемыйЭлемент.ПолучитьОбъект(); 
    УдаляемыйЭлемент.Удалить(); 
КонецЕсли; 

УдаляемыйЭлемент.УстановитьПометкуУдаления(Истина);

Как перебрать элементы справочника?

Выборка = Справочники.Номенклатура.ВыбратьИерархически(); 
Пока Выборка.Следующий() Цикл 
    Наименование = Выборка.Наименование; 
    // Обращение к другим данным справочника
    // .....
КонецЦикла; 

Запрос = Новый Запрос(
    "ВЫБРАТЬ 
    |    Ссылка, 
    |    Наименование 
    |ИЗ 
    |    Справочник.Номенклатура 
    |АВТОУПОРЯДОЧИВАНИЕ"
); 
Результат = Запрос.Выполнить().Выбрать(); 
Пока Результат.Следующий() Цикл 
    Наименование = Результат.Наименование;  
КонецЦикла;

Как выбрать все элементы из определенной группы?

Выборка = Справочники.Номенклатура.Выбрать(ПолеВводаРодитель); 
Пока Выборка.Следующий() Цикл 
    Наименование = Выборка.Наименование;
КонецЦикла; 

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

Выборка=Справочники.Номенклатура.ВыбратьИерархически(ПолеВводаРодитель); 
Пока Выборка.Следующий() Цикл 
    Наименование = Выборка.Наименование;  
КонецЦикла; 

Запрос = Новый Запрос(
    "ВЫБРАТЬ 
    |    Ссылка, 
    |    Наименование 
    |ИЗ 
    |    Справочник.Номенклатура 
    |ГДЕ 
    |    Родитель В ИЕРАРХИИ(&Родитель) 
    |АВТОУПОРЯДОЧИВАНИЕ"
); 
Запрос.УстановитьПараметр("Родитель", ПолеВводаРодитель); 
Результат = Запрос.Выполнить().Выбрать(); 
Пока Результат.Следующий() Цикл 
    Наименование = Результат.Наименование;  
КонецЦикла;

Как перебрать элементы подчиненного справочника с помощью запроса?

Процедура ПереборПодчиненыхЭлементов(Контрагент) 
    Запрос = Новый Запрос(); 
    Запрос.Текст =
    "ВЫБРАТЬ 
    |    КонтактныеЛица.Ссылка 
    |ИЗ 
    |    Справочник.КонтактныеЛица КАК КонтактныеЛица 
    |ГДЕ 
    |    КонтактныеЛица.Владелец = &Владелец"; 
    Запрос.УстановитьПараметр("Владелец", Контрагент); 
    Результат = Запрос.Выполнить(); 
    Выборка = Результат.Выбрать(); 
    Пока Выборка.Следующий() Цикл 
        ОчереднойПодчиненый = Выборка.Ссылка; 
    КонецЦикла; 
КонецПроцедуры

Как перебрать элементы подчиненного справочника с помощью выборки справочника?

Процедура ПереборПодчиненыхЭлементов(Контрагент) 
    // Получить выборку по указанному контрагенту
    Выборка = Справочники.КонтактныеЛица.Выбрать( , Контрагент); 
    Пока Выборка.Следующий() Цикл 
        ОчереднойПодчиненый = Выборка.Ссылка; 
    КонецЦикла; 
КонецПроцедуры

Как открыть форму списка (элемента) справочника?

Форма = Справочники.Номенклатура.ПолучитьФормуСписка(); 
Форма.Открыть();

Элемент = Справочники.Номенклатура.НайтиПоКоду("00070"); 
Форма = Элемент.ПолучитьФорму(); 
Форма.Открыть();

Как добавить запись в табличную часть элемента справочника?

ЭлементОбъект = СсылкаКонтрагент.ПолучитьОбъект(); 
НоваяСтрока = ЭлементОбъект.ВидыДеятельности.Добавить(); 
// Заполнить реквизиты
НоваяСтрока.ВидДеятельности = ПолеВводаВидДеятельности; 
// .....
ЭлементОбъект.Записать();

Как удалить строки из табличной части справочника?

ЭлементСправочника = Справочники.Контрагенты.НайтиПоКоду("Ю0006"); 
ОбъектСправочника = ЭлементСправочника.ПолучитьОбъект(); 
ОбъектСправочника.ВидыДеятельности.Очистить(); 
ОбъектСправочника.Записать(); 

ОбъектСправочника = ВыбранныйЭлемент.ПолучитьОбъект(); 

// Создать структуру для отбора удаляемых строк
СтруктураОтбора = Новый Структура("ВидДеятельности", ВыбранныйВидДеятельности); 

// Получить массив удаляемых строк
ПодходящиеСтроки = ОбъектСправочника.ВидыДеятельности.НайтиСтроки(СтруктураОтбора); 

// Удалить строки
Для Каждого ОчереднаяСтрока Из ПодходящиеСтроки Цикл 
    ОбъектСправочника.ВидыДеятельности.Удалить(ОчереднаяСтрока); 
КонецЦикла; 

ОбъектСправочника.Записать();

Как перебрать строки табличной части справочника?

ЭлементСправочника = Справочники.Контрагенты.НайтиПоКоду("Ю0006"); 
Для Каждого ТекущаяСтрока Из ЭлементСправочника.ВидыДеятельности Цикл 
    Сообщить(ТекущаяСтрока.ВидДеятельности); 
КонецЦикла;

Как создать элемент в нужной группе?

КодГруппы = "330100"; 
ПоискПоПолномуКоду = Ложь; // значение по умолчанию 
Группа = Справочники.Номенклатура.НайтиПоКоду(КодГруппы, ПоискПоПолномуКоду); 

Если Группа.Пустая() Тогда 
    Группа = Справочники.Номенклатура.СоздатьГруппу(); 
    Группа.Код = КодГруппы; 
    Группа.Наименование = "Загруженные"; 
    Группа.Записать(); 
ИначеЕсли НЕ Группа.ЭтоГруппа Тогда 
    Сообщить("Найден элемент справочника с указанным кодом!"); 
    // Предусмотреть прерывание алгоритма...
КонецЕсли; 

Спр = Справочники.Номенклатура.СоздатьЭлемент(); 
Спр.Наименование = "Программно созданный"; 
// Реквизиты заполняются в соответствии с задачей
// .....
Спр.Родитель = Группа.Ссылка; 
Спр.Записать(); 

Группа = Справочники.Номенклатура.Загруженные; 

КодЭлемента = "330100"; 
ПоискПоПолномуКоду = Ложь; // Значение по умолчанию 
Родитель = Справочники.Номенклатура.НайтиПоКоду(КодЭлемента, ПоискПоПолномуКоду); 

Если Родитель.Пустая() Тогда 
Родитель = Справочники.Номенклатура.СоздатьЭлемент(); 

Родитель.Код = КодЭлемента; 
Родитель.Наименование = "Загруженные"; 

Родитель.Записать(); 
КонецЕсли; 

Спр = Справочники.Номенклатура.СоздатьЭлемент(); 
Спр.Наименование = "Программно созданный"; 
// Реквизиты заполняются в соответствии с задачей
// .....
Спр.Родитель = Родитель.Ссылка; 
Спр.Записать();

Как узнать, есть ли у текущего элемента подчиненные?

Выборка = Справочники.Номенклатура.Выбрать( , Владелец); 
Если Выборка.Следующий() = Истина Тогда 
    // Есть подчиненные элементы.
КонецЕсли;

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

Как узнать количество подчиненных элементов у выбранного элемента справочника?

Выборка = Справочники.ЕдиницыИзмерения.Выбрать( , Владелец); 
КоличествоЭлементов = 0; 
Пока Выборка.Следующий() Цикл 
    КоличествоЭлементов = КоличествоЭлементов + 1; 
КонецЦикла; 

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

Если Выборка.Следующий() Тогда 
    КоличествоЗаписей = Выборка.КоличествоЗаписей; 
КонецЕсли;

Как узнать количество подчиненных элементов у выбранного элемента справочника, если подчиненных справочников несколько?

ВЫБРАТЬ
    СУММА(КоличествоПодчиненных) КАК КоличествоПодчиненныхЭлементов 
ИЗ 
    (ВЫБРАТЬ 
        КОЛИЧЕСТВО(*) КАК КоличествоПодчиненных 
    ИЗ 
        Справочник.ЕдиницыИзмерения КАК ЕдиницыИзмерения 
    ГДЕ
        ЕдиницыИзмерения.Владелец = &Владелец 

    ОБЪЕДИНИТЬ ВСЕ 

    ВЫБРАТЬ 
        КОЛИЧЕСТВО(*) 
    ИЗ 
        Справочник.СерииНоменклатуры КАК СерииНоменклатуры 
    ГДЕ
        СерииНоменклатуры.Владелец = &Владелец
    ) КАК ВложенныйЗапрос

Как получить всех родителей выбранного элемента справочника?

МассивРодителей = Новый Массив; 
Родитель = СсылкаНаЭлемент.Родитель; 

Пока НЕ Родитель.Пустая() Цикл
    МассивРодителей.Добавить(Родитель);
    Родитель = Родитель.Родитель; 
КонецЦикла; 

Для Каждого ТекущийРодитель Из МассивРодителей Цикл
    // Работа с текущим родителем
КонецЦикла;
ВЫБРАТЬ 
    Номенклатура.Ссылка КАК Ссылка 
ИЗ 
    Справочник.Номенклатура КАК Номенклатура 
ГДЕ 
    Номенклатура.Ссылка = &Ссылка 
ИТОГИ ПО 
    Ссылка ТОЛЬКО ИЕРАРХИЯ 
ТекущийЭлементНоменклатуры = ЭлементНоменклатура; 

Запрос = Новый Запрос(
    "ВЫБРАТЬ 
    |    Номенклатура.Родитель, 
    |    Номенклатура.Родитель.Родитель, 
    |    Номенклатура.Родитель.Родитель.Родитель, 
    |    Номенклатура.Родитель.Родитель.Родитель.Родитель, 
    |    Номенклатура.Родитель.Родитель.Родитель.Родитель.Родитель 
    |ИЗ 
    |    Справочник.Номенклатура КАК Номенклатура 
    |ГДЕ 
    |    Номенклатура.Ссылка = &ТекущийЭлементНоменклатуры"; 

Пока Истина Цикл 
    Запрос.УстановитьПараметр("ТекущийЭлементНоменклатуры", ТекущийЭлементНоменклатуры); 
    Результат = Запрос.Выполнить(); 
    Если Результат.Пустой() Тогда 
        Прервать; 
    КонецЕсли; 
    Выборка = Результат.Выбрать(); 
    Выборка.Следующий(); 

    Для НомерКолонки = 0 По Результат.Колонки.Количество() - 1 Цикл 
        ТекущийЭлементНоменклатуры = Выборка[НомерКолонки]; 
        Если ТекущийЭлементНоменклатуры = Справочники.Номенклатура.ПустаяСсылка() Тогда 
            Прервать; 
        Иначе 
            Сообщить(ТекущийЭлементНоменклатуры); 
        КонецЕсли; 
    КонецЦикла; 

    Если ТекущийЭлементНоменклатуры = Справочники.Номенклатура.ПустаяСсылка() Тогда 
        Прервать;
    КонецЕсли; 
КонецЦикла;

Как получить запросом «полный» код элементов справочника, если тип кода — Строка?

ВЫБРАТЬ 
    Контрагенты.Ссылка, 
    ВЫБОР 
        КОГДА (Контрагенты.Родитель.Код ЕСТЬ NULL ) ТОГДА Контрагенты.Код 
        КОГДА (Контрагенты.Родитель.Родитель.Код ЕСТЬ NULL ) ТОГДА 
            Контрагенты.Родитель.Код + "/" + Контрагенты.Код 
        ИНАЧЕ Контрагенты.Родитель.Родитель.Код + "/" + Контрагенты.Родитель.Код + 
            "/" + Контрагенты.Код 
    КОНЕЦ КАК ПолныйКод 
ИЗ 
    Справочник.Контрагенты КАК Контрагенты

Как получить все элементы справочника, содержащие в наименовании определенную подстроку, со всей иерархией, в которую они входят?

Запрос = Новый Запрос(
    "ВЫБРАТЬ 
    |    Контрагенты.Ссылка КАК Ссылка 
    |ИЗ 
    |    Справочник.Контрагенты КАК Контрагенты 
    |ГДЕ 
    |    (Контрагенты.Наименование ПОДОБНО &ЧастьНаименования) И (НЕ Контрагенты.ЭтоГруппа) 
    |ИТОГИ ПО 
    |    Ссылка ТОЛЬКО ИЕРАРХИЯ"
); 
Запрос.УстановитьПараметр("ЧастьНаименования", "%" + ПолеВводаПодстрока + "%");

Как найти все элементы справочника, в которых не заполнен строковый реквизит?

ВЫБРАТЬ 
    ФизическиеЛица.Ссылка 
ИЗ 
    Справочник.ФизическиеЛица КАК ФизическиеЛица 
ГДЕ 
    (ФизическиеЛица.ИНН = "") 

ВЫБРАТЬ 
    ФизическиеЛица.Ссылка 
ИЗ 
    Справочник.ФизическиеЛица КАК ФизическиеЛица 
ГДЕ 
    (ФизическиеЛица.СтраховойНомерПФР = "") ИЛИ (ФизическиеЛица.СтраховойНомерПФР = " - -")

Как перенести все элементы справочника «Контрагенты» из одной группы в другую?

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

Выборка = Результат.Выбрать(); 
Пока Выборка.Следующий() Цикл 
    Контрагент = Выборка.Ссылка.ПолучитьОбъект(); 
    Контрагент.Родитель = НовыйРодитель; 
    Контрагент.Записать(); 
КонецЦикла;

Как организовать программный выбор элемента справочника?

// Получить форму выбора справочника как подчиненную форме документа 
ФормаВыбора = Справочники.Номенклатура.ПолучитьФормуВыбора( , ЭтаФорма); 

// Открыть полученную форму 
ФормаВыбора.Открыть(); 

Процедура ОбработкаВыбора(ЗначениеВыбора, Источник) 
    ПолученноеЗначение = ЗначениеВыбора; 
    // Дальнейшая обработка значения...
КонецПроцедуры 

ФормаВыбора = Справочники.Номенклатура.ПолучитьФормуВыбора( , ЭтаФорма); 
Выбрано = ФормаВыбора.ОткрытьМодально(); 

Процедура ПолеВводаНачалоВыбора(Элемент, СтандартнаяОбработка) 
    // Запретить стандартную обработку. 
    СтандартнаяОбработка = Ложь; 
    // Получить форму выбора справочника как подчиненную полю ввода
    ФормаВыбора = Справочники.Номенклатура.ПолучитьФормуВыбора( , Элемент); 
    // Открыть полученную форму 
    ФормаВыбора.Открыть(); 
КонецПроцедуры 

Процедура ПолеВводаОбработкаВыбора(Элемент, ВыбранноеЗначение, СтандартнаяОбработка) 
    // Отключить стандартную обработку (при необходимости)
    СтандартнаяОбработка = Ложь; 
    ПолученноеЗначение = ВыбранноеЗначение; 
    // Дальнейшая обработка значения...
КонецПроцедуры

Как сохранить фотографию сотрудника в справочнике «Сотрудники»?

Процедура ЗагрузитьФотографию(Элемент)
    Режим = РежимДиалогаВыбораФайла.Открытие;
    ДиалогОткрытияФайла = Новый ДиалогВыбораФайла(Режим);
    ДиалогОткрытияФайла.ПолноеИмяФайла = "";
    Фильтр = "Текст (*,*)|*.*";
    ДиалогОткрытияФайла.Фильтр = Фильтр;
    ДиалогОткрытияФайла.МножественныйВыбор = Ложь;
    ДиалогОткрытияФайла.Заголовок = "Выберите картинку";
    Если ДиалогОткрытияФайла.Выбрать() Тогда 
        ВыбраннаяКартинка = Новый Картинка(ДиалогОткрытияФайла.ПолноеИмяФайла);
        ЭлементХранилища = Новый ХранилищеЗначения(ВыбраннаяКартинка);
        Фотография = ЭлементХранилища;
    КонецЕсли;
КонецПроцедуры

ВыбФайл = Новый ДвоичныеДанные(ДиалогОткрытияФайла.ПолноеИмяФайла);
элХранилища = Новый ХранилищеЗначения(ВыбФайл);
Фотография = элХранилища;

Справочники

  • Как создать элемент (группу) справочника?
  • Как найти элемент справочника?
  • Как удалить элемент справочника?
  • Как перебрать элементы справочника?
  • Как выбрать все элементы из определенной группы?
  • Как перебрать элементы подчиненного справочника с помощью запроса?
  • Как перебрать элементы подчиненного справочника с помощью выборки справочника?
  • Как открыть форму списка (элемента) справочника?
  • Как добавить запись в табличную часть элемента справочника?
  • Как удалить строки из табличной части справочника?
  • Как перебрать строки табличной части справочника?
  • Как создать элемент в нужной группе?
  • Как узнать, есть ли у текущего элемента подчиненные?
  • Как узнать количество подчиненных элементов у выбранного элемента справочника?
  • Как узнать количество подчиненных элементов у выбранного элемента справочника, если количество подчиненных справочников больше чем один?
  • Как получить всех родителей выбранного элемента справочника?
  • Как получить запросом “полный” код элементов справочника, если тип кода – Строка?
  • Как получить все элементы справочника, содержащие в наименовании определенную подстроку, со всей иерархией, в которую они входят?
  • Как найти все элементы справочника, в которых не заполнен строковый реквизит?
  • Как перенести все элементы справочника “Контрагенты” из одной группы в другую?
  • Как организовать программный выбор элемента справочника?
  • Как сохранить фотографию сотрудника в справочнике “Сотрудники”?
  • Как узнать, что справочник новый (УФ)?
  • Как создать элемент (группу) справочника?

    НовыйЭлемент = Справочники.ДокументыУдостоверяющиеЛичность.СоздатьЭлемент();
    НовыйЭлемент.Наименование = "военный билет"; 
    
    // Установить другие реквизиты.  
    ....
    
    НовыйЭлемент.Записать(); 
    
    НовыйЭлемент = Справочники.Банки.СоздатьЭлемент(); 
    
    // Получить ссылку на группу, в которой будет находиться новый элемент. 
    Родитель = Справочники.Банки.НайтиПоКоду("000000001"); 
    
    НовыйЭлемент.Наименование = "АКБ"; 
    НовыйЭлемент.Код = "000000011"; 
    НовыйЭлемент.Родитель = Родитель; 
    
    // Установить другие реквизиты.  
    ....
    
    НовыйЭлемент.Записать(); 
    
    НоваяГруппа = Справочники.Номенклатура.СоздатьГруппу(); 
    
    // Получить ссылку на группу, в которой должна находиться создаваемая группа. 
    Родитель = Справочники.Номенклатура.НайтиПоНаименованию("Обувь", Истина); 
    
    НоваяГруппа.Наименование = "Модельная обувь"; 
    НоваяГруппа.Родитель = Родитель; 
    
    // Установить другие реквизиты.  
    ....
    
    НоваяГруппа.Записать(); 
    
    
    // Создать новый элемент в корне справочника. 
    НовыйЭлемент = Справочники.Подразделения.СоздатьЭлемент(); 
    НовыйЭлемент.Наименование = "IT отдел";  
    НовыйЭлемент.Записать(); 
    
    // Получить ссылку на родителя добавляемых элементов. 
    Родитель = НовыйЭлемент.Ссылка; 
    
    // Создать дочерний элемент. 
    НовыйЭлемент = Справочники.Подразделения.СоздатьЭлемент(); 
    НовыйЭлемент.Наименование = "Группа разработки"; 
    НовыйЭлемент.Родитель = Родитель;  
    
    НовыйЭлемент.Записать();

    Как найти элемент справочника?

    // Найдем по коду
    РезультатПоиска = Справочники.Номенклатура.НайтиПоКоду("00030"); 
    Если РезультатПоиска.Пустая() Тогда 
    	// Выполнить действия, предусмотренные в случае, когда элемент не найден.  
    КонецЕсли; 
    
    // Найдем по наименованию
    РезультатПоиска = Справочники.Номенклатура.НайтиПоНаименованию("Кроссовки"); 
    
    // Найдем по реквизиту
    РезультатПоиска = Справочники.Номенклатура.НайтиПоРеквизиту("Артикул", "К-120002");

    Как удалить элемент справочника?

    // Найти ссылки на удаляемый элемент. 
    МассивСсылок = Новый Массив; 
    МассивСсылок.Добавить(СсылкаНаУдаляемыйЭлемент); 
    НайденныеСсылки = НайтиПоСсылкам(МассивСсылок); 
    
    Если НайденныеСсылки.Количество() > 0 Тогда 
    	Сообщить("Нельзя удалять элемент, на него имеются ссылки"); 
    Иначе 
    	УдаляемыйЭлемент = СсылкаНаУдаляемыйЭлемент.ПолучитьОбъект(); 
    	УдаляемыйЭлемент.Удалить(); 
    КонецЕсли; 
    
    УдаляемыйЭлемент.УстановитьПометкуУдаления(Истина);

    Как перебрать элементы справочника?

    Выборка = Справочники.Номенклатура.ВыбратьИерархически(); 
    Пока Выборка.Следующий() Цикл 
    	Наименование = Выборка.Наименование; 
    
    	// Обращение к другим данным справочника. 
    КонецЦикла; 
    
    Запрос = Новый Запрос(" 
    	|ВЫБРАТЬ 
    	|	Ссылка, 
    	|	Наименование 
    	|ИЗ 
    	|	Справочник.Номенклатура 
    	|АВТОУПОРЯДОЧИВАНИЕ"); 
    
    Результат = Запрос.Выполнить().Выбрать(); 
    
    Пока Результат.Следующий() Цикл 
    	Наименование = Результат.Наименование;  
    КонецЦикла;

    Как выбрать все элементы из определенной группы?

    Выборка = Справочники.Номенклатура.Выбрать(ПолеВводаРодитель); 
    Пока Выборка.Следующий() Цикл 
    	Наименование = Выборка.Наименование;
    КонецЦикла; 
    
    Запрос = Новый Запрос(" 
    	|ВЫБРАТЬ 
    	|	Ссылка, 
    	|	Наименование 
    	|ИЗ 
    	|	Справочник.Номенклатура 
    	|ГДЕ 
    	|	Родитель = &Родитель 
    	|АВТОУПОРЯДОЧИВАНИЕ"); 
    
    Запрос.УстановитьПараметр("Родитель", ПолеВводаРодитель); 
    
    Результат = Запрос.Выполнить().Выбрать(); 
    
    Пока Результат.Следующий() Цикл 
    	Наименование = Результат.Наименование;  
    КонецЦикла; 
    
    Выборка=Справочники.Номенклатура.ВыбратьИерархически(ПолеВводаРодитель); 
    Пока Выборка.Следующий() Цикл 
    	Наименование = Выборка.Наименование;  
    КонецЦикла; 
    
    
    Запрос = Новый Запрос(" 
    	|ВЫБРАТЬ 
    	|	Ссылка, 
    	|	Наименование 
    	|ИЗ 
    	|	Справочник.Номенклатура 
    	|ГДЕ 
    	|	Родитель В ИЕРАРХИИ(&Родитель) 
    	|АВТОУПОРЯДОЧИВАНИЕ"); 
    
    Запрос.УстановитьПараметр("Родитель", ПолеВводаРодитель); 
    
    Результат = Запрос.Выполнить().Выбрать(); 
    
    Пока Результат.Следующий() Цикл 
    	Наименование = Результат.Наименование;  
    КонецЦикла;

    Как перебрать элементы подчиненного справочника с помощью запроса?

    Процедура ПереборПодчиненыхЭлементов(Контрагент) 
    
    	Запрос = Новый Запрос; 
    	Запрос.Текст = "ВЫБРАТЬ 
    	|	КонтактныеЛица.Ссылка 
    	|ИЗ 
    	|	Справочник.КонтактныеЛица КАК КонтактныеЛица 
    	|ГДЕ 
    	|	КонтактныеЛица.Владелец = &Владелец"; 
    
    	Запрос.УстановитьПараметр("Владелец", Контрагент); 
    
    	Результат = Запрос.Выполнить(); 
    	Выборка = Результат.Выбрать(); 
    
    	Пока Выборка.Следующий() Цикл 
    		ОчереднойПодчиненый = Выборка.Ссылка; 
    	КонецЦикла; 
    
    КонецПроцедуры

    Как перебрать элементы подчиненного справочника с помощью выборки справочника?

    Процедура ПереборПодчиненыхЭлементов(Контрагент) 
    
    	// Получить выборку по указанному контрагенту. 
    	Выборка = Справочники.КонтактныеЛица.Выбрать( , Контрагент); 
    
    	Пока Выборка.Следующий() Цикл 
    		ОчереднойПодчиненый = Выборка.Ссылка; 
    	КонецЦикла; 
    
    КонецПроцедуры

    Как открыть форму списка (элемента) справочника?

    Форма = Справочники.Номенклатура.ПолучитьФормуСписка(); 
    Форма.Открыть();
    
    Элемент = Справочники.Номенклатура.НайтиПоКоду("00070"); 
    Форма = Элемент.ПолучитьФорму(); 
    Форма.Открыть();

    Как добавить запись в табличную часть элемента справочника?

    ЭлементОбъект = СсылкаКонтрагент.ПолучитьОбъект(); 
    НоваяСтрока = ЭлементОбъект.ВидыДеятельности.Добавить(); 
    
    // Заполнить реквизиты. 
    НоваяСтрока.ВидДеятельности = ПолеВводаВидДеятельности; 
    
    ЭлементОбъект.Записать();

    Как удалить строки из табличной части справочника?

    ЭлементСправочника = Справочники.Контрагенты.НайтиПоКоду("Ю0006"); 
    ОбъектСправочника = ЭлементСправочника.ПолучитьОбъект(); 
    ОбъектСправочника.ВидыДеятельности.Очистить(); 
    ОбъектСправочника.Записать(); 
    
    
    ОбъектСправочника = ВыбранныйЭлемент.ПолучитьОбъект(); 
    
    // Создать структуру для отбора удаляемых строк. 
    СтруктураОтбора = Новый Структура("ВидДеятельности", ВыбранныйВидДеятельности); 
    
    // Получить массив удаляемых строк. 
    ПодходящиеСтроки = ОбъектСправочника.ВидыДеятельности.НайтиСтроки(СтруктураОтбора); 
    
    // Удалить строки. 
    Для Каждого ОчереднаяСтрока Из ПодходящиеСтроки Цикл 
    	ОбъектСправочника.ВидыДеятельности.Удалить(ОчереднаяСтрока); 
    КонецЦикла; 
    
    ОбъектСправочника.Записать();

    Как перебрать строки табличной части справочника?

    ЭлементСправочника = Справочники.Контрагенты.НайтиПоКоду("Ю0006"); 
    Для Каждого ТекущаяСтрока Из ЭлементСправочника.ВидыДеятельности Цикл 
    	Сообщить(ТекущаяСтрока.ВидДеятельности); 
    КонецЦикла;

    Как создать элемент в нужной группе?

    КодГруппы = "330100"; 
    ПоискПоПолномуКоду = Ложь; // значение по умолчанию 
    Группа = Справочники.Номенклатура.НайтиПоКоду(КодГруппы, ПоискПоПолномуКоду); 
    
    Если Группа.Пустая() Тогда 
    	Группа = Справочники.Номенклатура.СоздатьГруппу(); 
    
    	Группа.Код = КодГруппы; 
    	Группа.Наименование = "Загруженные"; 
    	Группа.Записать(); 
    
    ИначеЕсли Не Группа.ЭтоГруппа Тогда 
    	Сообщить("Найден элемент справочника с указанным кодом!"); 
    
    	// Предусмотреть прерывание алгоритма.
    
    КонецЕсли; 
    
    Спр = Справочники.Номенклатура.СоздатьЭлемент(); 
    Спр.Наименование = "Программно созданный"; 
    
    // Реквизиты заполняются в соответствии с задачей.  
    
    Спр.Родитель = Группа.Ссылка; 
    Спр.Записать(); 
    
    
    Группа = Справочники.Номенклатура.Загруженные; 
    
    
    КодЭлемента = "330100"; 
    ПоискПоПолномуКоду = Ложь; //Значение по умолчанию 
    Родитель = Справочники.Номенклатура.НайтиПоКоду(КодЭлемента, ПоискПоПолномуКоду); 
    
    Если Родитель.Пустая() Тогда 
    Родитель = Справочники.Номенклатура.СоздатьЭлемент(); 
    
    Родитель.Код = КодЭлемента; 
    Родитель.Наименование = "Загруженные"; 
    
    Родитель.Записать(); 
    КонецЕсли; 
    
    Спр = Справочники.Номенклатура.СоздатьЭлемент(); 
    Спр.Наименование = "Программно созданный"; 
    // Реквизиты заполняются в соотвествии с задачей. 
    
    Спр.Родитель = Родитель.Ссылка; 
    Спр.Записать();

    Как узнать, есть ли у текущего элемента подчиненные?

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

    Как узнать количество подчиненных элементов у выбранного элемента справочника?

    Выборка = Справочники.ЕдиницыИзмерения.Выбрать( , Владелец); 
    КоличествоЭлементов = 0; 
    Пока Выборка.Следующий() Цикл 
    	КоличествоЭлементов = КоличествоЭлементов + 1; 
    КонецЦикла; 
    
    
    Запрос = Новый Запрос; 
    Запрос.Текст = "ВЫБРАТЬ 
    	|	КОЛИЧЕСТВО(*) КАК КоличествоЗаписей 
    	|ИЗ 
    	|	Справочник.ЕдиницыИзмерения КАК ЕдиницыИзмерения 
    	|ГДЕ 
    	|	ЕдиницыИзмерения.Владелец = &Владелец"; 
    
    Запрос.УстановитьПараметр("Владелец", Владелец); 
    
    Выборка = Запрос.Выполнить().Выбрать(); 
    
    Если Выборка.Следующий() Тогда 
    	КоличествоЗаписей = Выборка.КоличествоЗаписей; 
    КонецЕсли;

    Как узнать количество подчиненных элементов у выбранного элемента справочника, если количество подчиненных справочников больше чем один?

    ВЫБРАТЬ
    	СУММА(КоличествоПодчиненных) КАК КоличествоПодчиненныхЭлементов 
    ИЗ 
    	(ВЫБРАТЬ 
    		КОЛИЧЕСТВО(*) КАК КоличествоПодчиненных 
    	ИЗ 
    		Справочник.ЕдиницыИзмерения КАК ЕдиницыИзмерения 
    	ГДЕ ЕдиницыИзмерения.Владелец = &Владелец 
    
    	ОБЪЕДИНИТЬ ВСЕ 
    
    	ВЫБРАТЬ 
    		КОЛИЧЕСТВО(*) 
    	ИЗ 
    		Справочник.СерииНоменклатуры КАК СерииНоменклатуры 
    	ГДЕ СерииНоменклатуры.Владелец = &Владелец ) КАК ВложенныйЗапрос

    Как получить всех родителей выбранного элемента справочника?

    МассивРодителей = Новый Массив; 
    Родитель = СсылкаНаЭлемент.Родитель; 
    
    Пока Не Родитель.Пустая() Цикл 
    	МассивРодителей.Добавить(Родитель); 
    	Родитель = Родитель.Родитель; 
    КонецЦикла; 
    
    
    Для Каждого ТекущийРодитель Из МассивРодителей Цикл 
    	// Работа с текущим родителем. 
    КонецЦикла;
    
    //-----------------------------------------------------------------------------------
    
    ТекущийЭлементНоменклатуры = ЭлементНоменклатура; 
    
    Запрос = Новый Запрос("ВЫБРАТЬ 
    	|	Номенклатура.Родитель, 
    	|	Номенклатура.Родитель.Родитель, 
    	|	Номенклатура.Родитель.Родитель.Родитель, 
    	|	Номенклатура.Родитель.Родитель.Родитель.Родитель, 
    	|	Номенклатура.Родитель.Родитель.Родитель.Родитель.Родитель 
    	|ИЗ 
    	|	Справочник.Номенклатура КАК Номенклатура 
    	|ГДЕ 
    	|	Номенклатура.Ссылка = &ТекущийЭлементНоменклатуры"; 
    
    Пока Истина Цикл 
    	Запрос.УстановитьПараметр("ТекущийЭлементНоменклатуры", ТекущийЭлементНоменклатуры); 
    	Результат = Запрос.Выполнить(); 
    	Если Результат.Пустой() Тогда 
    		Прервать; 
    	КонецЕсли; 
    	Выборка = Результат.Выбрать(); 
    	Выборка.Следующий(); 
    
    	Для НомерКолонки = 0 По Результат.Колонки.Количество() - 1 Цикл 
    		ТекущийЭлементНоменклатуры = Выборка[НомерКолонки]; 
    		Если ТекущийЭлементНоменклатуры = Справочники.Номенклатура.ПустаяСсылка() Тогда 
    			Прервать; 
    		Иначе 
    			Сообщить(ТекущийЭлементНоменклатуры); 
    		КонецЕсли; 
    	КонецЦикла; 
    
    	Если ТекущийЭлементНоменклатуры = Справочники.Номенклатура.ПустаяСсылка() Тогда 
    		Прервать;
    	КонецЕсли; 
    КонецЦикла;
    ВЫБРАТЬ 
    	Номенклатура.Ссылка КАК Ссылка 
    ИЗ 
    	Справочник.Номенклатура КАК Номенклатура 
    ГДЕ 
    	Номенклатура.Ссылка = &Ссылка 
    ИТОГИ ПО 
    	Ссылка ТОЛЬКО ИЕРАРХИЯ 

    Как получить запросом “полный” код элементов справочника, если тип кода – Строка?

    ВЫБРАТЬ 
    	Контрагенты.Ссылка, 
    	ВЫБОР 
    		КОГДА (Контрагенты.Родитель.Код ЕСТЬ NULL ) ТОГДА Контрагенты.Код 
    		КОГДА (Контрагенты.Родитель.Родитель.Код ЕСТЬ NULL ) ТОГДА 
    			Контрагенты.Родитель.Код + "/" + Контрагенты.Код 
    		ИНАЧЕ Контрагенты.Родитель.Родитель.Код + "/" + Контрагенты.Родитель.Код + "/" + Контрагенты.Код
    			 
    	КОНЕЦ КАК ПолныйКод 
    ИЗ 
    	Справочник.Контрагенты КАК Контрагенты

    Как получить все элементы справочника, содержащие в наименовании определенную подстроку, со всей иерархией, в которую они входят?

    Запрос = Новый Запрос("ВЫБРАТЬ 
    	|	Контрагенты.Ссылка КАК Ссылка 
    	|ИЗ 
    	|	Справочник.Контрагенты КАК Контрагенты 
    	|ГДЕ 
    	|	(Контрагенты.Наименование ПОДОБНО &ЧастьНаименования) И (НЕ Контрагенты.ЭтоГруппа) 
    	|ИТОГИ ПО 
    	|	Ссылка ТОЛЬКО ИЕРАРХИЯ"); 
    
    Запрос.УстановитьПараметр("ЧастьНаименования", "%" + ПолеВводаПодстрока + "%");

    Как найти все элементы справочника, в которых не заполнен строковый реквизит?

    ВЫБРАТЬ 
    	ФизическиеЛица.Ссылка 
    ИЗ 
    	Справочник.ФизическиеЛица КАК ФизическиеЛица 
    ГДЕ 
    	(ФизическиеЛица.ИНН = "") 
    
    
    ВЫБРАТЬ 
    	ФизическиеЛица.Ссылка 
    ИЗ 
    	Справочник.ФизическиеЛица КАК ФизическиеЛица 
    ГДЕ 
    	(ФизическиеЛица.СтраховойНомерПФР = "") ИЛИ (ФизическиеЛица.СтраховойНомерПФР = " - -")

    Как перенести все элементы справочника “Контрагенты” из одной группы в другую?

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

    Как организовать программный выбор элемента справочника?

    // Получить форму выбора справочника как подчиненную 
    // форме документа 
    ФормаВыбора = Справочники.Номенклатура.ПолучитьФормуВыбора( , ЭтаФорма); 
    
    // Открыть полученную форму 
    ФормаВыбора.Открыть(); 
    
    
    Процедура ОбработкаВыбора(ЗначениеВыбора, Источник) 
    
    	ПолученноеЗначение = ЗначениеВыбора; 
    	// Дальнейшая обработка значения.  
    
    КонецПроцедуры 
    
    
    ФормаВыбора = Справочники.Номенклатура.ПолучитьФормуВыбора( , ЭтаФорма); 
    Выбрано = ФормаВыбора.ОткрытьМодально(); 
    
    
    Процедура ПолеВводаНачалоВыбора(Элемент, СтандартнаяОбработка) 
    
    	// Запретить стандартную обработку. 
    	СтандартнаяОбработка = Ложь; 
    
    	// Получить форму выбора справочника как подчиненную полю ввода. 
    	ФормаВыбора = Справочники.Номенклатура.ПолучитьФормуВыбора( , Элемент); 
    
    	// Открыть полученную форму 
    	ФормаВыбора.Открыть(); 
    
    КонецПроцедуры 
    
    
    Процедура ПолеВводаОбработкаВыбора(Элемент, ВыбранноеЗначение, СтандартнаяОбработка) 
    
    	// Отключить стандартную обработку (при необходимости). 
    	СтандартнаяОбработка = Ложь; 
    
    	ПолученноеЗначение = ВыбранноеЗначение; 
    	// Дальнейшая обработка значения.  
    
    КонецПроцедуры

    Как сохранить фотографию сотрудника в справочнике “Сотрудники”?

    Процедура ЗагрузитьФотографию(Элемент) 
    	Режим = РежимДиалогаВыбораФайла.Открытие; 
    	ДиалогОткрытияФайла = Новый ДиалогВыбораФайла(Режим); 
    	ДиалогОткрытияФайла.ПолноеИмяФайла = ""; 
    	Фильтр = "Текст (*,*)|*.*"; 
    	ДиалогОткрытияФайла.Фильтр = Фильтр; 
    	ДиалогОткрытияФайла.МножественныйВыбор = Ложь; 
    	ДиалогОткрытияФайла.Заголовок = "Выберите картинку"; 
    	Если ДиалогОткрытияФайла.Выбрать() Тогда 
    		ВыбраннаяКартинка = Новый Картинка(ДиалогОткрытияФайла.ПолноеИмяФайла); 
    		ЭлементХранилища = Новый ХранилищеЗначения(ВыбраннаяКартинка); 
    		Фотография = ЭлементХранилища; 
    	КонецЕсли; 
    КонецПроцедуры 
    
    ВыбФайл = Новый ДвоичныеДанные(ДиалогОткрытияФайла.ПолноеИмяФайла); 
    элХранилища = Новый ХранилищеЗначения(ВыбФайл); 
    Фотография = элХранилища;

    Как узнать, что справочник новый (УФ)?

    ФлНовый =  Параметры.Ключ.Пустая();

    Добавить комментарий