All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.wizarius.orm.database.DatabaseStorage Maven / Gradle / Ivy

There is a newer version: 0.0.27.6
Show newest version
package com.wizarius.orm.database;

import com.wizarius.orm.database.connection.DBConnectionPool;
import com.wizarius.orm.database.entityreader.EntityQuery;

import java.lang.reflect.ParameterizedType;
import java.util.List;

/**
 * @author Vladyslav Shyshkin on 29.04.17.
 */
public class DatabaseStorage {
    protected final DBConnectionPool pool;
    private final Class clazz;
    private final EntityQuery session;

    public DatabaseStorage(DBConnectionPool pool, Class clazz) throws DBException {
        this.pool = pool;
        this.clazz = clazz;
        this.session = pool.getEntityManager().getEntityQuery(clazz);
    }

    @SuppressWarnings("unchecked")
    public DatabaseStorage(DBConnectionPool pool) throws DBException {
        this.pool = pool;
        this.clazz = (Class) ((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[0];
        this.session = pool.getEntityManager().getEntityQuery(clazz);
    }

    /**
     * Save entity
     *
     * @param entity DBEntity
     * @throws DBException on unable to save to database
     */
    public void save(T entity) throws DBException {
        session.getInsertQuery().execute(entity);
    }

    /**
     * Save entities list
     *
     * @param entities entities
     * @throws DBException on unable to save entity
     */
    public void save(List entities) throws DBException {
        session.getInsertQuery().execute(entities);
    }

    /**
     * Get table name
     *
     * @return table name
     */
    public String getTableName() {
        return session.getFields().getTableName();
    }

    /**
     * Update entity
     *
     * @param entity DBEntity
     * @throws DBException on unable to update entity in database
     */
    public void update(T entity, int id) throws DBException {
        session.getUpdateQuery().where("id", id).execute(entity);
    }

    /**
     * Update entity
     *
     * @param entity DBEntity
     * @throws DBException on unable to update entity in database
     */
    public void update(T entity, long id) throws DBException {
        session.getUpdateQuery().where("id", id).execute(entity);
    }

    /**
     * Get entity by id
     *
     * @param id entity id
     * @throws DBException on unable to get by id
     */
    public T getByID(Object id) throws DBException {
        return session.getSelectQuery().where("id", id, clazz).getOne();
    }

    /**
     * Delete entity
     *
     * @param entity entity to delete
     * @throws DBException on unable to delete
     */
    public void delete(T entity) throws DBException {
        session.getDeleteQuery().execute(entity);
    }

    /**
     * Delete entity by id
     *
     * @param id entity id
     * @throws DBException on unable to delete by id
     */
    public void deleteByID(long id) throws DBException {
        session.getDeleteQuery().where("id", id).execute();
    }

    /**
     * Delete entity by id
     *
     * @param id entity id
     * @throws DBException on unable to delete byy id
     */
    public void deleteByID(int id) throws DBException {
        session.getDeleteQuery().where("id", id).execute();
    }

    /**
     * Get all records in database
     *
     * @return array list of entities
     * @throws DBException on unable to get all
     */
    public List getAll() throws DBException {
        return session.getSelectQuery().execute();
    }

    /**
     * Delete all records from table
     *
     * @throws DBException on unable to clear
     */
    public void clear() throws DBException {
        session.getDeleteQuery().execute();
    }

    /**
     * Get count elements in table
     *
     * @return count elements in table
     * @throws DBException database exception
     */
    public long count() throws DBException {
        return session.getSelectQuery().getCount();
    }

    /**
     * Returns entity session
     *
     * @return entity session
     */
    public EntityQuery getSession() {
        return session;
    }

    /**
     * Returns connection pool
     *
     * @return database connection pool
     */
    public DBConnectionPool getPool() {
        return pool;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy