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

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