Java tutorial
/* =========================================================== * $Id: CustomerDAOImpl.java 516 2009-08-23 16:33:31Z bitorb $ * This file is part of Micrite * =========================================================== * * (C) Copyright 2009, by Gaixie.org and Contributors. * * Project Info: http://micrite.gaixie.org/ * * Micrite 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. * * Micrite 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 Micrite. If not, see <http://www.gnu.org/licenses/>. * */ package org.gaixie.micrite.crm.dao.hibernate; import java.util.ArrayList; import java.util.Date; import java.util.List; import org.apache.derby.tools.sysinfo; import org.gaixie.micrite.common.search.SearchBean; import org.gaixie.micrite.common.search.SearchFactory; import org.gaixie.micrite.beans.Dictionary; import org.gaixie.micrite.beans.Carowner; //import org.gaixie.micrite.beans.CustomerSource; import org.gaixie.micrite.crm.dao.ICustomerDAO; import org.gaixie.micrite.dao.hibernate.GenericDAOImpl; import org.hibernate.criterion.DetachedCriteria; import org.hibernate.criterion.Expression; import org.hibernate.criterion.Projections; /** * ??hibernate * @see org.gaixie.micrite.crm.dao.ICustomerDAO */ public class CustomerDAOImpl extends GenericDAOImpl<Carowner, Integer> implements ICustomerDAO { @SuppressWarnings("unchecked") public List<Carowner> advancedFindByPerPage(SearchBean[] queryBean, int start, int limit) { DetachedCriteria criteria = SearchFactory.generateCriteria(Carowner.class, queryBean); System.out.println(criteria); return getHibernateTemplate().findByCriteria(criteria, start, limit); } public int advancedFindCount(SearchBean[] queryBean) { DetachedCriteria criteria = SearchFactory.generateCriteria(Carowner.class, queryBean); criteria.setProjection(Projections.rowCount()); return (Integer) getHibernateTemplate().findByCriteria(criteria).get(0); } // @SuppressWarnings("unchecked") // public List<CustomerSource> findAllCustomerSource() { // DetachedCriteria criteria = DetachedCriteria.forClass(CustomerSource.class); // return getHibernateTemplate().findByCriteria(criteria); // } public int findByCreateDateSpacingCount(Date startDate, Date endDate, int customerSourceType) { DetachedCriteria criteria = DetachedCriteria.forClass(Carowner.class); criteria.createAlias("customerSource", "cs"); if (0 != customerSourceType) { criteria.add(Expression.eq("cs.id", customerSourceType)); } criteria.add(Expression.between("creation_ts", startDate, endDate)); criteria.setProjection(Projections.rowCount()); return (Integer) getHibernateTemplate().findByCriteria(criteria).get(0); } @SuppressWarnings("unchecked") public List<Carowner> findByCreateDateSpacingPerPage(Date startDate, Date endDate, int start, int limit, int customerSourceType) { DetachedCriteria criteria = DetachedCriteria.forClass(Carowner.class); criteria.createAlias("customerSource", "cs"); if (0 != customerSourceType) { criteria.add(Expression.eq("cs.id", customerSourceType)); } criteria.add(Expression.between("creation_ts", startDate, endDate)); return getHibernateTemplate().findByCriteria(criteria, start, limit); } @SuppressWarnings("unchecked") public List findCSGroupByTelVague(SearchBean[] queryBean) { DetachedCriteria criteria = SearchFactory.generateCriteria(Carowner.class, queryBean); criteria.createAlias("customerSource", "cs"); criteria.setProjection(Projections.projectionList().add(Projections.count("cs.name")) .add(Projections.groupProperty("cs.name"))); return getHibernateTemplate().findByCriteria(criteria); } // // public CustomerSource getCustomerSource(int id) { // return (CustomerSource) getHibernateTemplate().get(CustomerSource.class, id); // } }