2012-11-16 8 views
7

Ich versuche, Lazy Loading innerhalb meiner Dataset-Setups zu implementieren. Momentan funktioniert dies ohne die Lazy-Loading-Implementierung, aber ich bekomme keine Daten in der Datentabelle nach dem Implementieren des Lazy-Ladens. Allerdings kann ich meine Liste innerhalb meiner LoadData-Methode drucken, um zu überprüfen, dass die Daten in meine Liste geladen werden, aber es scheint ein Problem zu geben, sobald mein LazyModel zurückgegeben wird und das Laden der Datentabelle versucht wird. Dies könnte einfach etwas sein, das ich übersehen habe. Jede Hilfe wird sehr geschätzt!Primefaces Lazy Loading keine Daten in Datentabelle

Hier ist mein ScreenshotListProducer Klassencode:

@ManagedBean 
    @RequestScoped 
    public class ScreenshotListProducer implements Serializable { 
     private static final long serialVersionUID = 1L; 
     @Inject 
     private EntityManager em; 

     private List<Screenshot> screenshots; 

     private LazyDataModel<Screenshot> lazyModel = null; 

     private int pageSize = 5; 

     public void setPageSize(int pageSize) { 
      this.pageSize = pageSize; 
     } 

     public int getPageSize() { 
      return pageSize; 
     } 

     @Produces 
     @Named 
     public List<Screenshot> getScreenshots() { 
      System.out.println("************* getting screenshots list **************"); 
      return screenshots; 
     } 

     @PostConstruct 
     public void LoadData() { 
      lazyModel = new LazyDataModel<Screenshot>() { 
       private static final long serialVersionUID = 1L; 

        @Override 
        public List<Screenshot> load(int first, int pageSize, String sortField, SortOrder sortOrder, Map<String,String> filters) {  
        int start = first; 
        int end = first + pageSize; 

        try { 
         CriteriaBuilder cb = em.getCriteriaBuilder(); 
         CriteriaQuery<Screenshot> criteria = cb.createQuery(Screenshot.class); 
         Root<Screenshot> screenshot = criteria.from(Screenshot.class); 
         criteria.select(screenshot).orderBy(cb.asc(screenshot.get("time"))); 

         TypedQuery<Screenshot> s = em.createQuery(criteria); 
         s.setMaxResults(end - start); 
         s.setFirstResult(start); 

         screenshots = s.getResultList(); 
         System.out.println("************* lazy screenshot list created **************"); 
         for (Screenshot lazylist : screenshots) { 
          System.out.println("id numbers in lazy list: " + lazylist.getId()); 
         } 
        } catch (NullPointerException e) { 
         // TODO Auto-generated catch block 
         e.printStackTrace(); 
        } 

        return screenshots; 
        } 
      }; 
     } 

    public LazyDataModel<Screenshot> getLazyModel() { 
     return lazyModel; 
    } 

Hier meine Screenshot-Klasse ist:

@Entity 
@XmlRootElement 
@Table(name="Test2012", uniqueConstraints = @UniqueConstraint(columnNames = "id")) 
public class Screenshot implements Serializable { 
    private static final long serialVersionUID = 1L; 

    @Id 
    @GeneratedValue 
    @Column(name = "id", columnDefinition="INT") 
    private Long id; 

    private Timestamp time; 

    public Long getId() { 
     return id; 
    } 

    public void setId(Long id) { 
     this.id = id; 
    } 

    public Timestamp getTime() { 
     return time; 
    } 

    public void setTime(Timestamp time) { 
     this.time = time; 
    } 
} 

Hier ist mein XHTML-Code:

<p:dataTable id="table1" var="scrshot" rowKey="#{scrshot.id}" value="#{screenshotListProducer.lazyModel}" paginator="true" rows="7" paginatorPosition="bottom" 
       paginatorTemplate="{CurrentPageReport} {FirstPageLink} {PreviousPageLink} {PageLinks} {NextPageLink} {LastPageLink} {RowsPerPageDropdown}" 
       rowsPerPageTemplate="7,20,50,100" widgetVar="dataTable" currentPageReportTemplate="(Number of Records: {totalRecords})" 
       emptyMessage="No screenshot data found with given criteria" lazy="true" scrollable="true" draggableColumns="true" scrollHeight="217" style="width: 100%;"> 
      <f:facet name="header"> 
      <p:outputPanel> 
       <h:outputText value="Search all fields: "/> 
       <p:inputText id="globalFilter" onkeyup="dataTable.filter()"/> 
      </p:outputPanel> 
      </f:facet> 
      <p:column selectionMode="multiple"/> 
      <p:column id="time" headerText="Time" sortBy="#{scrshot.time}" filterBy="#{scrshot.time}" filterMatchMode="startsWith"> 
      <h:outputText value="#{scrshot.time}"/> 
      </p:column> 
      <p:column id="id" headerText="ID" sortBy="#{scrshot.id}" filterBy="#{scrshot.id}" filterOptions="#{scrshot.id}" filterMatchMode="exact"> 
      <h:outputText value="#{scrshot.id}"/> 
      </p:column> 
    </p:dataTable> 
+0

können Sie den vollständigen Arbeitscode von Lazing laden – spt

Antwort

10

Gut im Fall faul loader müssen Sie die Gesamtzahl Ihrer Datensätze wie "this.setRowCount (total_records_that_are_there);" in Ihrer "laden" -Methode. Es ist notwendig, dass der Lazy Loader bestimmt, wie viele Seiten es gibt, so dass die nächsten und vorherigen Knöpfe in der Datentabelle bestimmt werden können, d. H. (Aktivieren/Deaktivieren). Wie [0 ist Start] und [total/rowsize] ist die Gesamtzahl der Seiten, die Sie jedoch mit der load-Methode mit (first und pagezie => skip and limit) abrufen;

+0

Vielen Dank für die Info. Vor etwas mehr als einer Woche habe ich meine Sortierung korrigiert, indem ich meine Zeilenanzahl und die Seitengröße festgelegt habe, aber ich bin in Kreisen gegangen, um zu versuchen, dass meine Filterung richtig funktioniert. Es gibt derzeit die ersten beiden Datensätze immer wieder zurück, aber es hat die korrekte Anzahl von Datenbankzeilen und -zeilen pro Seite. Irgendwelche Vorschläge? – user1530469

+0

Mein Filterproblem mit den sich wiederholenden Datensätzen war auf einen Datenbank-Join zurückzuführen, der aufgrund meiner Filterung stattfand. – user1530469

+0

Danke! Overriding getRowCount ist genau das, was ich brauchte! –