Skip to content

Latest commit

 

History

History
268 lines (205 loc) · 8.97 KB

README.md

File metadata and controls

268 lines (205 loc) · 8.97 KB

DataB

Simple and easy-to-use JDBC-based ORM for Java and Kotlin.

DataB is a library for Java and Kotlin programming languages that can help you to store application data in a database. You can save almost all types of data into a database using internal DataB functionality.

The latest version is 0.0.4-SNAPSHOT

Status: in development. Unstable, untested, and has a meager functionality.

Table of Contents

  1. Installation
  2. Getting started
  3. License

Installation

DataB is provided as a set of Maven repositories containing a lot of modules to construct a unique environment for every user. A list of modules and their descriptions are shown below.

Modules

Module name Description
datab Core module. It contains all main components, abstract classes, and interfaces to work with JDBC and databases.
datab-converters Additional module that contains different implementations of the DataB Converter interface. Currently, this module has only one implementation that can convert different objects to JSON.
datab-providers Additional important module that contains the implementation of DataB Provider and other components.
datab-examples Module that provides examples of using a DataB library.

As was mentioned before, the DataB is a set of Maven repositories. So, you can install each of them using both Maven and Gradle.

Build and install from sources

  1. Download sources and extract them.
  2. Go to the parent source directory.
  3. Open a terminal/console here and execute the following command:
mvn clean install

This command will compile and install DataB modules into your local Maven repository, and you will be able to use them in your projects.

Maven

To use DataB in your Maven projects, you should add appropriate DataB modules as dependencies. This example depends on such modules as datab main module, provider-sqlite and converter-gson.

    <dependencies>
        ...

        <dependency>
            <groupId>com.masich.datab</groupId>
            <artifactId>datab</artifactId>
            <version>0.0.4-SNAPSHOT</version>
        </dependency>
        <dependency>
            <groupId>com.masich.datab</groupId>
            <artifactId>provider-sqlite</artifactId>
            <version>0.0.4-SNAPSHOT</version>
        </dependency>
        <dependency>
            <groupId>com.masich.datab</groupId>
            <artifactId>converter-gson</artifactId>
            <version>0.0.4-SNAPSHOT</version>
        </dependency>
    </dependencies>

Gradle

To use DataB in your Gradle project, you also must indicate that you are using Maven local repository.

repositories {
    ...
    
    mavenLocal()
}

dependencies {
    ...
    
    implementation("com.masich.datab:datab:0.0.4-SNAPSHOT")
    implementation("com.masich.datab:provider-sqlite:0.0.4-SNAPSHOT")
    implementation("com.masich.datab:converter-gson:0.0.4-SNAPSHOT")
}

Getting started

Initialization

Before using databases and any DataB core functionality, it is necessary to initialize it. An example of a method that initializes the DataB is provided below.

private static void initDB() throws SQLException {
    DBManager manager = new DBManager.Builder()
            //Provider for your type of database
            .addProviderFactory(new SQLiteProviderFactory())
            //Path to your database. You also can use a full path like "jdbc:sqlite:sample.db"
            .addDatabaseSrc("sample.db")
            //Converter for saving custom classes (which are not DataB Entities) into a database
            .addConverterFactory(new GsonConverterFactory())
            .build();

    DBManager.setSingleton(manager);
}

Data models for DataB

In DataB, we define all database tables as specific Java classes. To define a class as a DataB table (called entity), you need to inherit this custom class from a superclass Entity and annotate it using @Table annotation. You also need to specify the table name as an annotation value. For example, let's define the Java class Person associated with the database table "Person" as a DataB Entity.

@Table("Person")
public class Person extends Entity {

}

It's also required to provide an empty constructor. This thing is necessary to create instances of the saved objects and restore their states.

public Person() {}

After that, we can add additional fields to the Person class. Let's define such fields as a person's name and phone number. Every person has a unique phone number, and it's a good idea to describe it as a primary key for our table.

//Name of the column in a database that will be related to this field
@Field("name")
private String name;

//Unique primary key of the table. It can be almost anything 
//In this example, we are using a phone number
@PrimaryKey("phone_number")
private String phoneNumber;

So, now we have defined a simple Person class with a set of payload. So, let's use DataB functionality to communicate with a database and the Person table!

Using DataB features

After determining our custom DataB Entity, we can start using DataB core functionality. The first thing that we need to do before we start is to invoke our initDB() method.

initDB();

This method will set up and initialize core DataB instances and database tables. The SQLite database file sample.db will also be created after invoking this method. Finally, it is time to make Person instances and play with our database.

String maxTel = "160-332", bobTel = "161-200";
Person max = new Person("Max", maxTel);
Person bob = new Person("Bob", bobTel);

We have Max and Bob as our Person class instances. And we can easily save them into our database using save() method:

max.save();
bob.save();

And now, our database looks as follows:

name phone_number (PK)
1 Max 160-332
2 Bob 161-200

We can get a particular person in our database by using Person.getById() method. This method will return a person from the database with the appropriate id (Primary Key) or null if the person with such id isn't in the database table.

System.out.println(Person.getById(maxTel, Person.class));

This will print Person{name='Max', phoneNumber='160-332'} in the console. We also can use Person.getAll() method to get all rows in the Person database table. The result of this method is a List with all of the table rows.

System.out.println(Person.getAll(Person.class));

And this operation will print such information as:

[Person{name='Max', phoneNumber='160-332'}, Person{name='Bob', phoneNumber='161-200'}]

Of course, removing row or rows from the database is possible. To do it you can use either delete() for one row or Person.deleteAll(Person.class) for all rows in the database table:

bob.delete()
System.out.println(Person.getById(maxTel, Person.class));
System.out.println(Person.getAll(Person.class));

Person.deleteAll(Person.class);
System.out.println(Person.getAll(Person.class));

And the result will be as follows:

null
[Person{name='Bob', phoneNumber='161-200'}]
[]

You can also create Iterable instance and save it in a database table using Person.saveAll():

List<Person> people = new ArrayList<>();
people.add(max);
people.add(bob);
people.add(new Person("Lara", "163-213"));
people.add(new Person("Julia", "162-112"));

Person.saveAll(people);

And now our Person database table looks like this:

name phone_number (PK)
1 Max 160-332
2 Bob 161-200
3 Lara 163-213
4 Julia 162-112

And, of course, we can get all these rows:

System.out.println(Person.getAll(Person.class));

With a result such as this:

[Person{name='Max', phoneNumber='160-332'}, Person{name='Bob', phoneNumber='161-200'}, Person{name='Lara', phoneNumber='163-213'}, Person{name='Julia', phoneNumber='162-112'}]

The complete source code of this example is presented here.

License

This project is licensed under the MIT License - see the LICENSE file for details.