Penyimpanan data NoSQL non-tabular

Pengantar NoSQL

Jake Roach

Data Engineer

Basis data dokumen

Definisi: Alat penyimpanan data NoSQL yang menyimpan data dalam format fleksibel, semi-terstruktur, terdiri dari pasangan key-value, key-array, dan key-object (mirip JSON).

$$

$$

Logo Postgres JSON.

{
    "title": "Python for Data Analysis",
    "price": 53.99,
    "topics": [
        "Data Science",
        "Data Analytics",
        ...
    ],
    "author": {
        "first": "William"
        ...
    }
}
Pengantar NoSQL

Mengkueri data JSON dengan Postgres JSON

Data JSON yang disorot disimpan dalam tabel Postgres.

SELECT
    books -> 'title' AS title,
    books -> 'price' AS price
FROM data_science_resources
WHERE 
    books -> 'author' ->> 'last' = 'Viafore';

Menghasilkan keluaran berikut:

Keluaran kueri Postgres JSON.

Pengantar NoSQL

Menyambungkan ke database Postgres

import sqlalchemy

# Create a connection string, and an engine
connection_string = "postgresql+psycopg2://<user>:<password>@<host>:<port>/<database>"
db_engine = sqlalchemy.create_engine(connection_string)

Untuk membuat koneksi ke database Postgres:

  • Bentuk connection string
  • Buat engine dengan sqlalchemy.create_engine
  • Variabel db_engine akan disiapkan sebelum latihan
Pengantar NoSQL

Menulis dan menjalankan kueri Postgres JSON

import pandas as pd

# Build the query
query = """
    SELECT
        books -> 'title' AS title,
        books -> 'price' AS price
    FROM data_science_resources;
"""

# Execute the query
result = pd.read_sql(query, db_engine)
print(result)

Untuk menulis dan menjalankan kueri:

  • Susun kueri dalam string
  • Berikan query dan db_engine ke fungsi pd.read_sql()
  • Cetak DataFrame hasilnya
Pengantar NoSQL

Jenis penyimpanan NoSQL non-tabular lainnya

Key-value
{
    "name": "Jane Doe",
    "age": 25,
    "email": "[email protected]"
}

$$

Logo Redis.

Graf

Gambar basis data graf.

Pengantar NoSQL

Ayo berlatih!

Pengantar NoSQL

Preparing Video For Download...