Поиск данных справочников по вхождению всех слов

04.11.14

Задачи пользователя - Поиск данных

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

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
Поиск
.epf 7,39Kb ver:1.0
24
24 Скачать (1 SM) Купить за 1 850 руб.

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

Каким образом это можно реализовать? Да очень просто. Давайте по порядку.

1) Разбиваем нужную нам строку на массив слов, используя как разделитель символ пробела

2) Первым делом выбираем все элементы справочника без каких либо условий

3) Проходимся циклом по Массиву слов и делаем запрос к справочнику, но уже с условиемм ПОДОБНО "%НАШЕСЛОВО%"

4) Результат запроса выгружаем в массив значение и этот массив подставляем параметром в следующий шаг цикла

 

Т.е. по сути мы постоянно получаем результат, и из этого результата дальше ищем по второму и третьему и т.д слову.

Алгорит по безобразия прост в разработке и использовании. Можете использовать готовый кусок кода, скачав обработку, в которой можно искать по любому типу справочника.

 

Всем спасибо за внимание.

универсальный поиск

См. также

Поиск данных Системный администратор Программист Платформа 1С v8.3 Управляемые формы 1C:Бухгалтерия Платные (руб)

Обработки помогут Вам легко и, главное, быстро (в 5 раз и быстрее штатной обработки 1С), выполнить поиск дублирующих данных в Ваших базах 1С на платформах 8.1-8.3. Это позволит уменьшить объем лишней информации в справочниках и документах, планах видов характеристик и др., упростит работу с данными пользователям. А так же можно, одним нажатием, узнать в каких ссылочных объектах есть вообще дубли! Понятное расположение команд и настроек, в сочетании с описанием и справкой, еще упростят процесс. А так же обновления Вы получаете бесплатно в течение года с момента приобретения данных обработок! (Обновление от 27.11.2023, версия 6.12)

10800 руб.

14.05.2012    160157    341    253    

574

Математика и алгоритмы Инструментарий разработчика Универсальные функции Поиск данных Программист Платформа 1С v8.3 1C:Бухгалтерия 1С:ERP Управление предприятием 2 Абонемент ($m)

Несколько упакованных в один класс интерфейсов для обработки популярных универсальных коллекций. Для тех, кого раздражает отсутствие действительно единого интерфейса для универсальных коллекций.

5 стартмани

25.09.2024    2742    1    Артано    14    

19

Поиск данных Программист Платформа 1С v8.3 Россия Бесплатно (free)

В этой статье я хочу рассмотреть еще один кейс применения Clickhouse в связке с 1С - оптимизацию поиска в справочнике по ключевым словам. Здесь не будет готового решения, но будут описаны важные моменты, которые позволят легко применить данный кейс в реальности.

18.08.2024    2371    1cnik2    23    

17

Поиск данных Программист Платформа 1С v8.3 1C:Бухгалтерия Абонемент ($m)

Отображение и просмотр реквизитов справочника или документа - с бесконечным открытием подуровней.

1 стартмани

14.06.2024    3887    12    RustIG    33    

22

Поиск данных Системный администратор Программист Платформа 1С v8.3 Россия Абонемент ($m)

Статья об опыте развертывания и интеграции с базой данных Manticore Search для быстрого полнотекстового поиска.

1 стартмани

30.11.2023    5327    andreysidor4uk    18    

56

Поиск данных Системный администратор Программист Пользователь Платформа 1С v8.3 1C:Бухгалтерия Абонемент ($m)

Стандартная обработка с доработанным выводом ссылок в виде дерева с учётом фильтра и с удобным подбором исходного объекта

2 стартмани

24.11.2023    1440    19    SerVer1C    10    

10

Поиск данных Корректировка данных Пользователь Платформа 1С v8.3 Управляемые формы 1C:Бухгалтерия Абонемент ($m)

PowerOffice - обработка для поиска, просмотра и обработки данных для пользователей. Доступ к объектам на просмотр и редактирование данных определяется правами пользователя.

1 стартмани

05.06.2023    2492    26    PowerBoy    1    

16

Поиск данных Программист Платформа 1С v8.3 Управляемые формы 1C:Бухгалтерия Абонемент ($m)

Получение ссылки в 1С по бинарной строке из PostgreSQL в виде строки формата bytea или из MSSQL в виде шестнадцатиричной строки. Кроме ссылочных объектов ссылки могут быть получены и для перечислений. Это может быть полезно при анализе логов журнала регистрации или СУБД.

1 стартмани

04.04.2023    3445    4    berserg    2    

13
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. BigB 193 04.11.14 19:04 Сейчас в теме
Полнотекстовый поиск Вам в помощь!
KasperRWF; HiKS; ojiojiowka; +3 Ответить
2. Justindj 25 04.11.14 20:17 Сейчас в теме
(1) BigB, Разницу понимаешь между использованием полнотекстового поиска и моей идеей? Включение в режиме конфигуратора использование индексов и увеличение размера базы из за этого, постоянно обновлять индекс. Мою идею можно развить и искать по любому реквизиту в любом справочнике или документе и обрабатывать результат в удобной для пользователя форме. Сам смысл быстро подобрать товар или контрагента по набору слов и дальше его использовать для подстановки в документы или еще кудато...
3. DO_WHILE_LOOP 360 06.11.14 16:14 Сейчас в теме
Соглашусь с Justindj полнотекстовый поиск не всегда подходит, но предложенный алгоритм не оптимальный, я бы его оптимизировал например так:
Функция ПолучитьСписокВыбора(Текст, ВидСправочника)
	
	// Создаем список, который каждый раз будет заменятся новыми значениями
	СписокВыбора = Новый СписокЗначений;
	
	Если ЗначениеЗаполнено(Текст) Тогда 
		
		// Создадим текст условия поиска
		УсловиеПоиска = "";
		ТекстТемп = СтрЗаменить(Текст, " ", Символы.ПС);
		Для Счетчик = 1 По СтрЧислоСтрок(ТекстТемп) Цикл 
			УсловиеПоиска = УсловиеПоиска + "И Справочник.Наименование ПОДОБНО ""%" + СтрПолучитьСтроку(ТекстТемп, Счетчик) + "%""" + Символы.ПС;
		КонецЦикла;
		
		
		// А вот и сам алгоритм
		Запрос = Новый Запрос;
		Запрос.Текст = "ВЫБРАТЬ ПЕРВЫЕ 25
		|	Справочник.Ссылка КАК Значение
		|ИЗ
		|	Справочник." + ВидСправочника + " КАК Справочник
		|ГДЕ
		|	Справочник.ЭтоГруппа = ЛОЖЬ
		|	" + УсловиеПоиска + "
		|
		|УПОРЯДОЧИТЬ ПО
		|	Справочник.Наименование";
		
		СписокВыбора.ЗагрузитьЗначения(Запрос.Выполнить().Выгрузить().ВыгрузитьКолонку("Значение"));
		
	КонецЕсли;
	
	Возврат СписокВыбора;
	
КонецФункции

Показать
4. pereligins 21 24.03.15 18:21 Сейчас в теме
Исходный пример и пример в комментарии работают очень медленно, особенно на больших справочниках.
Рекомендую делать одним запросом, работает даже быстрее, причем еще и сортирует результат по наименованию:

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