Skip to content

typhon-project/typhonql

 
 

Repository files navigation

Run in eclipse

  • Import the typhonql as maven projects in eclipse. Let eclipse install the right maven connector plugins.

Building with maven (for example update sites)

(cd typhonql-bundler && mvn clean install)
mvn clean package

Technically the bundler only has to be run on every version bump of the bundler. (which is needed for new maven dependencies)

Documentation

The language is documented here: TyphonQL: an Evolving User Manual.

Feature support

In the tables below we will try to give an overview of feature support of the current master branch.

Icon Meaning
πŸŒ‘ not implemented
πŸŒ’ initial implementation, expect bugs
πŸŒ“ partially implemented (for example not on all backends)
πŸŒ” fully implemented, might be some bugs left
πŸŒ• finished

Types

Basic primitive types.

Feature Syntax Backend Remarks
int πŸŒ• πŸŒ•
bigint πŸŒ• πŸŒ•
string[maxSize] πŸŒ• πŸŒ•
text πŸŒ• πŸŒ•
point πŸŒ• πŸŒ“ not supported on neo4j yet
polygon πŸŒ• πŸŒ“ not supported on neo4j yet
bool πŸŒ• πŸŒ•
float πŸŒ• πŸŒ•
blob πŸŒ• πŸŒ• Only supported on mongo & mariadb backends
freetext[Id+] πŸŒ” πŸŒ‘ Syntax is almost finished, still requiring some work with ML & NLP teams
date πŸŒ• πŸŒ•
datetime πŸŒ• πŸŒ•
Custom data types πŸŒ• πŸŒ•

Relations

TyphonML supports relationships between entities. This section briefly summarizes TyphonQL's support for them. Note that, currently, this only involves MongoDB and SQL, since key-value stores are only used to store (primitive) properties. However, if an owning entity is removed, the corresponding entry in the key-value store is removed as well.

TODO: describe how GraphDBs fit the picture.

The cardinalities here represent the way they are specified in TyphonML; so "one-zero/many" between entities A and B means "A is related to one B, and B is related to zero or many As" (so it does not mean "One A is related to zero or more Bs").

NB for both containment and cross references, mandatory relations (e.g. one-one, one-one/many etc.) are not enforced.

Containment

Containment induces cascade delete, even across database boundaries, but only a single hop. Recursive containment (e.g., comments that are a reply to a comment), thus, works within a single back-end only.

The unsupported relations in the following table follow from consistency constraints on TyphonML models: containment is unidirectional, and tree-shaped (i.e. "childeren can only have a single parent").

Cardinality Support
one-one mongo/mongo, mongo/sql, sql/mongo
one-zero/one mongo/mongo, mongo/sql, sql/mongo
one-zero/many --
one-one/many --
one/zero-one mongo/mongo, mongo/sql, sql/mongo
one/zero-zero/one mongo/mongo, mongo/sql, sql/mongo
one/zero-zero/many --
one/zero-one/many --
zero/many-one mongo/mongo, mongo/sql, sql/mongo
zero/many-zero/one mongo/mongo, mongo/sql, sql/mongo
zero/many-zero/many --
zero/many-one/many --
one/many-one mongo/mongo, mongo/sql, sql/mongo
one/many-zero/one mongo/mongo, mongo/sql, sql/mongo
one/many-zero/many --
one/many-one/many --

Cross references

For cross references all combinations, with the above caveat about mandatory relations, are supported.

Expressions

Feature Syntax Backend Remarks
"nested" field access (a.b.c) πŸŒ• πŸŒ”
placeholders (??<name>) πŸŒ• πŸŒ”
lists ([..]) πŸŒ• πŸŒ” only usable for relations
positive + & negative - πŸŒ• πŸŒ” if backends supports it
math operations (*+/-) πŸŒ• πŸŒ” if backends support it
comparisons (== and friends) πŸŒ• πŸŒ” if backends support it
boolean operations (&& and ||) πŸŒ• πŸŒ”
containment x in y πŸŒ• πŸŒ“ currently doesn't work from the inverse side
text compare x like y πŸŒ• ? TODO: check support

Backends

Backend Support Remarks
MariaDB πŸŒ•
MariaDB clusters πŸŒ• DL makes this transparant
MongoDB πŸŒ•
Cassandra πŸŒ•
Neo4J πŸŒ“ geo features need to be added

Generic features

Feature Support Remarks
Query across different backends πŸŒ”
Query validation πŸŒ” Syntax is validated and checked against the ML model
Query type checking in IDE πŸŒ•
Query optimization πŸŒ’ We try to get where clauses on the correct backend
Unicode Support πŸŒ” It should be possible to use unicode anywhere. Collation is currently fixed to utf8 (we have to think about extending this in ML if needed)
DAL/Generated API πŸŒ”
Navigation based queries (path, reachability, transitive closure) πŸŒ‘
Transactions πŸŒ‘ unclear if we can add decent support for this
Parametrized/Bulk queries πŸŒ“ Currently doesn't provide a lot of performance benefit, but can in the future
DDL Operations πŸŒ“
Operations on freetext attributes πŸŒ‘ Working with NLP team to get this integrated