/* * Electronic Logistics Management Information System (eLMIS) is a supply chain management system for health commodities in a developing country setting. * * Copyright (C) 2015 John Snow, Inc (JSI). This program was produced for the U.S. Agency for International Development (USAID). It was prepared under the USAID | DELIVER PROJECT, Task Order 4. * * This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. */ package org.openlmis.report.mapper; import org.apache.ibatis.annotations.Options; import org.apache.ibatis.annotations.Param; import org.apache.ibatis.annotations.Select; import org.apache.ibatis.annotations.SelectProvider; import org.apache.ibatis.mapping.ResultSetType; import org.apache.ibatis.session.RowBounds; import org.openlmis.report.builder.CCEStorageCapacityQueryBuilder; import org.openlmis.report.model.params.CCEStorageCapacityReportParam; import org.openlmis.report.model.report.CCEStorageCapacityReport; import org.springframework.stereotype.Repository; import java.util.List; @Repository public interface CCEStorageCapacityReportMapper { @SelectProvider(type = CCEStorageCapacityQueryBuilder.class, method = "getData") @Options(resultSetType = ResultSetType.SCROLL_SENSITIVE, fetchSize = -1, timeout = 0, useCache = false, flushCache = false) List<CCEStorageCapacityReport> getFilteredSortedCCEStorageCapacityReport( @Param("filterCriteria") CCEStorageCapacityReportParam param, @Param("rowBounds") RowBounds rowBounds, @Param("userId") Long userId ); @Select("select value from facility_demographic_estimates fd " + " join demographic_estimate_categories dc on fd.demographicestimateid=dc.id " + " where dc.name = #{demographicCategory} and fd.facilityid=#{facilityId} and fd.year=#{year} limit 1") Integer getFacilityCategoryPopulation( @Param("demographicCategory") String demographicCategory, @Param("facilityId") Long facilityId, @Param("year") int year ); @Select("select value from district_demographic_estimates dd " + " join demographic_estimate_categories dc on dd.demographicestimateid=dc.id " + " join facilities f on f.geographiczoneid=dd.districtid " + " where dc.name =#{demographicCategory} and f.id=#{facilityId} and dd.year=#{year} limit 1") Integer getDistrictCategoryPoulation( @Param("demographicCategory") String demographicCategory, @Param("facilityId") Long facilityId, @Param("year") int year ); @Select("select SUM(value) from district_demographic_estimates dd " + " join demographic_estimate_categories dc on dd.demographicestimateid=dc.id " + " where dc.name = #{demographicCategory} and dd.districtid " + " IN (select id from geographic_zones where parentid= " + " (select gz.parentid from facilities f join geographic_zones gz on gz.id=f.geographiczoneid where f.id=#{facilityId})) " + " and dd.year=#{year}") Integer getRegionalCategoryPoulation( @Param("demographicCategory") String demographicCategory, @Param("facilityId") Long facilityId, @Param("year") int year ); }