/* * Copyright 2014 by SCSK Corporation. * * This file is part of PrimeCloud Controller(TM). * * PrimeCloud Controller(TM) is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 2 of the License, or * (at your option) any later version. * * PrimeCloud Controller(TM) 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with PrimeCloud Controller(TM). If not, see <http://www.gnu.org/licenses/>. */ package jp.primecloud.auto.dao.crud.impl; import java.util.ArrayList; import java.util.Collection; import java.util.HashMap; import java.util.List; import java.util.Map; import org.springframework.orm.ibatis.support.SqlMapClientDaoSupport; import jp.primecloud.auto.dao.crud.BaseComponentInstanceDao; import jp.primecloud.auto.entity.crud.ComponentInstance; /** * <p> * {@link BaseComponentInstanceDao}の実装クラスです。 * </p> * */ @SuppressWarnings("deprecation") public abstract class BaseComponentInstanceDaoImpl extends SqlMapClientDaoSupport implements BaseComponentInstanceDao { protected String namespace = "ComponentInstance"; /** * {@inheritDoc} */ @Override public ComponentInstance read( Long componentNo, Long instanceNo ) { Map<String, Object> paramMap = new HashMap<String, Object>(); paramMap.put("componentNo", componentNo); paramMap.put("instanceNo", instanceNo); return (ComponentInstance) getSqlMapClientTemplate().queryForObject(getSqlMapId("read"), paramMap); } /** * {@inheritDoc} */ @Override @SuppressWarnings("unchecked") public List<ComponentInstance> readAll() { return (List<ComponentInstance>) getSqlMapClientTemplate().queryForList(getSqlMapId("readAll")); } /** * {@inheritDoc} */ @Override @SuppressWarnings("unchecked") public List<ComponentInstance> readByComponentNo( Long componentNo ) { Map<String, Object> paramMap = new HashMap<String, Object>(); paramMap.put("componentNo", componentNo); return (List<ComponentInstance>) getSqlMapClientTemplate().queryForList(getSqlMapId("readByComponentNo"), paramMap); } /** * {@inheritDoc} */ @Override @SuppressWarnings("unchecked") public List<ComponentInstance> readByInstanceNo( Long instanceNo ) { Map<String, Object> paramMap = new HashMap<String, Object>(); paramMap.put("instanceNo", instanceNo); return (List<ComponentInstance>) getSqlMapClientTemplate().queryForList(getSqlMapId("readByInstanceNo"), paramMap); } /** * {@inheritDoc} */ @Override @SuppressWarnings("unchecked") public List<ComponentInstance> readInComponentNos( Collection<Long> componentNos ) { if (componentNos.isEmpty()) { return new ArrayList<ComponentInstance>(); } Map<String, Object> paramMap = new HashMap<String, Object>(); if (componentNos instanceof List) { paramMap.put("componentNos", componentNos); } else { paramMap.put("componentNos", new ArrayList<Long>(componentNos)); } paramMap.put("orderBys", new String[0]); return (List<ComponentInstance>) getSqlMapClientTemplate().queryForList(getSqlMapId("readInComponentNos"), paramMap); } /** * {@inheritDoc} */ @Override @SuppressWarnings("unchecked") public List<ComponentInstance> readInInstanceNos( Collection<Long> instanceNos ) { if (instanceNos.isEmpty()) { return new ArrayList<ComponentInstance>(); } Map<String, Object> paramMap = new HashMap<String, Object>(); if (instanceNos instanceof List) { paramMap.put("instanceNos", instanceNos); } else { paramMap.put("instanceNos", new ArrayList<Long>(instanceNos)); } paramMap.put("orderBys", new String[0]); return (List<ComponentInstance>) getSqlMapClientTemplate().queryForList(getSqlMapId("readInInstanceNos"), paramMap); } /** * {@inheritDoc} */ @Override public void create(ComponentInstance entity) { String id = "create"; getSqlMapClientTemplate().insert(getSqlMapId(id), entity); } /** * {@inheritDoc} */ @Override public void update(ComponentInstance entity) { getSqlMapClientTemplate().insert(getSqlMapId("update"), entity); } /** * {@inheritDoc} */ @Override public void delete(ComponentInstance entity) { getSqlMapClientTemplate().insert(getSqlMapId("delete"), entity); } /** * {@inheritDoc} */ @Override public void deleteAll() { getSqlMapClientTemplate().delete(getSqlMapId("deleteAll")); } /** * {@inheritDoc} */ @Override public void deleteByComponentNoAndInstanceNo( Long componentNo, Long instanceNo ) { Map<String, Object> paramMap = new HashMap<String, Object>(); paramMap.put("componentNo", componentNo); paramMap.put("instanceNo", instanceNo); getSqlMapClientTemplate().delete(getSqlMapId("deleteByComponentNoAndInstanceNo"), paramMap); } /** * {@inheritDoc} */ @Override public void deleteByComponentNo( Long componentNo ) { Map<String, Object> paramMap = new HashMap<String, Object>(); paramMap.put("componentNo", componentNo); getSqlMapClientTemplate().delete(getSqlMapId("deleteByComponentNo"), paramMap); } /** * {@inheritDoc} */ @Override public void deleteByInstanceNo( Long instanceNo ) { Map<String, Object> paramMap = new HashMap<String, Object>(); paramMap.put("instanceNo", instanceNo); getSqlMapClientTemplate().delete(getSqlMapId("deleteByInstanceNo"), paramMap); } /** * {@inheritDoc} */ @Override public long countAll() { return (Long) getSqlMapClientTemplate().queryForObject(getSqlMapId("countAll")); } /** * {@inheritDoc} */ @Override public long countByComponentNoAndInstanceNo( Long componentNo, Long instanceNo ) { Map<String, Object> paramMap = new HashMap<String, Object>(); paramMap.put("componentNo", componentNo); paramMap.put("instanceNo", instanceNo); return (Long) getSqlMapClientTemplate().queryForObject(getSqlMapId("countByComponentNoAndInstanceNo"), paramMap); } /** * {@inheritDoc} */ @Override public long countByComponentNo( Long componentNo ) { Map<String, Object> paramMap = new HashMap<String, Object>(); paramMap.put("componentNo", componentNo); return (Long) getSqlMapClientTemplate().queryForObject(getSqlMapId("countByComponentNo"), paramMap); } /** * {@inheritDoc} */ @Override public long countByInstanceNo( Long instanceNo ) { Map<String, Object> paramMap = new HashMap<String, Object>(); paramMap.put("instanceNo", instanceNo); return (Long) getSqlMapClientTemplate().queryForObject(getSqlMapId("countByInstanceNo"), paramMap); } protected String getSqlMapId(String id) { if (namespace == null || namespace.length() == 0) { return id; } return namespace + "." + id; } }