Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/adrenallen/replit-db-orm
A mongoose inspired ORM for Repl.it's built-in database
https://github.com/adrenallen/replit-db-orm
database nodejs orm replit
Last synced: 3 days ago
JSON representation
A mongoose inspired ORM for Repl.it's built-in database
- Host: GitHub
- URL: https://github.com/adrenallen/replit-db-orm
- Owner: adrenallen
- Created: 2021-02-09T04:26:16.000Z (almost 4 years ago)
- Default Branch: master
- Last Pushed: 2022-03-30T03:38:08.000Z (almost 3 years ago)
- Last Synced: 2024-12-16T19:11:45.596Z (about 1 month ago)
- Topics: database, nodejs, orm, replit
- Language: JavaScript
- Homepage:
- Size: 3.91 KB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Repl DB ORM
A quick experiment to build an ORM on top of [Repl.it](https://repl.it)'s existing key/value based database.
[More information about Repl's database can be found here](https://docs.repl.it/misc/database)
## Usage
```
const {model, Schema} = require('repl-db-orm');// Define a schema, what fields we want and their types
var testSchema = {
Property1: Number,
Words: String
};// Create the model, specify the name and can specify the "table"
// as a third param which is just how we store the keys
const testModel = model("test", testSchema);(async () => {
// Create a new object by our model
let a = new testModel({Property1: 55, Words: "Test test"});// save it to the db
await a.save()// Find matches!
testModel.find({Property1: 55}).then(console.log);
})();```
## How it works
Each model property is saved as a key/value based on the schema definition.Since we know the first part of the keys, we can query by rough matches to find models of a certain type with matching property values.
Then we can pull the model id out of the key itself with some simple regex.
## Contributing
Feel free to open PRs to improve this, it's still missing quite a few key features for usage such as delete, findOne, or a way to add other where clauses like OR.