Перевод текста запроса SQL в запрос 1С

16.10.23

База данных - Инструменты администратора БД

Обработка предназначена для перевода запросов извлечённых из SQL в язык запросов 1С. Работает как в управляемых, так и в обычных формах.

Скачать исходный код

Наименование Файл Версия Размер
Перевод текста запроса SQL в запрос 1С:
.epf 10,64Kb
26
.epf 10,64Kb 26 Скачать

 

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

Протестировано на платформе 8.3.18.1289.

Ниже основной текст программы:

Функция ПереведённыйЗапрос() Экспорт
	
	Если ЗначениеЗаполнено(ЗапросSQL) Тогда
		SQL = СокрЛП(ЗапросSQL);
		SQL = СтрЗаменить(SQL, "[", "");
		SQL = СтрЗаменить(SQL, "]", "");
	Иначе
		Возврат "";
	КонецЕсли;
	
	СтруктурБД = ПолучитьСтруктуруХраненияБазыДанных(,Истина);
	
	СоответствиеИмёнТаблиц = Новый ТаблицаЗначений;
	СоответствиеИмёнТаблиц.Колонки.Добавить("ИмяSQL", Новый ОписаниеТипов("Строка"));
	СоответствиеИмёнТаблиц.Колонки.Добавить("Имя1С", Новый ОписаниеТипов("Строка"));
	СоответствиеИмёнТаблиц.Колонки.Добавить("Алиас", Новый ОписаниеТипов("Строка"));
	СоответствиеИмёнТаблиц.Колонки.Добавить("Поля");
	
	Рез = SQL;
	Сч = Найти(Рез, "dbo.");
	
	Пока Сч > 0 Цикл
		
		Остаток = Сред(Рез, Сч+4);
		Алиас = "";
		
		Сч = Найти(Остаток, " ");
		
		Если Сч > 0 Тогда
			ИмяТаблицыSQL = СокрЛП(Лев(Остаток, Сч));
			Алиас = АлиасТаблицыSQL(ИмяТаблицыSQL, Остаток, Сч);
		Иначе
			ИмяТаблицыSQL = СокрЛП(Остаток);
		КонецЕсли;
		
		НовСтр = СоответствиеИмёнТаблиц.Добавить();
		НовСтр.ИмяSQL = "dbo." + ИмяТаблицыSQL;
		
		СтрокаСтруктурыБД = СтруктурБД.НайтиСтроки(Новый Структура("ИмяТаблицыХранения", ИмяТаблицыSQL));
		Если СтрокаСтруктурыБД.Количество() = 1 Тогда
			НовСтр.Имя1С = СтрокаСтруктурыБД[0].ИмяТаблицы;
			НовСтр.Поля = СтрокаСтруктурыБД[0].Поля;
		Иначе
			НовСтр.Имя1С = ИмяТаблицыSQL;
		КонецЕсли;
		
		НовСтр.Алиас = Алиас;
		
		Если ЗначениеЗаполнено(Алиас) Тогда
			Рез = СтрЗаменить(Рез, НовСтр.ИмяSQL + " " + Алиас, НовСтр.Имя1С + " как " + Алиас);
		Иначе
			Рез = СтрЗаменить(Рез, НовСтр.ИмяSQL, НовСтр.Имя1С);
		КонецЕсли;
		
		Сч = Найти(Рез, "dbo.");
		
	КонецЦикла;
	
	Для Каждого Строка Из СоответствиеИмёнТаблиц Цикл
		
		Если ТипЗнч(Строка.Поля) = Тип("ТаблицаЗначений") Тогда
			
			Для Каждого СтрПоле Из Строка.Поля Цикл
				
				Если ЗначениеЗаполнено(Строка.Алиас) Тогда
					ИмяПоляХранения = Строка.Алиас + "." + СтрПоле.ИмяПоляХранения;
					ИмяПоля1С = Строка.Алиас + "." + СтрПоле.ИмяПоля;
				Иначе
					ИмяПоляХранения = СтрПоле.ИмяПоляХранения;
					ИмяПоля1С = СтрПоле.ИмяПоля;
				КонецЕсли;
				
				Рез = СтрЗаменить(Рез, ИмяПоляХранения, ИмяПоля1С);
				
			КонецЦикла;
			
		КонецЕсли;
		
	КонецЦикла;
	
	Рез = СтрЗаменить(Рез, "LEFT OUTER JOIN", "LEFT JOIN");
	Рез = СтрЗаменить(Рез, "OPTION (FAST 1)", "");
	Рез = СтрЗаменить(Рез, "@", "&");
	
	Возврат Рез;

КонецФункции

Функция АлиасТаблицыSQL(ИмяТаблицыSQL, ОстатокЗапроса, Сч)
	
	Кон = СтрДлина(ОстатокЗапроса);
	Нач = Сч+1;
	Алиас = "";
	
	Для Инд = Нач По Кон Цикл
		
		Врм = Сред(ОстатокЗапроса, Инд, 1);
		
		Если Инд = Нач Тогда
			
			Если Врм = "T" Тогда
				Алиас = "T";
			Иначе
				Прервать;
			КонецЕсли;
			
		Иначе
			
			Если Найти("0123456789", Врм) > 0 Тогда
				Алиас = Алиас + Врм;
			Иначе
				Прервать;
			КонецЕсли;
			
		КонецЕсли;
		
	КонецЦикла;
	
	Возврат Алиас;
	
КонецФункции

 

SQL

См. также

Автоподбор ролей для профилей и групп доступа в любых типовых базах 1С УТ 11, КА 2, ERP2, Розница 2/3, УНФ 16/3, БП 3, ЗУП 3 и подобных (УФ, Платформа 8.3.14+)

Инструменты администратора БД Роли и права 8.3.14 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Документооборот 1С:Зарплата и кадры государственного учреждения 3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Платные (руб)

Роли… Вы тратите много времени и сил на подбор ролей среди около 2400 в ERP или 1500 в Рознице 2, пытаясь понять какими правами они обладают? Вы все время смотрите права в конфигураторе или отчетах чтоб создать нормальные профили доступа? Вы хотите наглядно видеть какие права дает профиль и редактировать все в простом виде? А может хотите просто указать подсистему и дать права на просмотр и добавление на объекты и не лезть в дебри прав и чтоб обработка сама подобрала нужные роли? Все это теперь стало возможно! Обновление от 15.12.2023, версия 1.1.

14400 руб.

06.12.2023    3850    20    1    

43

Infostart УДиФ: Управление данными и формами 1С

Инструменты администратора БД Инструментарий разработчика Роли и права Платформа 1С v8.3 Конфигурации 1cv8 Россия Платные (руб)

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

10000 руб.

10.11.2023    4809    12    2    

38

PowerTools

Инструментарий разработчика Инструменты администратора БД Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Россия Платные (руб)

Универсальный инструмент программиста для администрирования конфигураций. Сборник наиболее часто используемых обработок под единым интерфейсом.

3600 руб.

14.01.2013    179040    1086    0    

863

Ускоренное проведение документов (x4), устранение ошибок 60/62 счетов и зачет авансов (Бухгалтерия 3.0)

Закрытие периода Инструменты администратора БД Корректировка данных Бухгалтерский учет 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

Расширение «Оперативное проведение» в 4 раза уменьшает время проведения документов и закрытия месяца. Является комплексным решением проблем 62 и 60 счетов. Оптимизирует проведение при включенной функциональной опции «Раздельный учет НДС». Используется в более 10 организациях уже 2 года. Совместимо с конфигурацией Бухгалтерия 3.0 (+КОРП).

14400 руб.

29.04.2020    28346    83    146    

61

Конфигурация Session Monitor

Мониторинг Инструменты администратора БД Платформа 1С v8.3 Россия Платные (руб)

Конфигурация Session Monitor предназначена для мониторинга сервера 1С с целью отслеживания чрезмерной нагрузки от конкретных сеансов и скорости реакции рабочих процессов.

1500 руб.

01.12.2020    14485    36    0    

51

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

Инструменты администратора БД Платформа 1С v8.3 1С:Комплексная автоматизация 1.х 1С:Управление производственным предприятием Платные (руб)

Конфигурация Комплексная автоматизация 1.1 (и УПП 1.3 тоже) хранит файлы и изображения в справочнике Хранилище дополнительной информации в реквизите Хранилище типа ХранилищеЗначений. Та же история с ВложениямиЭлектроннойПочты. Но при этом присоединенные файлы в Электронном документообороте хранит в томах на диске. Эта доработка позволяет использовать стандартный механизм хранения файлов, изображений и вложений электронных писем в томах на диске. При этом можно разделить тома хранения по объектам конфигурации.

4200 руб.

10.11.2015    61676    90    59    

74

Хранилище файлов на SQL

Инструменты администратора БД Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Управленческий учет Платные (руб)

Привязка файлов / сканов к объектам 1С с сохранением их на SQL-сервере

12000 руб.

09.10.2019    11268    5    8    

9

Автоматическое резервное копирование любой клиент-серверной базы 1С в формате DT с удалением сеансов, архивацией, изменением расширения (8.3.14+, расширение)

Архивирование (backup) Инструменты администратора БД Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Платные (руб)

Данная разработка позволит решить вопрос с резервным копированием Ваших баз в автоматическом режиме, расположенных на сервере 1С. Система умеет ставить блокировки на вход, блокировать фоновые задания, принудительно отключать сеансы пользователей. И все это система делает в автоматически при создании бэкапа (или через команду). Выгрузка происходит в родной формат 1С - .dt. Так же система умеет архивировать данные выгрузки с установкой пароля. Умеет менять расширение файла zip или dt на любое указанное вами, что позволит сохранить выгрузки от шифровальщика. Может удалять старые копии выгрузок, оставляя указанное количество резервных копий, начиная с самой поздней.

6000 руб.

06.11.2012    70378    622    44    

80
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. гаврюша 2 16.10.23 18:56 Сейчас в теме
А обратного перевода нет (1С в SQL)?
svbel85; seperblunt2; +2 Ответить
3. sapervodichka 6812 17.10.23 11:02 Сейчас в теме
(1) вот держи
Прикрепленные файлы:
ТрансляторЗапросовИз1СвSQL.epf
crazycat; DrAku1a; cleaner_it; webester; maksa2005; гаврюша; acces969; Andreyyy; svbel85; +9 Ответить
5. acces969 344 18.10.23 12:06 Сейчас в теме
(3) Отлично, спасибо. Нужные и удобные инструменты для работы.
2. SerVer1C 767 17.10.23 09:22 Сейчас в теме
Такие конвертеры надо делать с построением абстрактного синтаксического дерева. Чтобы можно было переводить любые запросы.
4. maksa2005 534 18.10.23 06:59 Сейчас в теме
Автор молодец. Спасибо. посмотрел.
Есть конечно особенности из SQL как:
0xAF591CC1DEE6F33211EB8648D9B1DF84

Это реквизит
Прикрепленные файлы:
6. user1647484 9 18.10.23 16:07 Сейчас в теме
сопоставление лучше делать в макете таблицей. очень удобно.
7. kembrik 10 19.10.23 10:35 Сейчас в теме
За стартмани так же обработка, я так понимаю что в тексте статьи? Получается MS SQL only, на PostgreSQL не взлетит судя по dbo? Укажите пожалуйста в требованиях
9. Дмитрий74Чел 234 23.10.23 12:35 Сейчас в теме
8. alex_sayan 19.10.23 18:23 Сейчас в теме
Для понятности псевдонимы таблиц тоже стоит преобразовать. Все эти Т1, Т2... превращаются в неразборчивое месиво. К т-шкам прилепить имя обьекта, и уже станет гораздо нагляднее

Т7 -> ПользователиТ7
Т8 -> ФизическиеЛицаТ8
AlexSTAL; ong1990; altu71; cleaner_it; +4 Ответить
Оставьте свое сообщение