Переписываем запросы 1С для повышения производительности на SQL сервере

В идеальном мире не имело бы значение, какой мы используем синтаксис для формирования запроса. Любой логически идентичный запрос должен бы вызывать одинаковый план выполнения с одинаковыми характеристиками производительности. Для достижения этой цели оптимизатор запросов SQL сервера должен знать различные варианты синтаксиса для конкретной логической конструкции и иметь ресурсы для исследования этих вариантов. В настоящее время такая ситуация просто невозможна.

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

Для достижения этой цели оптимизатор запросов SQL сервера должен знать различные варианты синтаксиса для конкретной логической конструкции и иметь ресурсы для исследования этих вариантов. В настоящее время такая ситуация просто невозможна.  

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

Цель: изучить влияние синтаксиса запроса на генерируемые SQL планы запросов

Тестовая среда:

  • Windows Server 2008 R2 Enterprise
  • MS SQL server 2008 R2
  • 1С:Предприятие 8.2.19.90

SQL properties:

Инструменты:

  • SQL Server Profiler
  • Консоль запросов 1С

Подготовка:

Запускаем SQL Server Profiler, устанавливаем соединение, отмечаем события и колонки как показано на рисунке:

Устанавливаем отбор для нашей базы:

Примеры

Выполняем запрос:

Данный вид запроса сгенерировал следующий план исполнения:

Теперь попробуем упорядочить по полю «Код». В результате получаем следующий план:

Попробуем добавить еще упорядочивание и по полю «Код Улицы В Коде»:

Теперь появились элементы параллелизма.

Далее, если добавить «Различные» и сортировку по убыванию мы получим схожий план выполнения.

Переписываем запрос

Как видно, вариант запроса с отбором "ИЛИ" вместо "В" вызывает тот же план выполнения, разве что работает дольше.

Если добавим упорядочивание по полю «КОД», то получим схожий результат с запросом с "В"

Добавление упорядочивания и по полю «Код Улицы В Коде» вызывает генерацию плана, схожего с запросом “В” при тех же условиях упорядочивания.

Теперь попробуем другой синтаксис:

Теперь мы наблюдаем в корне другой план исполнения, который, правда имеет худшие показатели, по сравнению с самым первым запросом. Если добавим упорядочивание по полю «Код»:

При добавлении упорядочивания по полю «Код Улицы В Коде», получим тот же план выполнения запроса.

Пример запроса с большим количеством таблиц

ВЫБРАТЬ  ПЕРВЫЕ 1000
	УчетЗатратРегл.АналитикаВидаУчета,
	УчетЗатратРегл.АналитикаУчетаЗатрат,
	УчетЗатратРегл.АналитикаУчетаПартий,
	УчетЗатратРегл.АналитикаРаспределенияЗатрат,
	УчетЗатратРегл.Количество,
	УчетЗатратРегл.КоличествоНУ,
	УчетЗатратРегл.Количество КАК КоличествоПолучатель,
	УчетЗатратРегл.КоличествоНУ КАК КоличествоНУПолучатель,
	УчетЗатратРегл.Стоимость,
	УчетЗатратРегл.Стоимость КАК СтоимостьПолучатель,
	УчетЗатратРегл.СтоимостьНУ,
	УчетЗатратРегл.СтоимостьНУ КАК СтоимостьНУПолучатель,
	УчетЗатратРегл.ПостояннаяРазница,
	УчетЗатратРегл.ПостояннаяРазница КАК ПостояннаяРазницаПолучатель,
	УчетЗатратРегл.КодОперации,
	УчетЗатратРегл.КорАналитикаВидаУчета,
	УчетЗатратРегл.КорАналитикаУчетаЗатрат,
	УчетЗатратРегл.КорАналитикаУчетаПартий,
	УчетЗатратРегл.КорАналитикаРаспределенияЗатрат,
	УчетЗатратРегл.НомерСтроки КАК НомерСтрокиВРегистре,
	РегАналитикаВидаУчета.РазделУчета,
	РегАналитикаВидаУчета.Организация,
	РегАналитикаВидаУчета.ПодразделениеОрганизации,
	РегАналитикаВидаУчета.Подразделение,
	РегАналитикаВидаУчета.СчетУчета,
	РегАналитикаВидаУчета.СчетУчетаНУ,
	РегАналитикаВидаУчета.Проект,
	РегАналитикаВидаУчета.Склад,
	РегАналитикаРаспределенияЗатрат.НоменклатурнаяГруппа,
	РегАналитикаРаспределенияЗатрат.Продукция,
	РегАналитикаРаспределенияЗатрат.ХарактеристикаПродукции,
	РегАналитикаРаспределенияЗатрат.СерияПродукции,
	РегАналитикаРаспределенияЗатрат.Спецификация,
	РегАналитикаУчетаЗатрат.СтатьяЗатрат,
	РегАналитикаУчетаЗатрат.Затрата,
	РегАналитикаУчетаЗатрат.ХарактеристикаЗатраты,
	РегАналитикаУчетаЗатрат.СерияЗатраты,
	РегАналитикаУчетаЗатрат.СпособРаспределенияЗатрат,
	РегАналитикаУчетаЗатрат.ХарактерЗатрат,
	РегАналитикаУчетаЗатрат.Качество,
	РегАналитикаУчетаПартий.СтатусПартии,
	РегАналитикаУчетаПартий.Заказ,
	РегАналитикаУчетаПартий.ДоговорКомитента,
	РегАналитикаУчетаПартий.ДоговорКомиссионера,
	РегАналитикаУчетаПартий.Комиссионер,
	КорРегАналитикаВидаУчета.РазделУчета КАК КорРазделУчета,
	КорРегАналитикаВидаУчета.Организация КАК КорОрганизация,
	КорРегАналитикаВидаУчета.ПодразделениеОрганизации КАК КорПодразделениеОрганизации,
	КорРегАналитикаВидаУчета.Подразделение КАК КорПодразделение,
	ЕСТЬNULL(КорРегАналитикаВидаУчета.СчетУчета, КорРегАналитикаУчетаПрочихЗатрат.СчетУчета) КАК КорСчетУчета,
	ЕСТЬNULL(КорРегАналитикаВидаУчета.СчетУчетаНУ, КорРегАналитикаУчетаПрочихЗатрат.СчетУчетаНУ) КАК КорСчетУчетаНУ,
	КорРегАналитикаВидаУчета.Проект КАК КорПроект,
	КорРегАналитикаВидаУчета.Склад КАК КорСклад,
	КорРегАналитикаВидаУчета.Склад КАК СкладПолучатель,
	КорРегАналитикаУчетаПрочихЗатрат.ОбъектСтроительства КАК КорОбъектСтроительства,
	КорРегАналитикаУчетаПрочихЗатрат.СпособСтроительства КАК КорСпособСтроительства,
	КорРегАналитикаУчетаПрочихЗатрат.Субконто1 КАК КорСубконто1,
	КорРегАналитикаУчетаПрочихЗатрат.Субконто2 КАК КорСубконто2,
	КорРегАналитикаУчетаПрочихЗатрат.Субконто3 КАК КорСубконто3,
	КорРегАналитикаУчетаПрочихЗатрат.СубконтоНУ1 КАК КорСубконтоНУ1,
	КорРегАналитикаУчетаПрочихЗатрат.СубконтоНУ2 КАК КорСубконтоНУ2,
	КорРегАналитикаУчетаПрочихЗатрат.СубконтоНУ3 КАК КорСубконтоНУ3,
	КорРегАналитикаУчетаПрочихЗатрат.ДатаИсправительнойЗаписи КАК ДатаИсправительнойЗаписи,
	КорРегАналитикаУчетаПрочихЗатрат.СчитатьРазницыПостоянными КАК СчитатьРазницыПостоянными,
	КорРегАналитикаРаспределенияЗатрат.НоменклатурнаяГруппа КАК КорНоменклатурнаяГруппа,
	КорРегАналитикаРаспределенияЗатрат.Продукция КАК КорПродукция,
	КорРегАналитикаРаспределенияЗатрат.ХарактеристикаПродукции КАК КорХарактеристикаПродукции,
	КорРегАналитикаРаспределенияЗатрат.СерияПродукции КАК КорСерияПродукции,
	КорРегАналитикаРаспределенияЗатрат.Спецификация КАК КорСпецификация,
	КорРегАналитикаУчетаЗатрат.СтатьяЗатрат КАК КорСтатьяЗатрат,
	КорРегАналитикаУчетаЗатрат.Затрата КАК КорЗатрата,
	КорРегАналитикаУчетаЗатрат.ХарактеристикаЗатраты КАК КорХарактеристикаЗатраты,
	КорРегАналитикаУчетаЗатрат.СерияЗатраты КАК КорСерияЗатраты,
	КорРегАналитикаУчетаЗатрат.СпособРаспределенияЗатрат КАК КорСпособРаспределенияЗатрат,
	КорРегАналитикаУчетаЗатрат.ХарактерЗатрат КАК КорХарактерЗатрат,
	КорРегАналитикаУчетаЗатрат.Качество КАК КорКачество,
	КорРегАналитикаУчетаПартий.СтатусПартии КАК КорСтатусПартии,
	КорРегАналитикаУчетаПартий.Заказ КАК КорЗаказ,
	КорРегАналитикаУчетаПартий.ДоговорКомитента КАК КорДоговорКомитента,
	КорРегАналитикаУчетаПартий.ДоговорКомиссионера КАК КорДоговорКомиссионера,
	КорРегАналитикаУчетаПартий.Комиссионер КАК КорКомиссионер,
	УчетЗатратРегл.Регистратор
ИЗ
	РегистрНакопления.УчетЗатратРегл КАК УчетЗатратРегл
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.АналитикаВидаУчета КАК РегАналитикаВидаУчета
		ПО УчетЗатратРегл.АналитикаВидаУчета = РегАналитикаВидаУчета.Ссылка
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.АналитикаУчетаЗатрат КАК РегАналитикаУчетаЗатрат
		ПО УчетЗатратРегл.АналитикаУчетаЗатрат = РегАналитикаУчетаЗатрат.Ссылка
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.АналитикаУчетаПартий КАК РегАналитикаУчетаПартий
		ПО УчетЗатратРегл.АналитикаУчетаПартий = РегАналитикаУчетаПартий.Ссылка
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.АналитикаРаспределенияЗатрат КАК РегАналитикаРаспределенияЗатрат
		ПО УчетЗатратРегл.АналитикаРаспределенияЗатрат = РегАналитикаРаспределенияЗатрат.Ссылка
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.АналитикаВидаУчета КАК КорРегАналитикаВидаУчета
		ПО УчетЗатратРегл.КорАналитикаВидаУчета = КорРегАналитикаВидаУчета.Ссылка
			И (УчетЗатратРегл.КорАналитикаВидаУчета ССЫЛКА Справочник.КлючиАналитикиВидаУчета)
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.АналитикаУчетаПрочихЗатрат КАК КорРегАналитикаУчетаПрочихЗатрат
		ПО УчетЗатратРегл.КорАналитикаВидаУчета = КорРегАналитикаУчетаПрочихЗатрат.Ссылка
			И (УчетЗатратРегл.КорАналитикаВидаУчета ССЫЛКА Справочник.КлючиАналитикиУчетаПрочихЗатрат)
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.АналитикаУчетаЗатрат КАК КорРегАналитикаУчетаЗатрат
		ПО УчетЗатратРегл.КорАналитикаУчетаЗатрат = КорРегАналитикаУчетаЗатрат.Ссылка
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.АналитикаУчетаПартий КАК КорРегАналитикаУчетаПартий
		ПО УчетЗатратРегл.КорАналитикаУчетаПартий = КорРегАналитикаУчетаПартий.Ссылка
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.АналитикаРаспределенияЗатрат КАК КорРегАналитикаРаспределенияЗатрат
		ПО УчетЗатратРегл.КорАналитикаРаспределенияЗатрат = КорРегАналитикаРаспределенияЗатрат.Ссылка
ГДЕ
	УчетЗатратРегл.ВидДвижения = ЗНАЧЕНИЕ(ВидДвиженияНакопления.Расход)
	И УчетЗатратРегл.НомерСтроки >= -1
	И УчетЗатратРегл.Регистратор = &Регистратор

УПОРЯДОЧИТЬ ПО
НомерСтрокиВРегистре	

Показана только часть плана. Видно, что оператор Key Lookup имеет стоимость 52% и весь запрос выполняется 0,415 сек.

Перепишем запрос:

ВЫБРАТЬ ПЕРВЫЕ 1000
	УчетЗатратРегл.Период,
	УчетЗатратРегл.Регистратор,
	УчетЗатратРегл.НомерСтроки,
	УчетЗатратРегл.Активность,
	УчетЗатратРегл.ВидДвижения,
	УчетЗатратРегл.АналитикаВидаУчета,
	УчетЗатратРегл.АналитикаУчетаЗатрат,
	УчетЗатратРегл.АналитикаУчетаПартий,
	УчетЗатратРегл.АналитикаРаспределенияЗатрат,
	УчетЗатратРегл.Количество,
	УчетЗатратРегл.КоличествоНУ,
	УчетЗатратРегл.Стоимость,
	УчетЗатратРегл.СтоимостьНУ,
	УчетЗатратРегл.ПостояннаяРазница,
	УчетЗатратРегл.КодОперации,
	УчетЗатратРегл.КорАналитикаВидаУчета,
	УчетЗатратРегл.КорАналитикаУчетаЗатрат,
	УчетЗатратРегл.КорАналитикаУчетаПартий,
	УчетЗатратРегл.КорАналитикаРаспределенияЗатрат,
	УчетЗатратРегл.МоментВремени
ПОМЕСТИТЬ врУчетЗатратРегл
ИЗ
	РегистрНакопления.УчетЗатратРегл КАК УчетЗатратРегл
ГДЕ
	УчетЗатратРегл.ВидДвижения = ЗНАЧЕНИЕ(ВидДвиженияНакопления.Расход)
	И УчетЗатратРегл.НомерСтроки >= -1
	И УчетЗатратРегл.Регистратор = &Регистратор

УПОРЯДОЧИТЬ ПО
	НомерСтроки
;

////////////////////////////////////////////////////////////////////////////////
ВЫБРАТЬ 
	УчетЗатратРегл.АналитикаВидаУчета,
	УчетЗатратРегл.АналитикаУчетаЗатрат,
	УчетЗатратРегл.АналитикаУчетаПартий,
	УчетЗатратРегл.АналитикаРаспределенияЗатрат,
	УчетЗатратРегл.Количество,
	УчетЗатратРегл.КоличествоНУ,
	УчетЗатратРегл.Количество КАК КоличествоПолучатель,
	УчетЗатратРегл.КоличествоНУ КАК КоличествоНУПолучатель,
	УчетЗатратРегл.Стоимость,
	УчетЗатратРегл.Стоимость КАК СтоимостьПолучатель,
	УчетЗатратРегл.СтоимостьНУ,
	УчетЗатратРегл.СтоимостьНУ КАК СтоимостьНУПолучатель,
	УчетЗатратРегл.ПостояннаяРазница,
	УчетЗатратРегл.ПостояннаяРазница КАК ПостояннаяРазницаПолучатель,
	УчетЗатратРегл.КодОперации,
	УчетЗатратРегл.КорАналитикаВидаУчета,
	УчетЗатратРегл.КорАналитикаУчетаЗатрат,
	УчетЗатратРегл.КорАналитикаУчетаПартий,
	УчетЗатратРегл.КорАналитикаРаспределенияЗатрат,
	УчетЗатратРегл.НомерСтроки КАК НомерСтрокиВРегистре,
	РегАналитикаВидаУчета.РазделУчета,
	РегАналитикаВидаУчета.Организация,
	РегАналитикаВидаУчета.ПодразделениеОрганизации,
	РегАналитикаВидаУчета.Подразделение,
	РегАналитикаВидаУчета.СчетУчета,
	РегАналитикаВидаУчета.СчетУчетаНУ,
	РегАналитикаВидаУчета.Проект,
	РегАналитикаВидаУчета.Склад,
	РегАналитикаРаспределенияЗатрат.НоменклатурнаяГруппа,
	РегАналитикаРаспределенияЗатрат.Продукция,
	РегАналитикаРаспределенияЗатрат.ХарактеристикаПродукции,
	РегАналитикаРаспределенияЗатрат.СерияПродукции,
	РегАналитикаРаспределенияЗатрат.Спецификация,
	РегАналитикаУчетаЗатрат.СтатьяЗатрат,
	РегАналитикаУчетаЗатрат.Затрата,
	РегАналитикаУчетаЗатрат.ХарактеристикаЗатраты,
	РегАналитикаУчетаЗатрат.СерияЗатраты,
	РегАналитикаУчетаЗатрат.СпособРаспределенияЗатрат,
	РегАналитикаУчетаЗатрат.ХарактерЗатрат,
	РегАналитикаУчетаЗатрат.Качество,
	РегАналитикаУчетаПартий.СтатусПартии,
	РегАналитикаУчетаПартий.Заказ,
	РегАналитикаУчетаПартий.ДоговорКомитента,
	РегАналитикаУчетаПартий.ДоговорКомиссионера,
	РегАналитикаУчетаПартий.Комиссионер,
	КорРегАналитикаВидаУчета.РазделУчета КАК КорРазделУчета,
	КорРегАналитикаВидаУчета.Организация КАК КорОрганизация,
	КорРегАналитикаВидаУчета.ПодразделениеОрганизации КАК КорПодразделениеОрганизации,
	КорРегАналитикаВидаУчета.Подразделение КАК КорПодразделение,
	ЕСТЬNULL(КорРегАналитикаВидаУчета.СчетУчета, КорРегАналитикаУчетаПрочихЗатрат.СчетУчета) КАК КорСчетУчета,
	ЕСТЬNULL(КорРегАналитикаВидаУчета.СчетУчетаНУ, КорРегАналитикаУчетаПрочихЗатрат.СчетУчетаНУ) КАК КорСчетУчетаНУ,
	КорРегАналитикаВидаУчета.Проект КАК КорПроект,
	КорРегАналитикаВидаУчета.Склад КАК КорСклад,
	КорРегАналитикаВидаУчета.Склад КАК СкладПолучатель,
	КорРегАналитикаУчетаПрочихЗатрат.ОбъектСтроительства КАК КорОбъектСтроительства,
	КорРегАналитикаУчетаПрочихЗатрат.СпособСтроительства КАК КорСпособСтроительства,
	КорРегАналитикаУчетаПрочихЗатрат.Субконто1 КАК КорСубконто1,
	КорРегАналитикаУчетаПрочихЗатрат.Субконто2 КАК КорСубконто2,
	КорРегАналитикаУчетаПрочихЗатрат.Субконто3 КАК КорСубконто3,
	КорРегАналитикаУчетаПрочихЗатрат.СубконтоНУ1 КАК КорСубконтоНУ1,
	КорРегАналитикаУчетаПрочихЗатрат.СубконтоНУ2 КАК КорСубконтоНУ2,
	КорРегАналитикаУчетаПрочихЗатрат.СубконтоНУ3 КАК КорСубконтоНУ3,
	КорРегАналитикаУчетаПрочихЗатрат.ДатаИсправительнойЗаписи КАК ДатаИсправительнойЗаписи,
	КорРегАналитикаУчетаПрочихЗатрат.СчитатьРазницыПостоянными КАК СчитатьРазницыПостоянными,
	КорРегАналитикаРаспределенияЗатрат.НоменклатурнаяГруппа КАК КорНоменклатурнаяГруппа,
	КорРегАналитикаРаспределенияЗатрат.Продукция КАК КорПродукция,
	КорРегАналитикаРаспределенияЗатрат.ХарактеристикаПродукции КАК КорХарактеристикаПродукции,
	КорРегАналитикаРаспределенияЗатрат.СерияПродукции КАК КорСерияПродукции,
	КорРегАналитикаРаспределенияЗатрат.Спецификация КАК КорСпецификация,
	КорРегАналитикаУчетаЗатрат.СтатьяЗатрат КАК КорСтатьяЗатрат,
	КорРегАналитикаУчетаЗатрат.Затрата КАК КорЗатрата,
	КорРегАналитикаУчетаЗатрат.ХарактеристикаЗатраты КАК КорХарактеристикаЗатраты,
	КорРегАналитикаУчетаЗатрат.СерияЗатраты КАК КорСерияЗатраты,
	КорРегАналитикаУчетаЗатрат.СпособРаспределенияЗатрат КАК КорСпособРаспределенияЗатрат,
	КорРегАналитикаУчетаЗатрат.ХарактерЗатрат КАК КорХарактерЗатрат,
	КорРегАналитикаУчетаЗатрат.Качество КАК КорКачество,
	КорРегАналитикаУчетаПартий.СтатусПартии КАК КорСтатусПартии,
	КорРегАналитикаУчетаПартий.Заказ КАК КорЗаказ,
	КорРегАналитикаУчетаПартий.ДоговорКомитента КАК КорДоговорКомитента,
	КорРегАналитикаУчетаПартий.ДоговорКомиссионера КАК КорДоговорКомиссионера,
	КорРегАналитикаУчетаПартий.Комиссионер КАК КорКомиссионер,
	УчетЗатратРегл.Регистратор
ИЗ
	врУчетЗатратРегл КАК УчетЗатратРегл
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.АналитикаВидаУчета КАК РегАналитикаВидаУчета
		ПО УчетЗатратРегл.АналитикаВидаУчета = РегАналитикаВидаУчета.Ссылка
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.АналитикаУчетаЗатрат КАК РегАналитикаУчетаЗатрат
		ПО УчетЗатратРегл.АналитикаУчетаЗатрат = РегАналитикаУчетаЗатрат.Ссылка
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.АналитикаУчетаПартий КАК РегАналитикаУчетаПартий
		ПО УчетЗатратРегл.АналитикаУчетаПартий = РегАналитикаУчетаПартий.Ссылка
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.АналитикаРаспределенияЗатрат КАК РегАналитикаРаспределенияЗатрат
		ПО УчетЗатратРегл.АналитикаРаспределенияЗатрат = РегАналитикаРаспределенияЗатрат.Ссылка
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.АналитикаВидаУчета КАК КорРегАналитикаВидаУчета
		ПО УчетЗатратРегл.КорАналитикаВидаУчета = КорРегАналитикаВидаУчета.Ссылка
			И (УчетЗатратРегл.КорАналитикаВидаУчета ССЫЛКА Справочник.КлючиАналитикиВидаУчета)
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.АналитикаУчетаПрочихЗатрат КАК КорРегАналитикаУчетаПрочихЗатрат
		ПО УчетЗатратРегл.КорАналитикаВидаУчета = КорРегАналитикаУчетаПрочихЗатрат.Ссылка
			И (УчетЗатратРегл.КорАналитикаВидаУчета ССЫЛКА Справочник.КлючиАналитикиУчетаПрочихЗатрат)
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.АналитикаУчетаЗатрат КАК КорРегАналитикаУчетаЗатрат
		ПО УчетЗатратРегл.КорАналитикаУчетаЗатрат = КорРегАналитикаУчетаЗатрат.Ссылка
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.АналитикаУчетаПартий КАК КорРегАналитикаУчетаПартий
		ПО УчетЗатратРегл.КорАналитикаУчетаПартий = КорРегАналитикаУчетаПартий.Ссылка
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.АналитикаРаспределенияЗатрат КАК КорРегАналитикаРаспределенияЗатрат
		ПО УчетЗатратРегл.КорАналитикаРаспределенияЗатрат = КорРегАналитикаРаспределенияЗатрат.Ссылка

Появился дополнительный план по созданию временной таблицы

Мы избавились от тяжелого оператора Key Lookup и добились значительных улучшений показателей производительности, несмотря на дополнительную операцию по созданию временной таблицы

Выводы

Мы отметили, что синтаксис запроса может влиять на выбор оптимизатором того или иного плана исполнения запроса, несмотря на то, что логически мы получаем один и тот же результат. Также можно отметить, что,например, синтаксис, содержащий «ОБЪЕДИНИТЬ ВСЕ» иногда может привести к выбору оптимизатором оптимального плана, иногда может ухудшить показатели. Использование временных таблиц также может улучшить показатели производительности.

Переписывание запросов и попытки использовать альтернативный синтаксис являются допустимой техникой «тюнинга» запросов, однако необходимо соблюдать некоторые меры предосторожности. Одним из рисков является то, что будущие изменения продукта (MS SQL Server) могут привести к тому, что конкретная форма запроса неожиданно перестанет генерировать лучший план, но это всегда риск и его можно уменьшить предварительным тестированием перед обновлением.

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

Начать дискуссию

QIWI станет страусом

QIWI объявляет о проведении ежегодного общего собрания акционеров в 2024 году

ВТБ отчитался об успехах и сложностях импортозамещения иностранного ПО

Выбрали главное из интервью, которое Вадим Кулик дал «Ведомостям»

Упрощенцам, даже свободным от уплаты НДС в 2025 году, придется формировать счета-фактуры. «Ночной бухгалтер» № 1725

Появляется все больше сопутствующих поправкам по налоговой реформе 2025 проблем. Упрощенцев с доходами до 60 млн рублей освободили от НДС автоматически, но при этом не убрали обязанность выставлять счета-фактуры. Бухгалтеры уже всерьез начинают называть УСН усложненной системе налогообложения.

Иллюстрация: Вера Ревина / Клерк.ру

Курсы повышения
квалификации

18
Официальное удостоверение с занесением в госреестр Рособрнадзора
Бесплатно с Отчетность

Ответственность бухгалтера после увольнения

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

Иллюстрация: Вера Ревина/Клерк.ру
1
Бухгалтерский учет

Бухучет для начинающих: рассказываем о дебетах, кредитах и первичке простым языком

Как устроена профессия бухгалтера, с какими задачами он работает и что означают все эти странные сокращения (НДС, ПСН, ЕНС и др.) — разбираемся в основах бухгалтерии.

Иллюстрация: Вера Ревина /Клерк.ру

Блогер Ивлеева должна налоговой больше 20 млн рублей

Сумма долга Анастасии Ивлеевой выросла до 20,9 млн рублей. Блогер не может выплатить задолженность уже три месяца.

Опытом делятся эксперты-практики, без воды
Бесплатно с НДФЛ

Новые налоговые базы и ставки НДФЛ с 2025 года: таблица

С 2025 года вводят новую прогрессивную шкалу НДФЛ.

Новые налоговые базы и ставки НДФЛ с 2025 года: таблица
Кадры

👍 Теперь в бизнес-аккаунте на «Клерке» можно продвигать свои вакансии

Продуктовая команда «Клерка» запустила новый функционал бизнес-аккаунтов: работодатели могут бесплатно размещать вакансии и, по желанию, платно их продвигать.

Верховный суд: валютный долг не должен индексироваться за просрочку

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

Счета-фактуры

👎 Освобожденных от НДС упрощенцев не освободили от счетов-фактур. Прогноз налогового инженера

Если доход за предыдущий год не превышает 60 млн рублей, в текущем году при УСН будет освобождение от НДС по статье 145 НК.

На сотрудников из стран ЕАЭС тоже надо подавать уведомление в миграционную службу

При приеме на работу иностранцев из стран ЕАЭС надо уведомлять Управление по вопросам миграции МВД о заключении с ними трудовых или гражданско-правовых договоров.

Минэкономразвития отмечает уверенный рост организаций в «русских офшорах»

Сейчас в специальных административных районах зарегистрировано 428 международных холдинговых компаний. Резиденты САР могут пользоваться налоговыми льготами, а также применять корпоративное право той страны, из которой организация решила переехать в РФ.

Законопроекты

РСПП поддержал законопроект о платформенной занятости в РФ

Президент РСПП Александр Шохин концептуально поддержал законопроект «О платформенной занятости в Российской Федерации».

Прогрессивная шкала налогов всё же будет введена

Информация о том, что рассматривается законопроект о введении прогрессивной налоговой шкалы, согласно которой ставка будет зависеть от размеров дохода, уже какое-то время будоражит общественность. К сожалению, такое нововведение с большой вероятностью будет реализовано.

В базе «Клерка» уже больше 1 000 актуальных резюме!

Больше тысячи бухгалтеров, кадровиков, юристов, руководителей, финансистов и специалистов по 1С ищут работодателей с сервисом Клерк.Работа.

Обзоры новостей

⚡️ Итоги дня: с второклассницы хотят взыскать 700 тысяч рублей, мошенники обманывают пользователей Ozon, а у Xiaomi сбой в работе умных устройств

Подготовили обзор главных событий дня — 16 июля 2024 года. Все самое интересное, что писали и обсуждали в сети, в одной подборке.

Интернет и IT

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

У абонентов при пополнении баланса наличными будут требовать паспорт.

Кадры

👷 Каждый третий наниматель сталкивается с неквалифицированными кандидатами. Почему, объясняет организатор опроса

Главной сложностью при подборе персонала опрошенные называют недостаточную компетенцию кандидатов на открытую вакансию — об этом говорят 54% респондентов.

Банки

Китайские партнеры перестали получать платежи через «ВТБ Шанхай»

Импортеры не могут отправить деньги китайским поставщикам через шанхайский филиал ВТБ.

Интересные материалы

Банки

ЦБ будет оперативно рассматривать сообщения об ошибочном включении в реестр мошенников

Те, кто по ошибке попал в список Центробанка, смогут оспорить это решение и разблокировать возможность проводить денежные переводы.