Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

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

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 Tables

To 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/)