OQGRAPH
OQGRAPH, che sta per OpenQueryGRAPH, è uno storage engine per MySQL e i suoi fork, creato dalla società di consulenze OpenQuery, e in particolare dal suo fondatore Arjen Lentz. È distribuito (e installabile con un comando SQL) in MariaDB e compatibile con Drizzle.
OQGRAPH è uno storage engine solo da un punto di vista tecnico, o formale. In realtà il suo scopo è permettere all'utente di navigare i dati contenuti in una tabella (creata con altri storage engine, come InnoDB o MyISAM) come si navigano i nodi di un grafo orientato o di un albero. Questa famiglia di operazioni sono piuttosto difficili da ottenere in SQL.
La licenza è la GNU GPL versione 2.
Le tabelle OQGRAPH
modificaLe tabelle OQGRAPH devono avere tutte la stessa struttura:
CREATE TABLE db.tblname (
latch SMALLINT UNSIGNED NULL,
origid BIGINT UNSIGNED NULL,
destid BIGINT UNSIGNED NULL,
weight DOUBLE NULL,
seq BIGINT UNSIGNED NULL,
linkid BIGINT UNSIGNED NULL,
KEY (latch, origid, destid) USING HASH,
KEY (latch, destid, origid) USING HASH
) ENGINE=OQGRAPH;
Ogni record di questa tabella rappresenta un arco, un collegamento con direzione tra due nodi. Ad ogni colonna è associato un significato speciale:
- origid - Il nodo di origine.
- destid - Il nodo di destinazione.
- weight - Il peso del collegamento.
- latch - Utilizzato dalle SELECT per specificare quali informazioni si desiderano.
Le altre colonne sono utilizzate internamente.
Modifica dei dati
modificaLe colonne che possono essere modificate direttamente, tramite INSERT, UPDATE e REPLACE, sono origid, destid e weight. Se non si dà importanza al peso, è sufficiente valorizzare origid e destid.
Lettura dei dati
modificaLa colonna latch viene invece nominata nella clausola WHERE per far sapere allo storage engine che tipo di informazioni deve restituire. Segue l'elenco dei "comandi" che possono essere usati.
Latch = NULL
modificaLo stesso effetto si ottiene omettendo completamente latch. In questo modo si ottengono i limiti del grafo nelle colonne origid e destid.
Latch = 0
modificaIn linkid vengono restituiti gli id dei vertici.
Latch = 0 AND origid = N
modificaIn linkid vengono restituiti gli id dei vertici. In weight viene restituito il peso dei limiti.
Latch = 0 AND destid = N
modificaIn linkid vengono restituiti gli id dei vertici. In weight viene restituito il peso dei limiti.
Latch = 1
modificaRicerca con l'algoritmo del percorso più breve.
Latch = 2
modificaRicerca con l'algoritmo beadth-first.
Voci correlate
modificaCollegamenti esterni
modifica- (EN) Pagina ufficiale, su openquery.com.
- (EN) Documentazione ufficiale, su openquery.com. URL consultato il 20 ottobre 2012 (archiviato dall'url originale il 23 ottobre 2012).
- (EN) Repository del codice su Launchpad