Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gammaql/greldal
A micro-framework for bidirectional mapping between relational datastores and GraphQL APIs (powered by Node.js)
https://github.com/gammaql/greldal
api-server graphql knexjs nodejs typescript
Last synced: about 2 months ago
JSON representation
A micro-framework for bidirectional mapping between relational datastores and GraphQL APIs (powered by Node.js)
- Host: GitHub
- URL: https://github.com/gammaql/greldal
- Owner: gammaql
- License: mit
- Created: 2018-12-24T02:13:55.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2023-01-11T02:35:51.000Z (almost 2 years ago)
- Last Synced: 2024-10-10T19:30:51.273Z (3 months ago)
- Topics: api-server, graphql, knexjs, nodejs, typescript
- Language: TypeScript
- Homepage: https://gammaql.github.io/greldal/
- Size: 27.8 MB
- Stars: 58
- Watchers: 3
- Forks: 3
- Open Issues: 46
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
A simple micro-framework to expose your relational datastore as a GraphQL API (powered by Node.js).
Documentation | Issues | API Docs---
[GraphQL](https://graphql.org/) is a powerful solution for making your server side data available to clients through a flexible and bandwidth efficient API.
However, if your primary data source is a **relational database** then mapping GraphQL queries to efficient database queries can be arduous. With naive hierarchical resolution of resolvers it is very easy to end up with inefficient data access patterns and [N+1 queries](https://stackoverflow.com/questions/97197/what-is-the-n1-select-query-issue). Caching strategies, dataloader etc. partly mitigate the problem but the fact remains that you are not taking the full advantage of the capabilities of your powerful datastore.
GRelDAL is a **low level** library that gives you a declaritive API to map your relational data sources to GraphQL APIs. It is data store agnostic thanks to [Knex](https://knexjs.org), the underlying data access library that supports all common databases. Currently MySQL, PostgreSQL and SQLite are well tested.
When you generate your GraphQL API through GRelDAL, you can choose exactly how:
- Your database table schema maps to GraphQL types.
- Your GraphQL queries are mapped to SQL queries, including:
- which tables can be joined under which circumstances
- when batched queries can be performed
- when related rows can be fetched in advance in bulk, etc.
Plus, unlike many other similar solutions, GRelDAL has first class support for **subscriptions**, **stored procedures**, **user defined functions**, **JSON/XML/binary data** and **custom column types**.
---
[![Build Status](https://travis-ci.org/gammaql/greldal.svg?branch=master)](https://travis-ci.org/gammaql/greldal)
[![FOSSA Status](https://app.fossa.io/api/projects/git%2Bgithub.com%2Fgammaql%2Fgreldal.svg?type=shield)](https://app.fossa.io/projects/git%2Bgithub.com%2Fgammaql%2Fgreldal?ref=badge_shield)## License
[![FOSSA Status](https://app.fossa.io/api/projects/git%2Bgithub.com%2Fgammaql%2Fgreldal.svg?type=large)](https://app.fossa.io/projects/git%2Bgithub.com%2Fgammaql%2Fgreldal?ref=badge_large)