Java tutorial
/* * To change this license header, choose License Headers in Project Properties. * To change this template file, choose Tools | Templates * and open the template in the editor. */ package com.ensa.model.controller.impl; import com.ensa.model.Image; import com.ensa.model.controller.ImageDao; import java.util.ArrayList; import java.util.List; import org.hibernate.Query; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Repository; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; /** * * @author Iob */ @Repository @Service @Transactional public class ImageDAOImpl implements ImageDao { private static final Logger logger = LoggerFactory.getLogger(ImageDAOImpl.class); @Autowired private SessionFactory sessionFactory; public void setSessionFactory(SessionFactory sf) { this.sessionFactory = sf; } @Override public void addImage(Image img) { Session session = this.sessionFactory.getCurrentSession(); Transaction t = session.beginTransaction(); session.persist(img); t.commit(); logger.info("Image added successfully"); } @Override public void updateImage(Image img) { throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates. } @Override public Image getImageById(int id) { String hql = "FROM Image I WHERE I.ID=:id"; Session session = sessionFactory.getCurrentSession(); Transaction transaction = null; try { Query query = session.createQuery(hql); transaction = session.beginTransaction(); query.setParameter("ID ", id); List results = query.list(); transaction.commit(); if (results.isEmpty()) { return null; } else { return (Image) results.get(0); } } catch (Exception e) { e.printStackTrace(); transaction.rollback(); return null; } } @Override public List<Image> getAllImages() { String hql = "FROM Image"; Session session = sessionFactory.getCurrentSession(); Query query = session.createQuery(hql); query.setMaxResults(20); List results = query.list(); if (results.isEmpty()) { return null; } else { return results; } } @Override public void removeImage(int id) { } @Override public List<Image> getLikedImages() { List<Image> liste = new ArrayList<Image>(); Session session = this.sessionFactory.getCurrentSession(); Query query = session.createQuery("FROM Image img ORDER BY img.likes asc"); query.setMaxResults(100); liste = query.list(); return liste; } public List<Image> getDownloadedImages() { List<Image> liste = new ArrayList<Image>(); Session session = this.sessionFactory.getCurrentSession(); Query query = session.createQuery("FROM Image img ORDER BY img.downloads asc"); query.setMaxResults(100); liste = query.list(); return liste; } @Override public List<Image> getPublicImages() { List<Image> liste = new ArrayList<Image>(); Session session = this.sessionFactory.getCurrentSession(); Query query = session.createQuery("FROM Image img WHERE img.pravacy='public'"); query.setMaxResults(100); liste = query.list(); return liste; } }