DBDB.io The Encyclopedia of Database Systems · Est. 2017
Database of Databases

Database Entry

TigerGraph


TigerGraph is a distributed, parallel graph DBMS with high availability designed for real-time analytical workloads.[04]

Developer
Country of Origin
US
Start Year
2012 [05]
Former Name
GraphSQL
Project Type
Commercial
Written in
C++
Operating System
Linux
License
Proprietary

Database Entry

TigerGraph


TigerGraph is a distributed, parallel graph DBMS with high availability designed for real-time analytical workloads.[04]

History[04]


The company was founded in 2012 by Yu Xu.

Checkpoints


TigerGraph uses fuzzy checkpoints. TigerGraph can be backed up while it continues to serve user traffic (called “online” backup).

Compression


TigerGraph compresses data in different ways, including dictionary based, snappy, variable byte compression etc. TigerGraph also supports attribute compression. Depending the operation, TigerGraph may not need data decompression before processing.

Concurrency Control


TigerGraph uses both MVCC and 2PC (Deadlock prevention).

Data Model


TigerGraph uses property graph, where where data is organized as nodes (vertices), relationships (edges), and properties (their attributes).

Foreign Keys


In graph model, vertex serves as the primary key as in RDBMS, while edge serves as the foreign key.

Indexes


Currently TigerGraph uses default vertex-centric indexes (O(1)) and adjacency lists.

Isolation Levels


All transactions execute with the serializable isolation level by default.

Joins


As a graph database, TigerGraph has materialized the relationships between data as edges so there is no joining required. Graph analytics focus mainly on how to traverse along the edges.

Logging


TigerGraph uses MVCC snapshots and WAL (Write-Ahead Logging).

Query Compilation


TigerGraph supports code generation and the query runs as native application.

Query Execution


TigerGraph’s MPP architecture supports multiple partitions and multiple processors, allowing IO-parallelism, intra-partitions parallelism and inter-partition parallelism.

Query Interface


TigerGraph has its own query language GSQL, a SQL-like graph query language. TigerGraph also supports RESTful API to query and update the graph.

Storage Architecture


In-memory DBMS. TigerGraph also supports larger-than-memory databases under certain circumstances (e.g., when partial or most topology data are on disk).

Storage Model


NSM and delta-store.

Storage Organization


TigerGraph uses customized log-structured files (WAL + LSM). Its storage system consists of authorization manager, transaction manager, memory manager and file manager.

Stored Procedures


TigerGraph's GSQL is a procedure-like language. It allows query with updates, and query calling query.

System Architecture


TigerGraph is a shared-nothing DBMS.

Views


No view support for now.

Citations

5 sources
  1. https://www.tigergraph.com tigergraph.com Dead — Check Archive
  2. TigerGraph Documentation :: Explore tigergraph.com
  3. TigerGraph - Wikipedia wikipedia.org
  4. https://www.tigergraph.com/company tigergraph.com
  5. https://www.zdnet.com/article/tigergraph-a-graph-database-born-to-roar zdnet.com
Revision #11 Last Updated: