Hacker News new | past | comments | ask | show | jobs | submit login
Customizing My Postgres Shell (citusdata.com)
139 points by craigkerstiens on July 16, 2017 | hide | past | favorite | 7 comments



The article doesn't mention enabling unicode output.

    \pset linestyle unicode
and other related formatting options. Some examples here:

    http://postgres.cz/wiki/Pretty_borders_in_psql
    http://okbob.blogspot.co.uk/2014/10/styles-for-unicode-borders-are-merged.html
It's off by default for compatibility, but makes much more readable tabular output. I wrote this back in 2009 for 9.0, but not many people are aware of its existence (at least, I see plenty of ASCII output, and only occasional use of unicode in public writing).


This is cool. Always worth spending some time setting up psql.

In my psqlrc I also have a bunch of "macros" (unfortunately no parameters in psql) for common stuff like transaction handling and SET ROLE / RESET ROLE, lock monitoring etc.: https://github.com/hollobon/psqlrc/blob/master/psqlrc.conf Some of it only works on <=9.4.


Also, check out pgcli:

https://www.pgcli.com


I used pgcli for awhile, but really missed being able to set \x auto. I do like the tab completion quite a bit.


Useful, though I choose:

    \pset null ␀
i.e. U+2400 SYMBOL FOR NULL as my null symbol.


\x auto

All these years I didn't know about this.


The prompt 1 setting in the article emboldens everything and leaves you terminal with the bolded setting on exit as it is missing a '%' It should be:

\set PROMPT1 '%[%033[1m%][%/]%033[0m%]% # '




Join us for AI Startup School this June 16-17 in San Francisco!

Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: