Newer
Older
simple-database / src / nl / astraeus / database / ObjectPersister.java
package nl.astraeus.database;

import nl.astraeus.database.cache.Cache;

import java.util.List;

/**
 * Date: 11/13/13
 * Time: 9:36 PM
 */
public class ObjectPersister<T> {

    private Class<T> cls;
    private MetaData metaData;

    public ObjectPersister(Class<T> cls) {
        this.cls = cls;
        this.metaData = MetaDataHandler.get().getMetaData(cls);
    }

    public void insert(Object object) {
        metaData.insert(object);

        Long id = metaData.getId(object);
        Cache.get().set((Class<Object>) object.getClass(), id, object);
    }

    public void update(Object object) {
        metaData.update(object);

        Long id = metaData.getId(object);
        Cache.get().set((Class<Object>) object.getClass(), id, object);
    }

    public void delete(Object object) {
        Long id = metaData.getId(object);

        metaData.delete(id);
        Cache.get().set(object.getClass(), id, null);
    }

    public T find(long id) {
        T result = (T) metaData.find(id);

        Cache.get().set(cls, id, result);

        return result;
    }

    public List<T> selectAll() {
        return metaData.selectAll();
    }

    public List<T> selectFrom(String query, Object... params) {
        return metaData.selectFrom(query, params);
    }

    public List<T> selectWhere(String query, Object ... params) {
        return metaData.selectWhere(query, params);
    }

    public List<T> selectWhere(int from, int max, String query, Object ... params) {
        return metaData.selectWhere(from, max, query, params);
    }

    public int selectCount(String query, Object ... params) {
        return metaData.selectCount(query, params);
    }

    public T findWhere(String query, Object ... params) {
        return (T) metaData.findWhere(query, params);
    }

}