Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/croc-code/sql-boot
Advanced REST-wrapper for your SQL-queries (actually not only SQL)
https://github.com/croc-code/sql-boot
code-generator db db-generator db-ide db-manager db-migration db-swiss-knife db-tool dba ddl devops java nosql rdbms schema sql sql-generation
Last synced: 4 months ago
JSON representation
Advanced REST-wrapper for your SQL-queries (actually not only SQL)
- Host: GitHub
- URL: https://github.com/croc-code/sql-boot
- Owner: croc-code
- License: bsd-3-clause
- Created: 2016-11-21T15:05:08.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2022-06-20T22:41:03.000Z (over 2 years ago)
- Last Synced: 2024-05-21T18:12:13.681Z (9 months ago)
- Topics: code-generator, db, db-generator, db-ide, db-manager, db-migration, db-swiss-knife, db-tool, dba, ddl, devops, java, nosql, rdbms, schema, sql, sql-generation
- Language: Kotlin
- Homepage:
- Size: 2.99 MB
- Stars: 59
- Watchers: 4
- Forks: 4
- Open Issues: 19
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- jimsghstars - croc-code/sql-boot - Advanced REST-wrapper for your SQL-queries (actually not only SQL) (Kotlin)
README
[data:image/s3,"s3://crabby-images/ef4bd/ef4bd9d3d532e189bad9bab3560e96656fa65694" alt="Build Status"](https://travis-ci.org/crocinc/sql-boot)
[data:image/s3,"s3://crabby-images/b1674/b1674de7612322973345b8585c703b53eebc5e51" alt="Build status"](https://ci.appveyor.com/project/mgramin/sql-boot)
[data:image/s3,"s3://crabby-images/ce8f3/ce8f38b54b2ce0d205b86173ea2636fd30348831" alt="codecov"](https://codecov.io/gh/CrocInc/sql-boot)
[data:image/s3,"s3://crabby-images/4dc71/4dc71dea93f3f1f4d249ad310072c49afb46cbbe" alt="License"](https://github.com/sql-boot/sql-boot/blob/master/LICENSE)
[data:image/s3,"s3://crabby-images/a8f81/a8f81ae75999eef214c59e327eb2b20f0d272660" alt="codebeat badge"](https://codebeat.co/projects/github-com-mgramin-sql-boot-master)
[data:image/s3,"s3://crabby-images/d88cf/d88cfc9d3a4e0120e9a8a74226b4f165f4796a32" alt="Codacy Badge"](https://www.codacy.com/manual/mgramin/sql-boot?utm_source=github.com&utm_medium=referral&utm_content=CrocInc/sql-boot&utm_campaign=Badge_Grade)
[data:image/s3,"s3://crabby-images/0f056/0f056d19bd78dc0735ea1b81e07f5d76ffa2b254" alt="Docker Pulls"](https://hub.docker.com/r/mgramin/sql-boot/)
[data:image/s3,"s3://crabby-images/ee2f3/ee2f3503f9477231787a99a7dd3912ac73c8c925" alt="Main distribution"](https://github.com/sql-boot/sql-boot/releases/latest)
[data:image/s3,"s3://crabby-images/1f7c6/1f7c677a134547dd2442b19138d4b64ff3b51325" alt="Join the chat at https://gitter.im/sqlboot/Lobby"](https://gitter.im/sqlboot/Lobby?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
[data:image/s3,"s3://crabby-images/7a174/7a174e842d197230c2ca477ba94515a8f98c0f14" alt="EO badge"](https://www.elegantobjects.org/)
[data:image/s3,"s3://crabby-images/3f6b9/3f6b97f70a2d4cb8a7d412281526d581be0cb11c" alt="DevOps By Rultor.com"](http://www.rultor.com/p/CrocInc/sql-boot)
[data:image/s3,"s3://crabby-images/f85f9/f85f92f4596fc3e7311d978d039413a8321b8e54" alt="Hits-of-Code"](https://hitsofcode.com/view/github/CrocInc/sql-boot)
[data:image/s3,"s3://crabby-images/54107/5410764b1bbec11bb7304a9a6d44773068b2504d" alt="Scc Count Badge"](https://github.com/CrocInc/sql-boot/)
[data:image/s3,"s3://crabby-images/e82e2/e82e22b54fac8565ebfcc5fe2b5afdec7c835791" alt="Mentioned in Awesome database tools"](https://github.com/mgramin/awesome-db-tools)# Treat your database as Code
There are many awesome REST-wrappers for your Databases (e.g. [PostgREST](https://github.com/PostgREST/postgrest), [pREST](https://github.com/prest/prest), [sandman2](https://github.com/jeffknupp/sandman2) and many others), but how about REST-wrapper for your own SQL-queries?
The `sql-boot` tool is a REST-like wrapper for your own SQL-queries.
No ETLs, no generated SQL, no "automagic" - sql-boot simply transform your own SQL-query to Web resources.`sql-boot` recursively finds every *.sql files in your folders and start REST-like service and runs scripts against live databases in response to http requests.
Example
-------
Save you SQL-query to `big_cities.sql`:
````sql
select a.airport_code as code
, a.airport_name
, a.city
, a.coordinates
, a.timezone
from bookings.airports a
where a.city in (select aa.city
from bookings.airports aa
group by aa.city
having count(*) > 1)
order by
a.city
, a.airport_code
````Now `sql-boot` is ready to receive http requests (without restarting and other actions).
[Execute](http://81.23.10.106:8008/api/master_db/big_cities.sql) query on "master_db" database:
````bash
master_db/big_cities.sql
````[Execute](http://81.23.10.106:8008/api/.*/big_cities.sql) query against all registered databases:
````bash
.*/big_cities.sql
````[Execute](http://81.23.10.106:8008/api/.*/big_cities.sql?select=code,endpoint) query against all registered databases with specified columns:
````bash
.*/big_cities.sql?select=code,endpoint
````[Execute](http://81.23.10.106:8008/api/master_db/big_cities.sql?select=code&orderby=code-desc) query with ordering:
````bash
master_db/big_cities.sql?select=code&orderby=code-desc
````[Execute](http://81.23.10.106:8008/api/master_db/big_cities.sql?select=code&orderby=code-desc&page=1,3) query with pagination:
````bash
master_db/big_cities.sql?select=code&orderby=code-desc&page=1,3
````Self-documentation
------------------
sql-boot uses the [OpenAPI](https://github.com/OAI/OpenAPI-Specification) standard to generate up-to-date documentation for APIs based your SQL-queries metadata.
You can use a tool like [Swagger-UI](https://github.com/swagger-api/swagger-ui) or [Swagger-Editor](https://github.com/swagger-api/swagger-editor) to render interactive documentation (for demo requests) or [generate client API](https://github.com/swagger-api/swagger-codegen) against the live API server.How to pronounce
----------------
It is pronounced "sequelboot" - https://translate.google.com/?source=osdd#en/en/sequelbootTry with Docker and embedded (H2) demo db:
------------------------------------------
```
docker run -t -p 8007:8007 mgramin/sql-boot
```Build from source:
------------------
```
git clone https://github.com/mgramin/sql-boot
cd sql-boot
mvn package
```