169 похожих чатов

Мне тут приспичило встроить в программу форматировние текста SQL, расставить

переносы строк и отступы так, чтобы лучше читалось. Я что-то свое изобразил, оно после ключевых слов переносы ставит и длинные строки укорачивает по пробелам, но это все равно не то. Нужен парсер в дерево языковых блоков, чтобы всякие вложеные запросы, операторы и процедуры корректно обрабатывать. Может кто видел что-то готовое и не слишком сложное? Я находил на JS, какую-то навороченую штуку с форматированием и подсветкой. Но ее адаптировать не хочется, только в крайнем случае.

11 ответов

5 просмотров

https://github.com/geoffsmith82/DelphiSqlParser

у нас используется PoorMansTSqlFormatterLib для mssql... для postgre - свой пурификатор. тебе вообще для какого sql нужен? https://github.com/TaoK/PoorMansTSqlFormatter

Сергей Журавлев
https://github.com/geoffsmith82/DelphiSqlParser

странно, там не указано какие именно SQL диалекты он понимает.

Sergey-Bodrov Автор вопроса
Михаил Усков
у нас используется PoorMansTSqlFormatterLib для ms...

Мне для Postgre и для Sybase. Postgre в приоритете

Sergey-Bodrov Автор вопроса
Михаил Усков
у нас используется PoorMansTSqlFormatterLib для ms...

Спасибо огромное, тут и лицензия годная. Дальше я сам под себя доработаю.

В HTML Library Bundle входит SQL Framework, он не просто форматирование дает, а полноценно разбирает с учетом диалекта, определяет ошибки, позволяет делать code completion, изменять запрос (добавлять условия, менять сортировку, добавлять джойны, лимиты и.т.д) и даже выполнять запросы локально.

Alexander Sv
В HTML Library Bundle входит SQL Framework, он не ...

Какой общий предок в HTML Library c VCL-классами? TObject -> ... ?

notme
Какой общий предок в HTML Library c VCL-классами? ...

Общий предок чего? HtPanel она от TCustomPanel унаследована, HtLabel от Label

Alexander Sv
Общий предок чего? HtPanel она от TCustomPanel уна...

ну всех контролов ) я не знаю какие они там есть в этой библиотеке

Похожие вопросы

Обсуждают сегодня

Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
48
а проверьте, собирается ли у кого сейчас транк лазаря через делюкс? у меня вот: fpcupdeluxe: info: Lazarus Native Installer (BuildModuleCustom: UserIDE): LazBuild: building Us...
Iluha Companets
20
Такой вопрос: Почему DocLister, если указать другие шаблоны для пагинации - ко всем указанными шаблоном присваивается пустая строка?
Кирилл Гацевич
11
добрый день. возможно ли изменить цвет окон лазаруса? Как?
Budemposmotret
35
This is a big issue. Just by being a citizen of a country, you are denied to contribute to Open Source software: https://youtu.be/L5Ec5jrpLVk?si=1iIuHnMPbCB4anV-
Sharuzzaman Ahmat Raslan
72
Господа, а кто-нибудь сталкивался с размещением на TTabControl/TTabSheet множества контролов (> 100) с последующими External: Access violation? Вот буквально на ровном месте. ...
Dmitry
29
Вот например простой пример, как получить стоимость хешрейта монеты монеро с сайта whattomine.com c использование сеарилизатора при парсинге JSON TaskProfit := TTask.Run(proc...
Delphi Coder
2
А какие существуют способы обработки ошибок выделения памяти в ядре? Т.е., допустим, есть функция, которая возвращает адрес свободной страницы в физической памяти и диапазон в...
disba1ancer
51
Does anyone have some zeroday's left?
Wito!d ♥️🩷
44
ну так че, сделать програмулину, в которую можно добавлять в Едиты свои строчки кода(закладки) а потом по ним прыгать. ну и сохраняться они естественно будут той програмуленно...
Kraszx
15
Карта сайта