⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 fetchjoins.java

📁 This book shows you how to use JBoss to develop EJB projects.
💻 JAVA
字号:
package com.titan.clients;

import com.titan.domain.*;
import java.util.*;
import javax.persistence.*;

public class FetchJoins
{
   public static void main(String[] args) throws Exception 
   {
      HashMap props = new HashMap();
      props.put("hibernate.show_sql", "true");
      EntityManagerFactory factory =
         Persistence.createEntityManagerFactory("titan", props);
      EntityManager manager = factory.createEntityManager();
      try 
      {
         manager.getTransaction().begin();
         System.out.println("Initialize DB");
         InitializeDB.initialize(manager);
         System.out.println();
         System.out.println();
         manager.getTransaction().commit();
         System.out.println();
         System.out.println();
         System.out.println();
         
         manager.getTransaction().begin();
         noJoin(manager);
         manager.clear();
         manager.getTransaction().commit();
         System.out.println();
         System.out.println();
         System.out.println();


         manager.getTransaction().begin();
         joinFetch(manager);
         manager.clear();
         manager.getTransaction().commit();
      } 
      finally 
      {
         manager.close();
         factory.close();
      }
   }

   public static void noJoin(EntityManager manager)
   {
      System.out.println("-----------");
      System.out.println("  NO JOIN  ");
      System.out.println("-----------");
      Query query = manager.createQuery("SELECT c FROM Customer c");
      List results = query.getResultList();
      System.out.println();
      Iterator it = results.iterator();
      while (it.hasNext()) {
         Customer c = (Customer)it.next();
         Collection<Phone> phoneNumbers = c.getPhoneNumbers();
         // force the query so output looks nice
         phoneNumbers.size();
         System.out.print(c.getFirstName() + " " + c.getLastName());
         for (Phone p : phoneNumbers) {
            System.out.print(" " + p.getNumber());
         }
         System.out.println("");
      }
   }

   public static void joinFetch(EntityManager manager)
   {
      System.out.println("------------");
      System.out.println(" JOIN FETCH ");
      System.out.println("------------");
      Query query = manager.createQuery("SELECT c FROM Customer c LEFT JOIN FETCH c.phoneNumbers");
      List results = query.getResultList();
      HashSet set = new HashSet();
      set.addAll(results);
      System.out.println();
      Iterator it = set.iterator();
      while (it.hasNext()) {
         Customer c = (Customer)it.next();
         System.out.print(c.getFirstName() + " " + c.getLastName());
         for (Phone p : c.getPhoneNumbers()) {
            System.out.print(" " + p.getNumber());
         }
         System.out.println("");
      }
   }
}
      

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -