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 model; import java.util.ArrayList; import javax.swing.ListModel; import org.hibernate.ObjectNotFoundException; import org.hibernate.Query; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; /** * * @author joao */ public class FuncaoModel { private final SessionFactory objSessionFactory; //String para mensagem de erro String msg = ""; public FuncaoModel() { //Recebe o Session Factory do HIbernate this.objSessionFactory = sigos.SigosHibernateUtil.getSessionFactory(); } public String insert(Funcao obj) { //Abre um sesso Session objSession = this.objSessionFactory.openSession(); //Inicia uma transao dentro da sesso aberta Transaction objTransaction = objSession.beginTransaction(); try { //ADICIONA o objeto categoria, assim o hibernate persiste no bancoapagando o registro. objSession.save(obj); //Realiza um commit do INSERT objTransaction.commit(); } catch (Exception e) { //Caso ocorrer algum erro, mostra uma mensagem this.msg = e.getMessage(); //Realiza o Rollback, cancelando o INSERT no banco de dados. objTransaction.rollback(); } //Fecha a sesso objSession.close(); //Retorna a mensagem return this.msg; } public String update(Funcao obj) { //Abre um sesso Session objSession = this.objSessionFactory.openSession(); //Inicia uma transao dentro da sesso aberta Transaction objTransaction = objSession.beginTransaction(); try { //ATUALIZA o objeto categoria, assim o hibernate persiste no bancoapagando o registro. objSession.merge(obj); //Realiza um commit do UPDATE objTransaction.commit(); } catch (Exception e) { //Caso ocorrer algum erro, mostra uma mensagem msg = e.getMessage(); //Realiza o Rollback, cancelando o UPDATE no banco de dados. objTransaction.rollback(); } //Fecha a sesso objSession.close(); //Retorna a mensagem return msg; } public String delete(Funcao obj) { //Abre um sesso Session objSession = this.objSessionFactory.openSession(); //Inicia uma transao dentro da sesso aberta Transaction objTransaction = objSession.beginTransaction(); try { //ATUALIZA o objeto categoria, assim o hibernate persiste no bancoapagando o registro. objSession.delete(obj); //Realiza um commit do UPDATE objTransaction.commit(); } catch (Exception e) { //Caso ocorrer algum erro, mostra uma mensagem msg = e.getMessage(); //Realiza o Rollback, cancelando o UPDATE no banco de dados. objTransaction.rollback(); } //Fecha a sesso objSession.close(); //Retorna a mensagem return msg; } public ListModel<Funcao> findByAllCombo() { ListModel<Funcao> lstFuncaoCombo = null; Session objSession = this.objSessionFactory.openSession(); try { Query objQuery = objSession.createQuery("from Funcao"); lstFuncaoCombo = (ListModel<Funcao>) objQuery.list(); } catch (ObjectNotFoundException e) { return null; } return lstFuncaoCombo; } public ArrayList<Funcao> findByAll() { //Cria lista de objetos ArrayList<Funcao> lstFuncao = null; //Abre um sesso Session objSession = this.objSessionFactory.openSession(); try { Query objQuery = objSession.createQuery("from Funcao"); lstFuncao = (ArrayList<Funcao>) objQuery.list(); } catch (ObjectNotFoundException e) { return null; } return lstFuncao; } public ArrayList<Funcao> findByFiltro(String descricao) { ArrayList<Funcao> lstFuncao = null; //Abre um sesso Session objSession = this.objSessionFactory.openSession(); try { Query objQuery = objSession.createQuery("from Funcao where descricao = :descricao"); objQuery.setParameter("descricao", descricao); lstFuncao = (ArrayList<Funcao>) objQuery.list(); } catch (ObjectNotFoundException e) { return null; } return lstFuncao; } public ArrayList<Funcao> findById(int idFuncao) { ArrayList<Funcao> lstFuncao = null; //Abre um sesso Session objSession = this.objSessionFactory.openSession(); try { Query objQuery = objSession.createQuery("from Funcao where id = :id order by descricao"); objQuery.setParameter("id", idFuncao); lstFuncao = (ArrayList<Funcao>) objQuery.list(); } catch (ObjectNotFoundException e) { return null; } return lstFuncao; } }