Advertisement
Guest User

10. Remove Towns

a guest
Mar 24th, 2018
175
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Java 1.84 KB | None | 0 0
  1. package app;
  2.  
  3.         import entities.Address;
  4.         import entities.Employee;
  5.         import entities.Town;
  6.  
  7.         import javax.persistence.EntityManager;
  8.         import javax.persistence.EntityManagerFactory;
  9.         import javax.persistence.Persistence;
  10.         import java.io.BufferedReader;
  11.         import java.io.IOException;
  12.         import java.io.InputStreamReader;
  13.         import java.util.List;
  14.  
  15. public class p11 {
  16.     public static void main(String[] args) throws IOException {
  17.         EntityManagerFactory factory = Persistence.createEntityManagerFactory("soft_uni");
  18.         EntityManager em = factory.createEntityManager();
  19.         BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
  20.  
  21.         String input = reader.readLine();
  22.         int counter = 0;
  23.         try {
  24.  
  25.             Town town = (Town) em.createQuery("FROM Town WHERE name =:parameter").setParameter("parameter", input).getSingleResult();
  26.             List<Address> addresses = em.createQuery("FROM Address WHERE town.id=:parameter1").setParameter("parameter1", town.getId()).getResultList();
  27.  
  28.             em.getTransaction().begin();
  29.  
  30.             for (Address a : addresses) {
  31.                
  32.                 for (Employee e : a.getEmployees()) {
  33.                     if (addresses.contains(e.getAddress())){
  34.                         e.setAddress(null);
  35.                         em.persist(e);
  36.                     }
  37.                 }
  38.                 em.remove(a);
  39.                 counter++;
  40.             }
  41.  
  42.             em.remove(town);
  43.             em.getTransaction().commit();
  44.             System.out.printf("%d addresses in %s was deleted", counter, input);
  45.  
  46.         } catch (Exception e) {
  47.             em.getTransaction().rollback();
  48.  
  49.         } finally {
  50.             em.close();
  51.             factory.close();
  52.         }
  53.     }
  54. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement