ca.gc.aafc.dina.service.PostgresHierarchicalDataService Maven / Gradle / Ivy
package ca.gc.aafc.dina.service;
import java.util.List;
import ca.gc.aafc.dina.dto.HierarchicalObject;
import ca.gc.aafc.dina.mybatis.UUIDTypeHandler;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Options;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Result;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.mapping.StatementType;
@Mapper
public interface PostgresHierarchicalDataService {
/**
* Select the entire hierarchy of an object to the root of a parent/child structure.
* The returned list is ordered and the last element is the root.
*
* @param id ID of the object for which we seek the hierarchy
* @param tableName Table name against which the search will be performed
* @param idColumnName Name of the column containing the object id
* @param uuidColumnName Name of the column containing the object uuid
* @param nameColumnName Name of the column containing the object name
* @param parentIdColumnName Name of the column containing the parent id
* @return List<HierarchicalObject>
* HierarchicalObjects represent each of the ancestors of the
* target object X (represented by id param). HierarchicalObject
* have attributes id, uuid, name, and rank of the ancestor
* where rank is the distance from X + 1
**/
@Select(
"WITH RECURSIVE get_hierarchy (id, parent_id, uuid, name, rank) AS ( "
+ "SELECT initial_t.${idColumnName}, initial_t.${parentIdColumnName}, initial_t.${uuidColumnName}, initial_t.${nameColumnName}, 1 "
+ "FROM ${tableName} AS initial_t where initial_t.${idColumnName} = ${id} " + "UNION ALL "
+ "SELECT node.${idColumnName}, node.${parentIdColumnName}, node.${uuidColumnName}, node.${nameColumnName}, gh.rank + 1 "
+ "FROM get_hierarchy gh, ${tableName} AS node " + "WHERE node.${idColumnName} = gh.parent_id) "
+ "SELECT id, uuid, name, rank FROM get_hierarchy;")
@Options(statementType = StatementType.CALLABLE)
@Result(property = "uuid", column = "uuid", typeHandler = UUIDTypeHandler.class)
List getHierarchy(
@Param("id") Integer id,
@Param("tableName") String tableName,
@Param("idColumnName") String idColumnName,
@Param("uuidColumnName") String uuidColumnName,
@Param("parentIdColumnName") String parentIdColumnName,
@Param("nameColumnName") String nameColumnName
);
/**
* Same as {@link #getHierarchy(Integer, String, String, String, String, String)} but with a type for every objects.
*
* @param id ID of the object for which we seek the hierarchy
* @param tableName Table name against which the search will be performed
* @param idColumnName Name of the column containing the object id
* @param uuidColumnName Name of the column containing the object uuid
* @param parentIdColumnName Name of the column containing the parent id
* @param nameColumnName Name of the column containing the object name
* @param typeColumnName Name of the column containing the type of the object
* @return List<HierarchicalObject>
* HierarchicalObjects represent each of the ancestors of the
* target object X (represented by id param). HierarchicalObject
* have attributes id, uuid, name, and rank of the ancestor
* where rank is the distance from X + 1
**/
@Select(
"WITH RECURSIVE get_hierarchy (id, parent_id, uuid, name, type, rank) AS ( "
+ "SELECT initial_t.${idColumnName}, initial_t.${parentIdColumnName}, initial_t.${uuidColumnName}, "
+ "initial_t.${nameColumnName}, initial_t.${typeColumnName}, 1 "
+ "FROM ${tableName} AS initial_t where initial_t.${idColumnName} = ${id} " + "UNION ALL "
+ "SELECT node.${idColumnName}, node.${parentIdColumnName}, node.${uuidColumnName}, node.${nameColumnName}, node.${typeColumnName}, gh.rank + 1 "
+ "FROM get_hierarchy gh, ${tableName} AS node " + "WHERE node.${idColumnName} = gh.parent_id) "
+ "SELECT id, uuid, name, type, rank FROM get_hierarchy;")
@Options(statementType = StatementType.CALLABLE)
@Result(property = "uuid", column = "uuid", typeHandler = UUIDTypeHandler.class)
List getHierarchyWithType(
@Param("id") Integer id,
@Param("tableName") String tableName,
@Param("idColumnName") String idColumnName,
@Param("uuidColumnName") String uuidColumnName,
@Param("parentIdColumnName") String parentIdColumnName,
@Param("nameColumnName") String nameColumnName,
@Param("typeColumnName") String typeColumnName
);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy