Skip to content

Latest commit

 

History

History
294 lines (201 loc) · 9.26 KB

PostgreSQL.md

File metadata and controls

294 lines (201 loc) · 9.26 KB
title output
PostgreSQL Notes for STM
pdf_document

PostgreSQL Notes for STM


Wednesday 5/24/2023

Fix COPYs broken escape system

The COPY function converts all embedded double quotes into \" . So if your embedded quotes are already escaped (as row_to_json and jsonb_agg produce), then the double quotes will be double escaped thus producing invalid json.

While the COPY command allows you to fix this ONLY IF you are exporting to CSV, for all other formats it does not offer any help.

You can fix the double escaped double quote output afterwards using the following SED one liner.

cat money10.json    | sed 's/\\\\"/\\"/g' > money10Fixed.json

Convert SQL output to a proper JSON object

This version produces a proper array of objects as 1 properly formatted and complete json object. (But it still has the double quote problem described below)

select jsonb_agg(v.*) as Money from (select id, title, body from posts where posttypeid=1 limti 10) as v;

Tuesday 5/23/2023

Convert SQL output to JSON

The following works but does not join all the rows together in an array. Instead each row is a proper json object but you cannot then send the output into a program that expects one complete json object (or an array of json objects - which is what I want.)

SELECT row_to_json(v.*) AS Money 
FROM (SELECT id, title, body FROM posts WHERE posttypeid=1 ORDER BY id LIMIT 20000) AS v;

Save SQL out to a file

The COPY function converts all embedded double quotes into \" . So if your embedded quotes are already escaped (as row_to_json and jsonb_agg produce), then the double quotes will be double escaped thus producing invalid json.

COPY (
  SELECT row_to_json(v.*) AS Money 
  FROM (SELECT id, title, body FROM posts WHERE posttypeid=1 ORDER BY id LIMIT 20000) AS v)
TO '/tmp/money20000.json' ;

Friday 5/12/2023

Upgrade to PostgreSQL 15.3 from 15.2_3 on gokart

==> postgresql@15 This formula has created a default database cluster with: initdb --locale=C -E UTF-8 /usr/local/var/postgresql@15 For more details, read: https://www.postgresql.org/docs/15/app-initdb.html

postgresql@15 is keg-only, which means it was not symlinked into /usr/local, because this is an alternate version of another formula.

If you need to have postgresql@15 first in your PATH, run: fish_add_path /usr/local/opt/postgresql@15/bin

For compilers to find postgresql@15 you may need to set: set -gx LDFLAGS "-L/usr/local/opt/postgresql@15/lib" set -gx CPPFLAGS "-I/usr/local/opt/postgresql@15/include"

For pkg-config to find postgresql@15 you may need to set: set -gx PKG_CONFIG_PATH "/usr/local/opt/postgresql@15/lib/pkgconfig"

To restart postgresql@15 after an upgrade: brew services restart postgresql@15 Or, if you don't want/need a background service you can just run: LC_ALL="C" /usr/local/opt/postgresql@15/bin/postgres -D /usr/local/var/postgresql@15


Tuesday 3/14/2023

On Gokart I upgraded from postgresql@15 15.2 -> 15.2_3

==> postgresql@15
This formula has created a default database cluster with:
  initdb --locale=C -E UTF-8 /usr/local/var/postgresql@15
For more details, read:
  https://www.postgresql.org/docs/15/app-initdb.html

postgresql@15 is keg-only, which means it was not symlinked into /usr/local,
because this is an alternate version of another formula.

If you need to have postgresql@15 first in your PATH, run:
  fish_add_path /usr/local/opt/postgresql@15/bin

For compilers to find postgresql@15 you may need to set:
  set -gx LDFLAGS "-L/usr/local/opt/postgresql@15/lib"
  set -gx CPPFLAGS "-I/usr/local/opt/postgresql@15/include"

For pkg-config to find postgresql@15 you may need to set:
  set -gx PKG_CONFIG_PATH "/usr/local/opt/postgresql@15/lib/pkgconfig"


To start postgresql@15 now and restart at login:
  brew services start postgresql@15

Tuesday 02/14/2023

On Gokart I upgraded from postgresql@15 15.1_1 to 15.2

==> postgresql@15
This formula has created a default database cluster with:
  initdb --locale=C -E UTF-8 /usr/local/var/postgresql@15
For more details, read:
  https://www.postgresql.org/docs/15/app-initdb.html

postgresql@15 is keg-only, which means it was not symlinked into /usr/local,
because this is an alternate version of another formula.

If you need to have postgresql@15 first in your PATH, run:
  fish_add_path /usr/local/opt/postgresql@15/bin

For compilers to find postgresql@15 you may need to set:
  set -gx LDFLAGS "-L/usr/local/opt/postgresql@15/lib"
  set -gx CPPFLAGS "-I/usr/local/opt/postgresql@15/include"

For pkg-config to find postgresql@15 you may need to set:
  set -gx PKG_CONFIG_PATH "/usr/local/opt/postgresql@15/lib/pkgconfig"


To start postgresql@15 now and restart at login:
  brew services start postgresql@15

Tuesday 01/24/2023

On RoadRunner I upgraded both versions of PostgreSQL (13 & 14)

postgresql@14 14.6 -> 14.6_1
postgresql@13 13.9 -> 13.9_1

Upgrading postgresql@13

==> Upgrading postgresql@13
  13.9 -> 13.9_1

==> Pouring postgresql@13--13.9_1.big_sur.bottle.tar.gz
==> Caveats
This formula has created a default database cluster with:
  initdb --locale=C -E UTF-8 $(brew --prefix)/var/postgresql@13
For more details, read:
  https://www.postgresql.org/docs/13/app-initdb.html

postgresql@13 is keg-only, which means it was not symlinked into /usr/local,
because this is an alternate version of another formula.

If you need to have postgresql@13 first in your PATH, run:
  echo 'export PATH="/usr/local/opt/postgresql@13/bin:$PATH"' >> ~/.zshrc

For compilers to find postgresql@13 you may need to set:
  export LDFLAGS="-L/usr/local/opt/postgresql@13/lib"
  export CPPFLAGS="-I/usr/local/opt/postgresql@13/include"

For pkg-config to find postgresql@13 you may need to set:
  export PKG_CONFIG_PATH="/usr/local/opt/postgresql@13/lib/pkgconfig"


To start postgresql@13 now and restart at login:
  brew services start postgresql@13
==> Summary
🍺  /usr/local/Cellar/postgresql@13/13.9_1: 3,240 files, 43.3MB
==> Running `brew cleanup postgresql@13`...

Upgrading postgresql@14

==> Upgrading postgresql@14
  14.6 -> 14.6_1

==> Pouring postgresql@14--14.6_1.big_sur.bottle.tar.gz

This formula has created a default database cluster with:
  initdb --locale=C -E UTF-8 $(brew --prefix)/var/postgresql@14
For more details, read:
  https://www.postgresql.org/docs/14/app-initdb.html

To start postgresql@14 now and restart at login:
  brew services start postgresql@14

Monday 01/23/2023

On Gokart, I Upgraded to postgresql@15.1_1.ventura.bottle.tar.gz via brew

brew upgrade postgresql@15

==> Installing postgresql@15
==> Pouring postgresql@15--15.1_1.ventura.bottle.tar.gz
==> Caveats
This formula has created a default database cluster with:
  initdb --locale=C -E UTF-8 /usr/local/var/postgresql@15
For more details, read:
  https://www.postgresql.org/docs/15/app-initdb.html

postgresql@15 is keg-only, which means it was not symlinked into /usr/local,
because this is an alternate version of another formula.

If you need to have postgresql@15 first in your PATH, run:
  fish_add_path /usr/local/opt/postgresql@15/bin

For compilers to find postgresql@15 you may need to set:
  set -gx LDFLAGS "-L/usr/local/opt/postgresql@15/lib"
  set -gx CPPFLAGS "-I/usr/local/opt/postgresql@15/include"

For pkg-config to find postgresql@15 you may need to set:
  set -gx PKG_CONFIG_PATH "/usr/local/opt/postgresql@15/lib/pkgconfig"


To restart postgresql@15 after an upgrade:
  brew services restart postgresql@15
Or, if you don't want/need a background service you can just run:
  /usr/local/opt/postgresql@15/bin/postgres -D /usr/local/var/postgresql@15
==> Summary
🍺  /usr/local/Cellar/postgresql@15/15.1_1: 3,345 files, 44.9MB
==> Running `brew cleanup postgresql@15`...
Disable this behaviour by setting HOMEBREW_NO_INSTALL_CLEANUP.
Hide these hints with HOMEBREW_NO_ENV_HINTS (see `man brew`).
Removing: /usr/local/Cellar/postgresql@15/15.1... (3,345 files, 44.9MB)

Wednesday 11/16/2022

  • Upgrade to 14.6 via brew
==> Upgrading postgresql@14
  14.5_5 -> 14.6

==> Pouring postgresql@14--14.6.big_sur.bottle.tar.gz
==> Caveats
This formula has created a default database cluster with:
  initdb --locale=C -E UTF-8 /usr/local/var/postgresql@14
For more details, read:
  https://www.postgresql.org/docs/14/app-initdb.html

To restart postgresql@14 after an upgrade:
  brew services restart postgresql@14
Or, if you don't want/need a background service you can just run:
  /usr/local/opt/postgresql@14/bin/postgres -D /usr/local/var/postgresql@14
==> Summary
🍺  /usr/local/Cellar/postgresql@14/14.6: 3,312 files, 45.6MB
==> Running `brew cleanup postgresql@14`...
Disable this behaviour by setting HOMEBREW_NO_INSTALL_CLEANUP.
Hide these hints with HOMEBREW_NO_ENV_HINTS (see `man brew`).
Removing: /usr/local/Cellar/postgresql@14/14.5_5... (3,309 files, 45.5MB)
Removing: /Users/stergios/Library/Caches/Homebrew/postgresql@14--14.5_5... (11.6MB)
Removing: /Users/stergios/Library/Caches/Homebrew/postgresql@14--14.5_2... (11.6MB)
Removing: /Users/stergios/Library/Caches/Homebrew/postgresql@14--14.5_3... (11.6MB)
Removing: /Users/stergios/Library/Caches/Homebrew/postgresql@14--14.5_4... (11.6MB)
Removing: /Users/stergios/Library/Caches/Homebrew/postgresql@14--14.5_1... (11.6MB)