Java tutorial
/* * Copyright J. Craig Venter Institute, 2013 * * The creation of this program was supported by J. Craig Venter Institute * and National Institute for Allergy and Infectious Diseases (NIAID), * Contract number HHSN272200900007C. * * This program 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 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ package org.jcvi.ometa.hibernate.dao; import org.hibernate.Criteria; import org.hibernate.SQLQuery; import org.hibernate.Session; import org.hibernate.criterion.Restrictions; import org.jcvi.ometa.model.SampleMetaAttribute; import org.jcvi.ometa.validation.ModelValidator; import java.util.ArrayList; import java.util.Date; import java.util.List; /** * Created by IntelliJ IDEA. * User: lfoster * Date: 1/3/11 * Time: 4:37 PM * <p/> * Database interchange for Event Meta Attributes - the information framing up what CAN be * given as an attribute. */ public class SampleMetaAttributeDAO extends HibernateDAO { public void write(SampleMetaAttribute model, Date transactionDate, Session session) throws DAOException { try { prepareForWriteback(model, null, transactionDate, session); session.saveOrUpdate(model); } catch (Exception ex) { throw new DAOException(ex); } } public void update(SampleMetaAttribute model, Date transactionDate, Session session) throws DAOException { try { prepareForWriteback(model, null, transactionDate, session); session.merge(model); } catch (Exception ex) { throw new DAOException(ex); } } /** * get all meta-attributes associated with project. */ public List<SampleMetaAttribute> readAll(Long projectId, Session session) throws DAOException { List<SampleMetaAttribute> attributeList = new ArrayList<SampleMetaAttribute>(); try { Criteria crit = session.createCriteria(SampleMetaAttribute.class); crit.add(Restrictions.eq("projectId", projectId)); List<SampleMetaAttribute> results = crit.list(); if (results != null) { for (SampleMetaAttribute result : results) { SampleMetaAttribute attribute = result; expandLookupValueId(attribute, session); attributeList.add(attribute); } logger.debug("Got " + results.size() + " sample meta attributes for project " + projectId); } } catch (Exception ex) { throw new DAOException(ex); } return attributeList; } /** * get all meta-attributes associated with all projects given. */ public List<SampleMetaAttribute> readAll(List<Long> projectIds, Session session) throws DAOException { List<SampleMetaAttribute> attributeList = new ArrayList<SampleMetaAttribute>(); try { if (projectIds.size() > 0) { Criteria crit = session.createCriteria(SampleMetaAttribute.class); crit.add(Restrictions.in("projectId", projectIds)); List<SampleMetaAttribute> results = crit.list(); if (results != null) { expandLookupValueIds(results, session); logger.debug("Got " + results.size() + " sample meta attributes for project list of size " + projectIds.size()); attributeList.addAll(results); } } } catch (Exception ex) { throw new DAOException(ex); } return attributeList; } public SampleMetaAttribute getSampleMetaAttribute(Long lookupValueId, Long projectId, Session session) throws DAOException { return getMetaAttribute(lookupValueId, projectId, session, SampleMetaAttribute.class); } /** * get all unique meta-attributes */ public List<SampleMetaAttribute> readAllUnique(Session session) throws DAOException { List<SampleMetaAttribute> attributeList = new ArrayList<SampleMetaAttribute>(); try { String sql = " select SMA.* from sample_meta_attribute SMA, " + " (select sampma_id, max(sampma_create_date) " + " from sample_meta_attribute group by sampma_lkuvlu_attribute_id) SMAU " + " where SMA.sampma_id = SMAU.sampma_id "; SQLQuery query = session.createSQLQuery(sql); query.addEntity("SMA", SampleMetaAttribute.class); attributeList = query.list(); } catch (Exception ex) { throw new DAOException(ex); } return attributeList; } private void prepareForWriteback(SampleMetaAttribute model, String actorName, Date transactionDate, Session session) throws DAOException { /* * Only apply active flag to newly added meta attribute * by hkim 9/7/12 */ if (model.getCreationDate() == null) model.setActive(true); handleProjectRelation(model, model.getProjectName(), model.getAttributeName(), session); handleCreationTracking(model, actorName, transactionDate, session); locateAttribNameLookupId(model, session, ModelValidator.ATTRIBUTE_LV_TYPE_NAME); } }