3 * Copyright (C) 2007 EDIT
4 * European Distributed Institute of Taxonomy
5 * http://www.e-taxonomy.eu
7 * The contents of this file are subject to the Mozilla Public License Version 1.1
8 * See LICENSE.TXT at the top of this package for the full license terms.
11 package eu
.etaxonomy
.cdm
.persistence
.dao
.hibernate
.taxon
;
13 import java
.math
.BigInteger
;
14 import java
.util
.List
;
16 import java
.util
.UUID
;
18 import org
.apache
.log4j
.Logger
;
19 import org
.springframework
.beans
.factory
.annotation
.Autowired
;
20 import org
.springframework
.beans
.factory
.annotation
.Qualifier
;
21 import org
.springframework
.stereotype
.Repository
;
23 import eu
.etaxonomy
.cdm
.hibernate
.HibernateProxyHelper
;
24 import eu
.etaxonomy
.cdm
.model
.taxon
.Classification
;
25 import eu
.etaxonomy
.cdm
.model
.taxon
.Taxon
;
26 import eu
.etaxonomy
.cdm
.model
.taxon
.TaxonNode
;
27 import eu
.etaxonomy
.cdm
.persistence
.dao
.hibernate
.common
.AnnotatableDaoImpl
;
28 import eu
.etaxonomy
.cdm
.persistence
.dao
.taxon
.ITaxonDao
;
29 import eu
.etaxonomy
.cdm
.persistence
.dao
.taxon
.ITaxonNodeDao
;
36 @Qualifier("taxonNodeDaoHibernateImpl")
37 public class TaxonNodeDaoHibernateImpl
extends AnnotatableDaoImpl
<TaxonNode
>
38 implements ITaxonNodeDao
{
39 @SuppressWarnings("unused")
40 private static final Logger logger
= Logger
.getLogger(TaxonNodeDaoHibernateImpl
.class);
43 private ITaxonDao taxonDao
;
45 public TaxonNodeDaoHibernateImpl() {
46 super(TaxonNode
.class);
49 public UUID
delete(TaxonNode persistentObject
, boolean deleteChildren
){
50 Taxon taxon
= persistentObject
.getTaxon();
51 taxon
= HibernateProxyHelper
.deproxy(taxon
, Taxon
.class);
53 /*Session session = this.getSession();
54 Query query = session.createQuery("from TaxonNode t where t.taxon = :taxon");
55 query.setParameter("taxon", taxon);
56 List result = query.list();*/
58 Set
<TaxonNode
> nodes
= taxon
.getTaxonNodes();
62 TaxonNode node
= nodes
.iterator().next();
63 node
= HibernateProxyHelper
.deproxy(node
, TaxonNode
.class);
65 taxon
.removeTaxonNode(node
, deleteChildren
);
66 taxonDao
.delete(taxon
);
69 //persistentObject.delete();
71 super.delete(persistentObject
);
75 //taxon = (Taxon)taxonDao.findByUuid(taxon.getUuid());
76 return persistentObject
.getUuid();
80 public List
<TaxonNode
> getTaxonOfAcceptedTaxaByClassification(Classification classification
, int start
, int end
) {
81 int classificationId
= classification
.getId();
83 String queryString
= "SELECT DISTINCT nodes.* FROM TaxonNode AS nodes LEFT JOIN TaxonBase AS taxa ON nodes.taxon_id = taxa.id WHERE taxa.DTYPE = 'Taxon' AND nodes.classification_id = " + classificationId
+ " ORDER BY taxa.titleCache LIMIT "+start
+"," +end
;
84 List
<TaxonNode
> result
= getSession().createSQLQuery(queryString
).addEntity(TaxonNode
.class).list();
91 * @see eu.etaxonomy.cdm.persistence.dao.taxon.ITaxonNodeDao#countTaxonOfAcceptedTaxaByClassification(eu.etaxonomy.cdm.model.taxon.Classification)
94 public int countTaxonOfAcceptedTaxaByClassification(Classification classification
){
95 int classificationId
= classification
.getId();
97 String queryString
= "SELECT DISTINCT COUNT('nodes.*') FROM TaxonNode AS nodes LEFT JOIN TaxonBase AS taxa ON nodes.taxon_id = taxa.id WHERE taxa.DTYPE = 'Taxon' AND nodes.classification_id = " + classificationId
;
98 List
<BigInteger
> result
= getSession().createSQLQuery(queryString
).list();
99 return result
.get(0).intValue ();