Memahami data JSON di Postgres

Pengantar NoSQL

Jake Roach

Data Engineer

JSON dan JSONB di Postgres

{
    'guardian': 'mother',
    'status': 'A',
    'educations': [4, 4],
    'jobs': {
        'P1': 'teacher',
        'P2': 'at_home'
    }
}
CREATE TABLE students
    <column-name> JSON,
    <column-bame> JSONB
;

JSON

  • Menyimpan data dalam format JSON
  • Pasangan key–value, array, objek bertingkat

$$

JSONB

  • Data disimpan dalam format biner
  • Mirip BSON di MongoDB
  • Penyimpanan dan pengambilan lebih efisien
  • Mendukung pengindeksan tambahan
Pengantar NoSQL

Mengapa data semi-terstruktur di Postgres?

Tabel Postgres dengan kolom bertipe JSON.

Pengantar NoSQL

Query data JSON dengan Postgres

SELECT
    address,
    famsize,
    ...
FROM students
[WHERE | GROUP BY | ORDER BY];

$$

  • row_to_json, json_to_record
  • Operator ->, ->>, #>, #>>
  • json_extract_path, json_extract_path_text

Kita juga akan bisa:

  • Menyisipkan record berformat JSON ke tabel Postgres
  • Tabel ke JSON, JSON ke tabel
  • Mengekstrak record individual dari objek JSON
Pengantar NoSQL

Menjalankan query dengan sqlalchemy dan pandas

import sqlalchemy
import pandas as pd
# Create a connection
db_engine = sqlalchemy.create_engine(
    "postgresql+psycopg2://<user>:<password>@<host>:5432/<database>"
)
# Write a query
query = "SELECT * FROM table_name;"
# Execute the query, show results
results = pd.read_sql(query, db_engine)
Pengantar NoSQL

Ayo berlatih!

Pengantar NoSQL

Preparing Video For Download...