com.wizarius.orm.database.entityreader.WizEntityManager Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of wizarius-orm Show documentation
Show all versions of wizarius-orm Show documentation
Java orm for Postgres or Mysql with migration system and connection pool
package com.wizarius.orm.database.entityreader;
import com.wizarius.orm.database.DBException;
import com.wizarius.orm.database.actions.WizDBDelete;
import com.wizarius.orm.database.actions.WizDBInsert;
import com.wizarius.orm.database.actions.WizDBSelect;
import com.wizarius.orm.database.actions.WizDBUpdate;
import com.wizarius.orm.database.annotations.DBField;
import com.wizarius.orm.database.annotations.DBJoinModel;
import com.wizarius.orm.database.annotations.DBModel;
import com.wizarius.orm.database.annotations.DBPredefinedField;
import com.wizarius.orm.database.connection.DBConnectionPool;
import com.wizarius.orm.database.data.UniqueTableDictionary;
import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
/**
* Created by Vladyslav Shyshkin on 12.11.17.
*/
public class WizEntityManager {
/**
* Connections pool
*/
private final DBConnectionPool pool;
/**
* Database connection pool
*
* @param pool database connection pool
*/
public WizEntityManager(DBConnectionPool pool) {
this.pool = pool;
}
/**
* Get connection type by java type
*
* @param field java field refraction
* @return connection type
*/
private static DBSupportedTypes javaTypeToDBType(Field field) {
return javaTypeToDBType(field.getType());
}
/**
* Get connection type by java class
*
* @param clazz class instance
* @return connection type
*/
public static DBSupportedTypes javaTypeToDBType(Class> clazz) {
if (clazz.isEnum()) {
return DBSupportedTypes.ENUM;
}
switch (clazz.getSimpleName()) {
case "Integer":
case "int": {
return DBSupportedTypes.INTEGER;
}
case "int[]": {
return DBSupportedTypes.INTEGER_ARRAY;
}
case "Short":
case "short": {
return DBSupportedTypes.SHORT;
}
case "short[]": {
return DBSupportedTypes.SHORT_ARRAY;
}
case "String": {
return DBSupportedTypes.STRING;
}
case "String[]": {
return DBSupportedTypes.STRING_ARRAY;
}
case "Byte":
case "byte": {
return DBSupportedTypes.BYTE;
}
case "byte[]": {
return DBSupportedTypes.BYTE_ARRAY;
}
case "Float":
case "float": {
return DBSupportedTypes.FLOAT;
}
case "float[]": {
return DBSupportedTypes.FLOAT_ARRAY;
}
case "Long":
case "long": {
return DBSupportedTypes.LONG;
}
case "long[]": {
return DBSupportedTypes.LONG_ARRAY;
}
case "Character":
case "char": {
return DBSupportedTypes.CHAR;
}
case "char[]": {
return DBSupportedTypes.CHAR_ARRAY;
}
case "Double":
case "double": {
return DBSupportedTypes.DOUBLE;
}
case "double[]": {
return DBSupportedTypes.DOUBLE_ARRAY;
}
case "boolean[]": {
return DBSupportedTypes.BOOLEAN_ARRAY;
}
case "Boolean":
case "boolean": {
return DBSupportedTypes.BOOLEAN;
}
case "BigDecimal": {
return DBSupportedTypes.BIGDECIMAL;
}
case "BigDecimal[]": {
return DBSupportedTypes.BIGDECIMAL_ARRAY;
}
case "Date": {
return DBSupportedTypes.DATE;
}
case "Date[]": {
return DBSupportedTypes.DATE_ARRAY;
}
case "Timestamp": {
return DBSupportedTypes.TIMESTAMP;
}
case "Timestamp[]": {
return DBSupportedTypes.TIMESTAMP_ARRAY;
}
}
if (clazz.isArray() && clazz.getComponentType().isEnum()) {
return DBSupportedTypes.ENUM_ARRAY;
}
return DBSupportedTypes.UNKNOWN;
}
/**
* Parse entity
*
* @param clazz entity clazz
* @return parsed fields list
* @throws DBException on parse entity exception
*/
public DBParsedFieldsList parseEntity(Class> clazz) throws DBException {
return parseEntity(clazz, new UniqueTableDictionary());
}
/**
* Parse entity
*
* @param clazz clazz name
* @param uniqueTableDictionary unique table dictionary
* @return parsed entities
* @throws DBException on unable to parse
*/
public DBParsedFieldsList parseEntity(Class> clazz, UniqueTableDictionary uniqueTableDictionary) throws DBException {
Object dbEntity;
try {
dbEntity = clazz.newInstance();
} catch (InstantiationException | IllegalAccessException e) {
throw new DBException("Unable to create new instance", e);
}
if (!dbEntity.getClass().isAnnotationPresent(DBModel.class)) {
throw new DBException("DBModel annotation not found");
}
DBModel modelAnnotation = dbEntity.getClass().getAnnotation(DBModel.class);
String tableName = modelAnnotation.tableName();
boolean readSuperClass = modelAnnotation.readSuperClass();
DBParsedFieldsList fieldsList = new DBParsedFieldsList(
tableName,
clazz,
uniqueTableDictionary.getNext()
);
List fields = findFields(dbEntity, readSuperClass);
for (Field field : fields) {
if (field.isAnnotationPresent(DBField.class)) {
String fieldName = field.getName();
DBField dbFieldAnnotation = field.getAnnotation(DBField.class);
String dbFieldName = dbFieldAnnotation.fieldName();
boolean isAutoIncrement = dbFieldAnnotation.isAutoIncrement();
fieldsList.add(new DBParsedField(
tableName,
fieldName,
dbFieldName,
field.getType(),
field,
javaTypeToDBType(field),
isAutoIncrement)
);
}
//if custom serialized-deserializer
if (field.isAnnotationPresent(DBPredefinedField.class)) {
String fieldName = field.getName();
DBPredefinedField dbFieldAnnotation = field.getAnnotation(DBPredefinedField.class);
String dbFieldName = dbFieldAnnotation.fieldName();
DBSupportedTypes type = dbFieldAnnotation.type();
fieldsList.add(new DBParsedField(
tableName,
fieldName,
dbFieldName,
field.getType(),
field,
type,
false)
);
}
//if join model
if (field.isAnnotationPresent(DBJoinModel.class)) {
String fieldName = field.getName();
String parentField = field.getAnnotation(DBJoinModel.class).currentDBFieldName();
String childField = field.getAnnotation(DBJoinModel.class).insideDBFieldName();
Class> fieldClass = field.getType();
DBParsedFieldsList parsedFields = parseEntity(fieldClass, uniqueTableDictionary);
DBParsedField parsedField = new DBParsedField(
tableName,
fieldName,
"",
field.getType(),
field,
DBSupportedTypes.JOIN_OBJECT,
false);
fieldsList.add(parsedField);
parsedField.setJoinField(new DBJoinField(parentField, childField, parsedFields));
}
}
return fieldsList;
}
/**
* Returns fields
*
* @param dbEntity db entity
* @param readSuperClass true if read superclass fields
* @return fields
*/
private List findFields(Object dbEntity, boolean readSuperClass) {
List result = new ArrayList<>();
Field[] entityFields = dbEntity.getClass().getDeclaredFields();
Collections.addAll(result, entityFields);
if (readSuperClass) {
Class> superclass = dbEntity.getClass().getSuperclass();
while (!superclass.getName().equals(Object.class.getName())) {
Field[] fields = superclass.getDeclaredFields();
Collections.addAll(result, fields);
superclass = superclass.getSuperclass();
}
}
return result;
}
/**
* Returns select query
*
* @param clazz entity class
* @param generic class
* @return db select query
* @throws DBException on unable to parse entity
*/
public WizDBSelect getSelectQuery(Class clazz) throws DBException {
DBParsedFieldsList fields = parseEntity(clazz);
return new WizDBSelect<>(pool, fields);
}
/**
* Returns insert query
*
* @param clazz entity class
* @param generic class
* @return db insert query
* @throws DBException on unable to parse entity
*/
public WizDBInsert getInsertQuery(Class clazz) throws DBException {
DBParsedFieldsList fields = parseEntity(clazz);
return new WizDBInsert<>(pool, fields);
}
/**
* Returns update query
*
* @param clazz entity class
* @param generic class
* @return db update query
* @throws DBException on unable to parse entity
*/
public WizDBUpdate getUpdateQuery(Class clazz) throws DBException {
DBParsedFieldsList fields = parseEntity(clazz);
return new WizDBUpdate<>(pool, fields);
}
/**
* Returns update query
*
* @param clazz entity class
* @param generic class
* @return db update query
* @throws DBException on unable to parse entity
*/
public WizDBDelete getDeleteQuery(Class clazz) throws DBException {
DBParsedFieldsList fields = parseEntity(clazz);
return new WizDBDelete<>(pool, fields);
}
/**
* Returns entity query builder
*
* @param clazz entity class
* @param entity
* @return entity queries
* @throws DBException on unable to parse entity
*/
public EntityQuery getEntityQuery(Class clazz) throws DBException {
DBParsedFieldsList fields = parseEntity(clazz);
return new EntityQuery<>(pool, fields);
}
/**
* Returns database connection pool
*
* @return connection pool
*/
public DBConnectionPool getPool() {
return pool;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy