Le traduzioni sono generate tramite traduzione automatica. In caso di conflitto tra il contenuto di una traduzione e la versione originale in Inglese, quest'ultima prevarrà.
Concetti e terminologia fondamentali in Amazon QLDB
Importante
Avviso di fine del supporto: i clienti esistenti potranno utilizzare Amazon QLDB fino alla fine del supporto il 31/07/2025. Per ulteriori dettagli, consulta Migrare un Amazon QLDB Ledger ad Amazon Aurora Postgre
Questa sezione fornisce una panoramica dei concetti e della terminologia principali di AmazonQLDB, inclusa la struttura del libro mastro e il modo in cui un registro gestisce i dati. Essendo un database di registro, QLDB si differenzia dagli altri database orientati ai documenti per quanto riguarda i seguenti concetti chiave.
Argomenti
QLDBmodello a oggetti di dati
Il modello fondamentale di oggetti di dati in Amazon QLDB è descritto come segue:
-
Ledger
Il primo passo è creare un libro mastro, che è il tipo di AWS risorsa principale in. QLDB Per informazioni su come creare un libro mastro, consulta Fase 1: Creare un nuovo libro contabile la sezione Guida introduttiva alla console oppure. Operazioni di base per Amazon QLDB Ledger
Sia per la
ALLOW_ALL
modalità che per la modalità diSTANDARD
autorizzazione di un libro mastro, si creano AWS Identity and Access Management (IAM) politiche che concedono le autorizzazioni per eseguire API operazioni su questa risorsa di registro.Formato del libro mastro: ARN
arn:aws:qldb:${region}:${account-id}:ledger/${ledger-name}
-
Diario e tabelle
Per iniziare a scrivere dati in un QLDB libro mastro, devi prima creare una tabella con un'CREATE TABLEistruzione di base. I dati contabili sono costituiti da revisioni di documenti che vengono inseriti nel giornale di registrazione del libro contabile. Le revisioni dei documenti vengono apportate al registro nel contesto di tabelle definite dall'utente. InQLDB, una tabella rappresenta una vista materializzata di una raccolta di revisioni di documenti dal giornale.
Nella modalità
STANDARD
autorizzazioni di un registro, è necessario creare IAM politiche che concedano le autorizzazioni per eseguire istruzioni PartiQL su questa risorsa della tabella. Con le autorizzazioni su una risorsa della tabella, è possibile eseguire istruzioni che accedono allo stato corrente della tabella. È inoltre possibile interrogare la cronologia delle revisioni della tabella utilizzando la funzione integratahistory()
.ARNFormato della tabella:
arn:aws:qldb:${region}:${account-id}:ledger/${ledger-name}/table/${table-id}
Per ulteriori informazioni sulla concessione delle autorizzazioni su un registro e sulle risorse associate, vedere. Come QLDB funziona Amazon con IAM
-
Documenti
Le tabelle sono costituite da revisioni diDocumenti di QLDB, che sono set di dati in formato Amazon Ion.
struct
Una revisione di un documento rappresenta una singola versione di una sequenza di documenti identificati da un ID di documento univoco.QLDBmemorizza la cronologia completa delle modifiche dei documenti confermati. Una tabella consente di interrogare lo stato corrente dei relativi documenti, mentre la
history()
funzione consente di interrogare l'intera cronologia delle revisioni dei documenti di una tabella. Per informazioni dettagliate sull'interrogazione e la scrittura delle revisioni, vedere. Lavorare con dati e cronologia -
Catalogo di sistema
Ogni libro mastro fornisce anche una risorsa di catalogo definita dal sistema su cui è possibile interrogare per elencare tutte le tabelle e gli indici in un libro mastro. Nella modalità
STANDARD
autorizzazioni di un libro mastro, è necessaria l'qldb:PartiQLSelect
autorizzazione su questa risorsa di catalogo per eseguire le seguenti operazioni:-
Esegui SELECT le istruzioni sulla tabella del catalogo di sistema information_schema.user_tables.
-
Visualizza l'elenco delle tabelle e degli indici nell'editor PartiQL sulla console. QLDB
Formato del catalogo: ARN
arn:aws:qldb:${region}:${account-id}:ledger/${ledger-name}/information_schema/user_tables
-
Transazioni basate su Journal-First
Quando un'applicazione legge o scrive dati in un QLDB registro, lo fa in una transazione di database. Tutte le transazioni sono soggette ai limiti definiti in. Quote e limiti in Amazon QLDB All'interno di una transazione, QLDB effettua le seguenti operazioni:
-
Legge lo stato corrente dei dati dal registro.
-
Esegui le istruzioni fornite nella transazione, quindi verifica la presenza di eventuali conflitti utilizzando optimistic concurrency control (OCC) per garantire un isolamento completamente serializzabile.
-
Se non vengono rilevati OCC conflitti, restituisci i risultati della transazione come segue:
-
Per le letture, restituisci il set di risultati e invia le
SELECT
dichiarazioni al diario in modo solo allegato. -
Per le scritture, inserisci tutti gli aggiornamenti, le eliminazioni o i nuovi dati inseriti nel diario in modo di sola aggiunta.
-
Il diario rappresenta una cronologia completa e immutabile di tutte le modifiche ai dati. QLDBscrive un blocco concatenato nel journal in una transazione. Ogni blocco contiene oggetti entry che rappresentano le revisioni del documento inserite, aggiornate ed eliminate, insieme alle istruzioni PartiQL che le hanno salvate.
Il diagramma seguente illustra questa struttura del diario.
Il diagramma mostra che le transazioni vengono salvate nel journal come blocchi contenenti le voci di revisione del documento. Ogni blocco viene sottoposto a hash e concatenato ai blocchi successivi per la verifica. Ogni blocco ha un numero di sequenza per specificare il suo indirizzo all'interno del filamento.
Nota
In AmazonQLDB, un filone è una partizione del diario del tuo libro mastro. QLDBattualmente supporta solo riviste con un solo filone.
Per informazioni sul contenuto dei dati in un blocco, vedere. Contenuti del diario in Amazon QLDB
Interrogazione dei dati
QLDBè destinato a soddisfare le esigenze dei carichi di lavoro di elaborazione delle transazioni online (OLTP) ad alte prestazioni. Un registro fornisce visualizzazioni tabellari interrogabili dei dati in base alle informazioni sulle transazioni salvate nel diario. Una visualizzazione tabellare in QLDB è un sottoinsieme dei dati di una tabella. Le visualizzazioni vengono gestite in tempo reale, in modo che siano sempre disponibili per le interrogazioni delle applicazioni.
È possibile interrogare le seguenti viste definite dal sistema utilizzando le istruzioni PartiQL: SELECT
-
Utente: l'ultima revisione attiva solo dei dati che hai scritto nella tabella (ovvero lo stato corrente dei dati utente). Questa è la visualizzazione predefinita inQLDB.
-
Impegnata: l'ultima revisione attiva sia dei dati utente che dei metadati generati dal sistema. Questa è la tabella completa definita dal sistema che corrisponde direttamente alla tabella utente.
Oltre a queste viste interrogabili, puoi interrogare la cronologia delle revisioni dei tuoi dati utilizzando la funzionalità integrata. Funzione di cronologia La funzione history restituisce sia i dati utente che i metadati associati nello stesso schema della visualizzazione confermata.
Archiviazione di dati
Esistono due tipi di archiviazione dei dati inQLDB:
-
Archiviazione del diario: lo spazio su disco utilizzato dal diario di un registro. Il diario è di sola appendice e contiene la cronologia completa, immutabile e verificabile di tutte le modifiche ai dati.
-
Archiviazione indicizzata: lo spazio su disco utilizzato dalle tabelle, dagli indici e dalla cronologia indicizzata di un registro. Lo storage indicizzato è costituito da dati di registro ottimizzati per query ad alte prestazioni.
Dopo che i dati sono stati inseriti nel diario, vengono materializzati nelle tabelle che hai definito. Queste tabelle sono ottimizzate per interrogazioni più veloci ed efficienti. Quando un'applicazione utilizza i dati transazionali API per leggere i dati, accede alle tabelle e agli indici archiviati nell'archivio indicizzato.
QLDBAPImodello
QLDBfornisce due tipi di strumenti con APIs cui il codice dell'applicazione può interagire:
-
Amazon QLDB: la gestione QLDB delle risorse API (nota anche come piano di controllo). APIViene utilizzato solo per la gestione delle risorse di registro e per le operazioni sui dati non transazionali. È possibile utilizzare queste operazioni per creare, eliminare, descrivere, elencare e aggiornare i registri. Puoi anche verificare i dati crittograficamente ed esportare o trasmettere blocchi di journal.
-
QLDBSessione Amazon: i dati QLDB transazionali. API È possibile utilizzarlo API per eseguire transazioni di dati su un registro con istruzioni PartiQL.
Importante
Invece di interagire direttamente con la QLDBsessioneAPI, consigliamo di utilizzare il QLDB driver o la QLDB shell per eseguire transazioni di dati su un registro.
-
Se lavori con un AWS SDK, usa il QLDB driver. Il driver fornisce un livello di astrazione di alto livello sopra i dati della QLDBsessione API e gestisce l'
SendCommand
operazione per te. Per informazioni e un elenco dei linguaggi di programmazione supportati, vedere. Guida introduttiva al driver -
Se stai lavorando con AWS CLI, usa la QLDB shell. La shell è un'interfaccia a riga di comando che utilizza il QLDB driver per interagire con un registro. Per informazioni, consulta Utilizzo della QLDB shell Amazon (APIsolo dati).
-
Per ulteriori informazioni su queste API operazioni, consultaQLDBAPIRiferimento Amazon.
Passaggi successivi
Per imparare a utilizzare un libro mastro con i dati, guarda Lavorare con dati e cronologia in Amazon QLDB e segui gli esempi che descrivono il processo di creazione di tabelle, inserimento di dati ed esecuzione di query di base. Questa guida spiega in modo approfondito come funzionano questi concetti, utilizzando dati di esempio ed esempi di query a titolo di contesto.
Per iniziare rapidamente con un esempio di tutorial applicativo utilizzando la QLDB console, consultaGuida introduttiva alla QLDB console Amazon.
Per un elenco dei termini e delle definizioni chiave descritti in questa sezione, vedere ilQLDBGlossario Amazon.