/*
* 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.equipment.repository.mapper;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Options;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.Update;
import org.openlmis.equipment.domain.ServiceType;
import org.springframework.stereotype.Repository;
import java.util.List;
@Repository
public interface ServiceTypeMapper {
@Select("select * from equipment_service_types where id = #{id}")
ServiceType getById(Long id);
@Select("select * from equipment_service_types order by name")
List<ServiceType> getAll();
@Insert("insert into equipment_service_types (name, description, createdBy, createdDate, modifiedBy, modifiedDate) " +
" values " +
" (#{name}, #{description}, #{createdBy},COALESCE(#{createdDate}, NOW()), #{modifiedBy}, NOW() )")
@Options(useGeneratedKeys = true)
void insert(ServiceType value);
@Update("UPDATE equipment_service_types SET " +
"name = #{name}, description = #{description}, modifiedBy = #{modifiedBy}, modifiedDate = NOW()" +
" WHERE id = #{id}")
void update(ServiceType value);
}