Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/coasterfreakde/ork
Object Relational Mapping for Kotlin
https://github.com/coasterfreakde/ork
data database kotlin mariadb mysql orm sql sqlite
Last synced: 3 months ago
JSON representation
Object Relational Mapping for Kotlin
- Host: GitHub
- URL: https://github.com/coasterfreakde/ork
- Owner: CoasterFreakDE
- License: mit
- Created: 2021-06-02T10:33:49.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2023-03-24T11:05:14.000Z (almost 2 years ago)
- Last Synced: 2024-05-01T18:07:06.657Z (9 months ago)
- Topics: data, database, kotlin, mariadb, mysql, orm, sql, sqlite
- Language: HTML
- Homepage: https://devsky.one
- Size: 574 KB
- Stars: 2
- Watchers: 0
- Forks: 2
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# ORK: Object Relational Mapping for Kotlin
[![Jitpack](https://jitpack.io/v/CoasterFreakDE/ORK.svg)](https://jitpack.io/#CoasterFreakDE/ORK) ![Repo Size](https://img.shields.io/github/repo-size/CoasterFreakDE/ORK) ![Contributors](https://img.shields.io/github/contributors/CoasterFreakDE/ORK) [![Discord](https://img.shields.io/discord/849650088518090813?label=Discord)](https://discord.gg/PEqVSTwy2K) [![CodeFactor](https://www.codefactor.io/repository/github/coasterfreakde/ork/badge)](https://www.codefactor.io/repository/github/coasterfreakde/ork)
ORK is a small project aiming to utilizing Kotlin dataclasses to use as ORM System
## Import in your Gradle/Maven Project
### 🐘 - Gradle:
#### Add Jitpack as Maven repo
```
repositories {
maven { url 'https://jitpack.io' }
}
```#### Add it to your dependencies
```
dependencies {
compile 'com.github.CoasterFreakDE:ork:0.7-SNAPSHOT'
}
```### Maven:
#### Add Jitpack as Maven repo
```
jitpack.io
https://jitpack.io
```
#### Add it to your dependencies
```com.github.CoasterFreakDE
ork
0.7-SNAPSHOT```
### Features/Todos:
- [X] Connect to jdbc url
- [X] Create Tables from DataClass
- [X] Save (INSERT OR UPDATE) DataClasses directly to your database with `.save()`
- [X] Delete Data with `.delete()`
- [ ] Select Data from database
- [ ] References (Foreign Keys)
- [ ] Move the PrimaryKey Annotation directly to the field---
### Connecting to your database
Connecting to your database is easy. Just add your credentials in a "connect" block at the start of your app.
To use sqlite just use `driver { "sqlite" }` and `host { "your.db" }`
```kotlin
connect {
host { "localhost" }
port { 3306 }
driver { "mariadb" } // Supported: mysql, mariadb, sqlite
database { "database" }
username { "root" }
password { "1234" }
autoReconnect { true }
}
```---
### Creating TablesTo create a table there are two steps you need to follow.
#### Create a data class
A Tableclass consists of 3 different parts.
- Implementing the interface `ITable`
- At least **one** PrimaryKey
- FieldNames```kotlin
@PrimaryKey("name", "gamegroup")
data class MyTable(@FieldName("name")
val name: String = "Peter",@FieldName("gamegroup")
val gamegroup: String = "Orks",@FieldName("xp")
val xp: Int = 0,) : ITable
```#### Create the Table
This is as simple as putting butter on bread.
You can add all your tables into a single statement by separating them with a `,````kotlin
createTable(MyTable::class.java)
```### Saving/Updating/Deleting data
Now comes the fun part. Since you'll be using these features most of the time, they need to be super simple.
```kotlin
val myDataToSave = MyTable("Hulk")
myDataToSave.save() // Insert or update data to the database
myDataToSave.delete() // Delete data from the database
```### Selecting / Searching for data
![Todo](https://i.imgur.com/OvMZBs9.jpg)
### Contributing
Feel free to leave a pull request or ticket for feature requests.
### Code Coverage
Try to cover as much as possible with tests.
Check [here](https://CoasterFreakDE.github.io/ORK/code-coverage/)