Format PostgreSQL Beautifully on Dbeaver with pg_formatter External Formatter
We need on shortket Ctrl+Shift+F
and the query must look like this.
data:image/s3,"s3://crabby-images/75ca7/75ca7e95ee2731e94f80fb47eed26d08a5420455" alt=""
Problem we have
The default formatter and compact formatter is bad in
- Default formatter — too much line break
SELECT * FROM my_table will have line break - Compact formatter — Need scroll horizontally
INSERT INTO will be so so long
data:image/s3,"s3://crabby-images/60783/607835a55915af49dde9502f7d27b68dc23586af" alt=""
data:image/s3,"s3://crabby-images/4369f/4369fd474f9165c2ecbf5c09d60e4034503b331b" alt=""
The Official Formatter pg_formatter
I have found the sqlparser
written in Python to have some problem with PostgreSQL keyword like uuid_generate_v4()
so I recommend using the pg_formatter
brew install pgformatter
pg_format
-- must see the help instruction
which pg_format
-- /opt/homebrew/bin/pg_format
-- Will copy this path to Dbeaver
Dbeaver setup
Preferences > Editor > SQL Editor > Formatting
You must pick the External Formatter then add the command line
/opt/homebrew/bin/pg_format ${file}
Note that in order to call the ${file}
the option use temp file MUST BE TICKED and at least at this version (2023-Jan) external formatter requires writing temp file.
data:image/s3,"s3://crabby-images/2cf79/2cf79a0c7e8053af3c139bbc1f8a14384afebf28" alt=""
Now we can format beautifully with Ctrl+Shift+F
See you next time.