com.bitranger.parknshop.seller.dao.impl.PsRecipientDAO.java Source code

Java tutorial

Introduction

Here is the source code for com.bitranger.parknshop.seller.dao.impl.PsRecipientDAO.java

Source

/*******************************************************************************
 * Copyright (c) 2014 BitRangers (Team C1).
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 * 
 * Contributors:
 *      BitRangers (Team C1) - initial API and implementation
 ******************************************************************************/
package com.bitranger.parknshop.seller.dao.impl;

import java.sql.SQLException;
import java.util.List;
import java.util.Set;

import org.hibernate.HibernateException;
import org.hibernate.LockMode;
import org.hibernate.SQLQuery;
import org.hibernate.Session;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.context.ApplicationContext;
import org.springframework.orm.hibernate3.HibernateCallback;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;

import com.bitranger.parknshop.seller.dao.IPsRecipientDAO;
import com.bitranger.parknshop.seller.model.PsRecipient;

/**
 * A data access object (DAO) providing persistence and search support for
 * PsRecipient entities. Transaction control of the save(), update() and
 * delete() operations can directly support Spring container-managed
 * transactions or they can be augmented to handle user-managed Spring
 * transactions. Each of these methods provides additional information for how
 * to configure it for the desired type of transaction control.
 * 
 * @see PsRecipient
 * @author MyEclipse Persistence Tools
 */
public class PsRecipientDAO extends HibernateDaoSupport implements IPsRecipientDAO {
    private static final Logger log = LoggerFactory.getLogger(PsRecipientDAO.class);
    // property constants
    public static final String NAME_RECIPIENT = "nameRecipient";
    public static final String ADDRESSS = "addresss";
    public static final String POSTAL_CODE = "postalCode";
    public static final String PHONE_NUMBER = "phoneNumber";
    public static final String COUNTRY = "country";
    public static final String PROVINCE = "province";
    public static final String CITY = "city";
    public static final String DETAILED_ADDR = "detailedAddr";

    @Override
    protected void initDao() {
        // do nothing
    }

    @Override
    public void save(PsRecipient transientInstance) {
        log.debug("saving PsRecipient instance");
        try {
            getHibernateTemplate().save(transientInstance);
            log.debug("save successful");
        } catch (RuntimeException re) {
            log.error("save failed", re);
            throw re;
        }
    }

    @Override
    public void delete(PsRecipient persistentInstance) {
        log.debug("deleting PsRecipient instance");
        try {
            getHibernateTemplate().delete(persistentInstance);
            log.debug("delete successful");
        } catch (RuntimeException re) {
            log.error("delete failed", re);
            throw re;
        }
    }

    @Override
    public PsRecipient findById(java.lang.Integer id) {
        log.debug("getting PsRecipient instance with id: " + id);
        try {
            PsRecipient instance = (PsRecipient) getHibernateTemplate()
                    .get("com.bitranger.parknshop.seller.model.PsRecipient", id);
            return instance;
        } catch (RuntimeException re) {
            log.error("get failed", re);
            throw re;
        }
    }

    public List<PsRecipient> findByExample(PsRecipient instance) {
        log.debug("finding PsRecipient instance by example");
        try {
            List<PsRecipient> results = (List<PsRecipient>) getHibernateTemplate().findByExample(instance);
            log.debug("find by example successful, result size: " + results.size());
            return results;
        } catch (RuntimeException re) {
            log.error("find by example failed", re);
            throw re;
        }
    }

    public List findByProperty(String propertyName, Object value) {
        log.debug("finding PsRecipient instance with property: " + propertyName + ", value: " + value);
        try {
            String queryString = "from PsRecipient as model where model." + propertyName + "= ?";
            return getHibernateTemplate().find(queryString, value);
        } catch (RuntimeException re) {
            log.error("find by property name failed", re);
            throw re;
        }
    }

    public List<PsRecipient> findByNameRecipient(Object nameRecipient) {
        return findByProperty(NAME_RECIPIENT, nameRecipient);
    }

    public List<PsRecipient> findByAddresss(Object addresss) {
        return findByProperty(ADDRESSS, addresss);
    }

    public List<PsRecipient> findByPostalCode(Object postalCode) {
        return findByProperty(POSTAL_CODE, postalCode);
    }

    public List<PsRecipient> findByPhoneNumber(Object phoneNumber) {
        return findByProperty(PHONE_NUMBER, phoneNumber);
    }

    public List<PsRecipient> findByCountry(Object country) {
        return findByProperty(COUNTRY, country);
    }

    public List<PsRecipient> findByProvince(Object province) {
        return findByProperty(PROVINCE, province);
    }

    public List<PsRecipient> findByCity(Object city) {
        return findByProperty(CITY, city);
    }

    public List<PsRecipient> findByDetailedAddr(Object detailedAddr) {
        return findByProperty(DETAILED_ADDR, detailedAddr);
    }

    public List findAll() {
        log.debug("finding all PsRecipient instances");
        try {
            String queryString = "from PsRecipient";
            return getHibernateTemplate().find(queryString);
        } catch (RuntimeException re) {
            log.error("find all failed", re);
            throw re;
        }
    }

    public PsRecipient merge(PsRecipient detachedInstance) {
        log.debug("merging PsRecipient instance");
        try {
            PsRecipient result = (PsRecipient) getHibernateTemplate().merge(detachedInstance);
            log.debug("merge successful");
            return result;
        } catch (RuntimeException re) {
            log.error("merge failed", re);
            throw re;
        }
    }

    public void attachDirty(PsRecipient instance) {
        log.debug("attaching dirty PsRecipient instance");
        try {
            getHibernateTemplate().saveOrUpdate(instance);
            log.debug("attach successful");
        } catch (RuntimeException re) {
            log.error("attach failed", re);
            throw re;
        }
    }

    public void attachClean(PsRecipient instance) {
        log.debug("attaching clean PsRecipient instance");
        try {
            getHibernateTemplate().lock(instance, LockMode.NONE);
            log.debug("attach successful");
        } catch (RuntimeException re) {
            log.error("attach failed", re);
            throw re;
        }
    }

    public static PsRecipientDAO getFromApplicationContext(ApplicationContext ctx) {
        return (PsRecipientDAO) ctx.getBean("PsRecipientDAO");
    }

    @Override
    public void update(PsRecipient detachedInstance) {
        getHibernateTemplate().update(detachedInstance);
    }

    @SuppressWarnings("unchecked")
    @Override
    public List<PsRecipient> findByCustomId(final Integer id) {
        return getHibernateTemplate().executeFind(new HibernateCallback<List<PsRecipient>>() {

            @Override
            public List<PsRecipient> doInHibernate(Session session) throws HibernateException, SQLException {
                SQLQuery q = session.createSQLQuery("select * from ps_recipient as RP where RP.id_customer = ?");
                q.setInteger(0, id);
                q.addEntity(PsRecipient.class);
                return q.list();
            }
        });
    }
}