Таблица значений, быстрое удаление дублей строк

Публикация № 190123 07.06.13

Разработка - Механизмы платформы 1С

Быстрое удаление дублей строк в таблице значений по списку колонок.

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

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

Специальные предложения

Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. kapustinag 07.06.13 18:21 Сейчас в теме
И какая получилась производительность? С какими вариантами сравнивали?
2. q_i 549 11.06.13 21:07 Сейчас в теме
Для Каждого Колонка Из БуфернаяТаблицаДанных.Колоники Цикл
ivangrant; user645801_yyyuuu123q; SP2000; Zircool; Vorobyov; +5 Ответить
3. bulpi 209 12.06.13 10:02 Сейчас в теме
Нужно пару слов про идею и алгоритм написать, а не только текст процедуры. Чем Ваш вариант лучше того, что я сейчас сяду и напишу за 10 минут на коленке?
4. CagoBHuK 32 13.06.13 09:53 Сейчас в теме
Алгоритм писателя на 1С 77. Проще всего:
ВЫБРАТЬ * ПОМЕСТИТЬ ВременнаяТаблица ИЗ &Таблица КАК ВременнаяТаблица;
ВЫБРАТЬ РАЗЛИЧНЫЕ * ИЗ ВременнаяТаблица
Dmitri93; strelvan; ProChelny; ilego; ivangrant; alsegor; 2711640; Bublik2011; Kserken; Азбука Морзе; higs; +11 Ответить
6. abe 12.08.13 12:07 Сейчас в теме
(4) CagoBHuK, нужно иметь в виду, что добавится передача/возврат данных на SQL.
8. CagoBHuK 32 12.08.13 12:15 Сейчас в теме
(6) В данном случае речь шла о таблице значений, которую на клиенте Вы никак не сможете получить. Использование метода "Скопировать" доступно только для универсальных коллекций значений, которые не могут существовать на клиенте. Иными словами сам код обработки предполагает серверный вызов.
9. abe 12.08.13 12:18 Сейчас в теме
(8) CagoBHuK, я и не спорю относительно серверного (сервера 1С) вызова, добавится вызов именно SQL сервера.
10. CagoBHuK 32 12.08.13 14:38 Сейчас в теме
(9) Вы считаете, что он будет длиться дольше, чем представленный алгоритм пересчета?
12. CeHbKA 293 14.01.14 09:41 Сейчас в теме
(4) CagoBHuK, это при условии что все поля строк одинаковые.

Если, например, в таблице 4 колонки и дубли удалять надо только по 3 колонкам, то вариант стар как мир и даже описан в синтакс-помощнике (осторожно, код в стиле "капитан очевидность"):

	Для каждого Строка из ТаблицаЗначений цикл
		Отбор = Новый Структура();
		Отбор.Вставить("Наименование", Строка.Наименование);
		Отбор.Вставить("Артикул", Строка.Артикул);
		Отбор.Вставить("Количество", Строка.Количество);
		Отбор.Вставить("Сумма", Строка.Сумма);		
		
		Строки = ТаблицаЗначений.НайтиСтроки(Отбор);
		
		Если Строки.Количество() > 1 Тогда
			Сч = 0;
			Пока Сч<Строки.Количество()-1 Цикл
				ТаблицаЗначений.Удалить(Строки[Сч]);	
				Сч = Сч+1;
			КонецЦикла;
		КонецЕсли;		
	КонецЦикла;
Показать

=)
SIrina9; ivangrant; Ankiss; ya.Avoronov; +4 1 Ответить
17. nselyutin 09.04.20 08:53 Сейчас в теме
Предложу свой вариант, немного улучшенный (12) больше универсальности, про быстродействие так же не могу сказать, тесты не проводил:

Процедура УдалитьДублиСтрокИзТаблицы(ИсходнаяТаблица, СписокКолонок = "") Экспорт
	
	Если СписокКолонок = "" Тогда 
			
		КолонкиТаблицы = ИсходнаяТаблица.ВыгрузитьКолонки().Колонки;

		ИменаКолонок = Новый Массив;
		
		Для Каждого КолонкаТаблица Из КолонкиТаблицы Цикл
			
			Если КолонкаТаблица.Имя = "НомерСтроки" Тогда
				
				Продолжить;
				
			КонецЕсли;
			
			ИменаКолонок.Добавить(КолонкаТаблица.Имя);
			
		КонецЦикла;

	Иначе
		
		ИменаКолонок = СтрРазделить("СписокКолонок", ",", Ложь);

	КонецЕсли;
	
	ИндексВерхний = 0;
	
	Пока ИндексВерхний < ИсходнаяТаблица.Количество() Цикл
		
		Строка = ИсходнаяТаблица[ИндексВерхний];
		
		Отбор = Новый Структура();
		
		Для Каждого ИмяКолонки Из ИменаКолонок Цикл
		
			Отбор.Вставить(ИмяКолонки, Строка[ИмяКолонки]);
			
		КонецЦикла;	
        
        Строки = ИсходнаяТаблица.НайтиСтроки(Отбор);
        
        Если Строки.Количество() > 1 Тогда
			
			Индекс = 0;
			
			Пока Индекс < Строки.Количество() - 1 Цикл
				
				ИсходнаяТаблица.Удалить(Строки[Индекс]);    
				
				Индекс = Индекс + 1;
				
			КонецЦикла;
			
		Иначе
			
			ИндексВерхний = ИндексВерхний + 1;
			
		КонецЕсли;
		
    КонецЦикла;
	
КонецПроцедуры
Показать
5. Vorobyov 25 14.06.13 15:51 Сейчас в теме
Можно использовать и запрос, спорить не буду. Таблицу нужно будет подготовить - описать типы колонок, и также добавить колонку, по которой будет происходить суммирование.
Далее почти по тексту, только нужно будет выбирать не различные, а группировать по нужному списку колонок (строить запрос динимически), и добавить в запрос условие "Имеющие сумма(КолонкаСуммирования) = 1". (просто различные использовать нельзя из-за значений в других колонках таблицы). Далее эту сгруппированную временную таблицу нужно будет джойнить с первоначальной временной таблицей, в условиях связи прописывать равенство по выбранным полям (строить условие динамически), плюс нужно будет в случае если нужно не удалить все дублирующие строки, а оставить по одной из удаляемых тоже это предусмотреть.

Хотел еще сказать, что этот способ расчитан, на большое количество строк в таблице, и малое количество строк с дублями, для других случаев можно это делать быстрее другим способом.

Вариант написанный на коленке возможно будет эффективнее, если предоставится возможность, хотел бы на него посмотреть и возможно использовать с Вашего разрешения.
7. abe 12.08.13 12:09 Сейчас в теме
Я бы еще подумал над добавлением индекса(ов) в таблицу значений (по которой выполняется поиск).
ImHunter; +1 Ответить
11. prodines 107 10.12.13 13:15 Сейчас в теме
Мой вариант:

МассивДублей = Новый Массив;
МассивСотрудников = Новый Массив; // проверяемое на дубль значение

Для каждого Строка Из ТЗНачисления Цикл

Если Строка.СпособРасчета = Перечисления.СпособыРасчетаОплатыТруда.СдельныйЗаработок Тогда // критерий сравнения на дубль, может быть любой

Элем = МассивСотрудников.Найти(Строка.Сотрудник);

Если Элем = Неопределено Тогда // это первое вхождение проверяемого на дубль сотрудника

МассивСотрудников.Добавить(Строка.Сотрудник);

Иначе // а это - уже мы дубль встретили, по данному сотруднику и по данному критерию проверки на дубль

МассивДублей.Добавить(Строка);

КонецЕсли;

КонецЕсли;

КонецЦикла;

Если МассивДублей.Количество() > 0 Тогда

Для каждого Элем Из МассивДублей Цикл

ТЗНачисления.Удалить(Элем);

КонецЦикла;

КонецЕсли;
Показать


Вся проверка делается за один проход. Очень просто.
isn; maikl007; Art39_; mart-sha; +4 Ответить
13. MaiorovYury 10 14.04.14 15:25 Сейчас в теме
14. DJDUH 17 14.04.14 15:57 Сейчас в теме
Ну как-бы есть и такой метод Таблицы Значений, как Свернуть("Групп колонки", " сумм колонки") если ничего не нужно суммировать, а только убрать дубли, подходит только групп колонки!
Слыхал наверное!?
15. logarifm 1110 29.11.19 18:52 Сейчас в теме
Так будет круче:

// Удаляет дубли строк из таблицы значений.
//
// Параметры:
//  ТаблицаИсточник           - ТаблицаЗначений - Таблица из которой необходимо удалить дубли строк
//  МассивИменКолонок         - Массив          - Имена колонок по которым производится поиск соответствий
//  ИмяКолонкиУказательСтроки - Строка          - Наименование колонки с указателем строки. 
//			Где значения указателя Тип Число, Строка
//			Например: указан параметр "НомерСтрокиФайла". Для каждой строки таблицы он равняется числам 1,2,3,4 и т.д.
//          При удалении дублирующих строк в исходящую таблицу будет добавлена колонка "УказательСтроки", где и будут размещены эти "идентификаторы/указатели". 
//          Колонка "НомерСтрокиФайла" будет содержать какое-то из значений.  
//          	"УказательСтроки"  = "4;1;2;3;" 
// 		        "НомерСтрокиФайла" = 4
//          Удаление происходит обратным перебором поэтому числа резмещены в таком порядке.
//
// Возвращаемое значение:
//   ТаблицаЗначений   - Содержит коллекцию имен входящих колонок.
//      Когда был указан параметр "ИмяКолонкиУказательСтроки" то добавляется колонка "УказательСтроки"
//
Функция УдалитьДублиСтрокИзТаблицыЗначений(ТаблицаИсточник, МассивИменКолонок, ИмяКолонкиУказательСтроки = "") Экспорт
	
	ИмяКлючевыхКолонок = СтрСоединить(МассивИменКолонок, ",");
	
	Если Не ПустаяСтрока(ИмяКолонкиУказательСтроки) Тогда
		ИмяКлючевыхКолонок = ИмяКлючевыхКолонок + "," + ИмяКолонкиУказательСтроки;
	КонецЕсли;	
	
	Таблица = ТаблицаИсточник.Скопировать(,ИмяКлючевыхКолонок);
	Если Не ПустаяСтрока(ИмяКолонкиУказательСтроки) Тогда
		Таблица.Колонки.Добавить("УказательСтроки");
	КонецЕсли;	
	
	СтруктураОтбора = Новый Структура;
	Для каждого Имя Из МассивИменКолонок Цикл
		СтруктураОтбора.Вставить(Имя);
	КонецЦикла;	
	
	ИндексСтроки = Таблица.Количество()-1;
	Пока Истина Цикл
		
		Если ИндексСтроки < 0 Тогда
			Прервать;
		КонецЕсли;
		
		СтрокаЗначений = Таблица.Получить(ИндексСтроки);
		ЗаполнитьЗначенияСвойств(СтруктураОтбора, СтрокаЗначений);
		
		НайденныеСтроки = Таблица.НайтиСтроки(СтруктураОтбора);
		Если НайденныеСтроки.Количество() > 1 Тогда
			
			Для каждого УдаляемаяСтрока Из НайденныеСтроки Цикл
				
				Если Таблица.Индекс(УдаляемаяСтрока) = ИндексСтроки Тогда
					Продолжить; //оставляем текущую строку 
				КонецЕсли;	
				
				//укажем какие указатели строк были удалены
				Если Не ПустаяСтрока(ИмяКолонкиУказательСтроки) Тогда
					
					ТекПозицияСтр = Формат(СтрокаЗначений[ИмяКолонкиУказательСтроки], "ЧГ=0");
					Если СтрНайти(СтрокаЗначений.УказательСтроки, ТекПозицияСтр) = 0 Тогда
						
						СтрокаЗначений.УказательСтроки = ТекПозицияСтр + ";";
						
					КонецЕсли;	
					
					СтрокаЗначений.УказательСтроки = СтрокаЗначений.УказательСтроки + Формат(УдаляемаяСтрока[ИмяКолонкиУказательСтроки],"ЧГ=0") + ";";
					
				КонецЕсли;	
				
				Таблица.Удалить(УдаляемаяСтрока);
				ИндексСтроки = ИндексСтроки - 1;//строк становится меньше (уменшаем индекс)
				
			КонецЦикла;	
			
		КонецЕсли;
		
		ИндексСтроки = ИндексСтроки - 1;
		
	КонецЦикла;
	
	Возврат Таблица;
КонецФункции	
Показать
16. burni4 84 27.12.19 10:02 Сейчас в теме
Предложу свой вариант, по быстродействию утверждать ничего не могу

// Процедура - Удаляет дубли строк из таблицы значений
//
// Параметры:
//  ТекущаяТаблицаЗначений	 - 	"ТаблицаЗначений,ТабличнаяЧасть"  - таблица значений в которой необходимо удалить дубли строк 
//
Процедура УдалитьДублиСтрокВТаблицеЗначений(ТекущаяТаблицаЗначений) Экспорт 
	
	 
	Если ТипЗнч(ТекущаяТаблицаЗначений)<>Тип("ТаблицаЗначений") тогда
		Возврат;
	КонецЕсли;
	
	ПеречислениеВсехКолонок="";
	
	Для каждого СтрокаКолонки из ТекущаяТаблицаЗначений.Колонки цикл
		
		ПеречислениеВсехКолонок= ПеречислениеВсехКолонок + СтрокаКолонки.Имя +",";
		
	КонецЦикла;
	
	Если ПеречислениеВсехКолонок="" тогда
		Возврат;
	Иначе
		ПеречислениеВсехКолонок = Лев(ПеречислениеВсехКолонок, СтрДлина(ПеречислениеВсехКолонок)-1);
	КонецЕсли;
	
	ТекущаяТаблицаЗначений.Свернуть(ПеречислениеВсехКолонок);	
	

КонецПроцедуры
Показать
GetNight; +1 Ответить
19. GetNight 46 04.09.20 11:51 Сейчас в теме
(16) как оказалось, сам решил эту задачу точно таким же способом), только с помощью оператора Сред вместо Лев+СтрДлина

    Для каждого СтрокаКолонки из ТекущаяТаблицаЗначений.Колонки цикл
        
        ПеречислениеВсехКолонок = ПеречислениеВсехКолонок + "," + СтрокаКолонки.Имя;
        
    КонецЦикла;
    
    Если ПеречислениеВсехКолонок = "" тогда
        Возврат;
    Иначе
        ПеречислениеВсехКолонок = Сред(ПеречислениеВсехКолонок, 2);
    КонецЕсли;
Показать
18. o3ophuk 25.06.20 23:20 Сейчас в теме
Процедура норм! Автору лайк!
Оставьте свое сообщение

См. также

Снова об использовании ТекущаяДата() на клиенте и на сервере и о работе в разных часовых поясах

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

Можно ли применять ТекущаяДата() вопреки требованиям стандартов 1С? Безопасно ли использование функции ОбщегоНазначенияКлиент.ДатаСеанса() из БСП? Как правильно поступать при работе пользователей в разных часовых поясах?

24.04.2023    3987    Alxby    26    

40

Самодельный обработчик ПослеЗаписи объекта

Механизмы платформы 1С Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Иногда при записи объекта хочется обработчик ПослеЗаписи, который бы выполнялся всегда после успешного завершения транзакции записи объекта. Статья описывает способ реализации такого обработчика.

03.04.2023    2797    tormozit    63    

39

Расширение глобального поиска 1С, или Глобальный поиск "на максималках"

Механизмы платформы 1С Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Мало кто знает, что поле "Глобального поиска" в 1С можно доработать. Добавить свои варианты поиска, кнопочки в результатах и даже целые пользовательские меню.

27.03.2023    4164    SeiOkami    9    

121

Postgres как предчувствие. Вычисляем процент импортозамещения в режиме Highload от 1С

HighLoad оптимизация Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

1С работает с СУБД Postgres более 10 лет, а сейчас это единственный легальный вариант для инсталляций в России. Много ли мы потеряем в производительности по сравнению с MS SQL? Выдержит ли Postgres 15.2 жесткий Highload со стороны 1С? Цель этой статьи - ответить на данные вопросы, с цифрами, которые можно использовать при расчете архитектуры.

23.03.2023    1625    1CUnlimited    9    

28

Версионирование объектов VS История данных

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Давайте разберемся в механизме «История данных» и поэкспериментируем для наглядности. Сравним «Версионирование объектов» и «Историю данных».

06.03.2023    5779    dsdred    37    

124

Оператор GOTO в 1С - табу или волшебная палочка?

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

В ежедневной практике программирования на платформе 1С оператор Goto (Перейти) практически не встречается. Не удивительно, что половина специалистов даже не подозревает о существовании данного оператора. Ну, а знающим он внушает ужас, и его стараются избегать. Так что же это за редкий оператор, и для чего он нужен?

19.02.2023    5669    Dementor    72    

43

Идентификатор объекта в запросе. Вы этого хотели?

Запросы Механизмы платформы 1С Платформа 1С v8.3 Запросы Бесплатно (free)

В платформе 8.3.22 появилась возможность получать идентификатор в запросе. Лично я ждал этого давно, но по итогу ждал большего. Что не так?

12.01.2023    12756    dsdred    15    

68

Маленькие хитрости большой платформы (часть 1)

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

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

29.12.2022    4210    zeltyr    25    

41

Практическая шпаргалка по новым возможностям языка запросов 1С

Механизмы платформы 1С Запросы Платформа 1С v8.3 Запросы Конфигурации 1cv8 Бесплатно (free)

В предлагаемой статье решил привести примеры применения новых возможностей языка запросов 1С, начиная с версии платформы 8.3.20.

21.11.2022    16274    quazare    34    

113

Создаем периодические реквизиты или привет из 1С 7.7

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Конечно же, платформа 1С:Предприятие 8 не поддерживает периодические реквизиты, в статье описано использование типовой методики периодических сведений в коробочных решениях от 1С.

26.10.2022    1297    morin    4    

26

Асинхронное нечто, или так, как раньше!

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Все же знают, что раньше было лучше! Возврат к истокам и погружение в детали...

23.10.2022    4758    starik-2005    38    

40

О цикле обратном замолвите слово...

Механизмы платформы 1С Языки и среды Платформа 1С v8.3 Платформа 1C v8.2 Бесплатно (free)

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

08.09.2022    6418    DrAku1a    69    

31

1С и Unicode

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Разбираемся, как 1С работает с текстом и отдельными символами в контексте Unicode.

05.09.2022    4690    Irwin    30    

80

Шпаргалка по функциям АСИНХ

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

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

29.07.2022    16955    zeltyr    17    

146

Экспертный кейс. История расследования одного небыстрого закрытия месяца в 1C:ERP. Пример неочевидных путей расследования в виде детективной истории

HighLoad оптимизация Механизмы платформы 1С Запросы Платформа 1С v8.3 1С:ERP Управление предприятием 2 Бесплатно (free)

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

11.07.2022    5734    it-expertise    27    

57

Состав индексов с дополнительным упорядочиванием на уровне СУБД (MS SQL) при индексации реквизитов

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

В момент обсуждения с коллегами работы индексов в 1С был затронут один из вопросов, который касался темы - каким образом происходит построение индексов при индексации реквизитов у объектов 1С (конкретнее, когда свойство реквизита "Индексировать" устанавливается в "Индексировать с доп. упорядочиванием"). Ранее я всегда опирался на знания, полученные в процессе чтения официальной документации от компании 1С, опубликованной на ITS. Наши мнения в этом вопросе разошлись и, как оказалось позже, мои знания не были актуальными, в итоге было проведено некоторое исследование по данному вопросу, чтобы выяснить истину.

15.06.2022    3060    sinichenko_alex    9    

34

Динамическое обновление - это зло?

Механизмы платформы 1С Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Копнем глубже в тему "Что же такое динамическое обновление" и почему оно может привести к проблемам. И может ли?

09.05.2022    18185    Infostart    79    

228

Об одной неочевидной проблеме перехода на версию платформы 8.3.20

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

При переходе на платформу 8.3.20 мы столкнулись с ошибкой "Повторяющийся псевдоним "Ссылка" Ссылка AS Ссылка,Presentation AS Presentation,Ссылка AS Ссылка" в ряде типовых конфигураций. Причём, эта проблема оказались неизвестна ни Яндексу, ни Гуглу. Путём мучительных экспериментов нам удалось найти решение. Пока я ещё не уверен, действительно это решение или обходной костыль, а настоящая проблема -- в чём-то другом, но это решение работает в ситуации, когда всё сломалось, а проблему надо решать срочно. Предположительная причина: платформа 8.3.20 более строго относится к типизации данных в запросах, чем предыдущие версии, вываливая в случае несоблюдения новшеств малопонятные ошибки.

08.04.2022    6861    Kernelbug    26    

34

Отборы динамического списка

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Динамический список предоставляет несколько объектов "Отбор". В статье разбирается, какой для чего нужен и как их использовать на форме. Рассматриваются только возможности платформы (без БСП).

28.03.2022    28701    Gladkov_Anton    7    

72

Фишки платформы 1С 8.3 для начинающего разработчика

Механизмы платформы 1С Платформа 1С v8.3 Конфигурации 1cv8 Россия Бесплатно (free)

В данной заметке рассмотрены вспомогательные инструменты платформы, которыми часто пренебрегают начинающие программисты 1С.

11.03.2022    11164    Dimbayyyy    98    

61

Экспертный кейс. Расследование деградации производительности системы. Проведение документа “Поступление товаров и услуг” (1С:ERP 2)

Механизмы платформы 1С Запросы HighLoad оптимизация Платформа 1С v8.3 1С:ERP Управление предприятием 2 Бесплатно (free)

В ходе проведения нагрузочного тестирования одним из наших клиентов была выявлена сильная деградация производительности системы в целом и, в частности, выполнения ключевой операции “Проведение документа поступление товаров и услуг” в течение выполнения теста. Согласно данным подсистемы БСП “Оценка производительности”, время выполнения ключевой операции “Проведение документа поступление товаров и услуг” возрастало в процессе тестирования с 15-20 секунд в начале тестирования до 150-200 секунд в его финале.

02.03.2022    4283    it-expertise    50    

31

Модульная архитектура или пара слов о расширениях. Часть I (мысли, рассуждения)

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

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

14.02.2022    6849    amon_ra    67    

25

Синхронный и асинхронный вызов в новых версиях платформы

Механизмы платформы 1С Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Начиная с платформы 8.3.18.1128 переработана технология работы с асинхронными вызовами. В данной статье хочу описать новые асинхронные вызовы и сравнить их с предыдущими на примере функции - Вопрос на клиенте.

31.01.2022    7064    Shining_ninja    17    

36

Несколько простых приемов для удобной работы в конфигураторе

Универсальные функции Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Простая и удобная среда разработки 1С:Предприятия позволяет практически любому человеку начать работать под капотом 1С - в конфигураторе. Время идет, новички становятся программистами, специалистами, а об удобных приемах работы узнают годами, по ходу своего карьерного пути. А здорово было бы, если бы все знали удобные приемы в начале своего пути? Эти несколько приемов будут полезны новичкам, так как они затрагивают ту область работы, с которой приходится сталкиваться в начале карьеры.

12.11.2021    13500    acces969    95    

142

Как спроектировать структуру регистра сведений

Механизмы платформы 1С Платформа 1С v8.3 Запросы Бесплатно (free)

«Что может быть проще?» — это первое, что приходит в голову. Но что, если это не так? В этой статье мы попробуем затронуть некоторые вопросы, которые могут возникнуть при проектировании больших регистров.

08.11.2021    9160    Neti    60    

108

О вложенных попытках, исключениях и о представлении ошибок

Механизмы платформы 1С Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

В данной статье, на небольшом примере, мне бы хотелось показать, как себя ведут вложенные "Попытка-Исключение". А также о том, чем отличаются методы ОписаниеОшибки() и ИнформацияОбОшибке().

07.11.2021    14014    Nicholas    22    

47

Обработчик ожидания. Нюансы

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

ПодключитьОбработчикОжидания: некоторые подробности и особенности работы

24.08.2021    27034    Yashazz    26    

65

Прогресс-бар в поле динамического списка

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Изображаем прогресс-бары в колонке динамического списка

23.08.2021    4690    Yashazz    13    

39

ПриПолученииДанныхНаСервере + Контекст формы. Лайфхак

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Передать свои произвольные данные в событие, которое "без контекста"? Легко!

13.08.2021    7655    Yashazz    16    

44

Новичок новичку: как добавить программно кнопку на форму путем расширения

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

Рассказываю очень простым языком, как добавить программно кнопку в типовую конфигурацию. Сам новичок в этом деле и рассказываю на "новичковом" языке.

13.05.2021    44543    user1312100    29    

73

Программное создание расширения

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Создание нового расширения "на лету", только штатными средствами 1С.

06.04.2021    7376    Yashazz    16    

77

Советы из Желтой тетради 📒 #1

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

В этой публикации я собрал в одном месте часть советов и лайфхаков, которые открыл для себя в последнее время. Регулярно я публикую их в своём телеграм-блоге "Жёлтая тетрадь 📒 Блог программиста 1С", здесь же - дайджест этих публикаций.

15.03.2021    6581    builin    120    

53

Расширенный автоподбор при вводе по строке в поле ввода в управляемых формах

Механизмы платформы 1С Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Бесплатно (free)

Началось все с того, что штатный автоподбор при вводе по строке в поле ввода для некоторых больших справочников устраивать перестал. Вообще, для способа поиска строки "Любая часть" он работает на первый взгляд очень хорошо: работает как полнотекстовый (т.е. по нескольким словам) даже без активации полнотекстового поиска, красиво подсвечивает слова поиска в результатах. Казалось бы, все отлично. Но есть неприятное ограничение - всего лишь 10 значений в результирующем списке (у вас может быть несколько больше, так как платформа неявно добавляет результаты поиска по истории ввода). Для небольших справочников или справочников с разнородным ассортиментом все хорошо. Но не в моей ситуации. А простых путей увеличить количество выдаваемых строк на момент написания статьи мне обнаружить не удалось. Пришлось полностью переопределять автоподбор. Ниже речь пойдет именно об этом. И, к слову, в типовых конфигурациях для некоторых справочников используются похожие приемы для увеличения количества строк результата автоподбора.

21.01.2021    11271    herfis    9    

52

О формах 1С замолвите слово... Необычное использование знакомого всем объекта

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

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

13.01.2021    10836    CyberCerber    46    

101

Наследование свойств элементов, или Как пользователь может сломать вашу форму

Механизмы платформы 1С Платформа 1С v8.3 Платформа 1C v8.2 Конфигурации 1cv8 Бесплатно (free)

В 1С можно установить свойства ТолькоПросмотр, Доступность и Видимость не только на элементы формы, но и на группы элементов. Но стоит ли так делать? Оказывается, пользователь может обойти запреты, которые установлены на папку. Об этом подробнее в видео.

12.01.2021    6801    SeiOkami    27    

112

Ускоряем медленный/долгий и тормозной стандартный поиск по динамическому списку, настраиваем его под себя

Механизмы платформы 1С Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Бесплатно (free)

Пользователи привыкли искать на форме списка, но, вбивая в поиск некорректные данные, могут завесить всю систему, а если еще искать нужно по НЕ полям списка, то решение только в своём поиске - все это решим в публикации с открытым кодом.

14.12.2020    41324    SizovE    2    

40

Передача параметров по значению в языке 1С

Механизмы платформы 1С Платформа 1С v8.3 ИТ-компания Бесплатно (free)

Все мы знаем, что в 1С можно написать такое: Процедура ОбработатьОбъект(Знач Объект) КонецПроцедуры Т.е. тем самым мы передаем в процедуру параметр по значению Далее в статье будут рассмотрены некоторые особенности передачи по значению объектов НЕпримитивных типов.

26.11.2020    6587    direktorSan    9    

29