I'm working this JPAContainer + Hibernate and it takes a long time to load. For example page with SQLContainer loading 60ms and same page with JPA Container loading 1.30s.
With JPAContainer in console I see many SQL queries - for each entity - query; Entity Person does not have links to other tables;
Code with jpacontainer:
JPAContainer<Person> container = JPAContainerFactory.make(Person.class,
            "persistence-unit");
table.setContainerDataSource(container);
Code with SQLContainer:
JDBCConnectionPool pool = null;
    try {
        pool = new SimpleJDBCConnectionPool("org.postgresql.Driver",
                "jdbc:postgresql://127.0.0.1:5432/postgres", "postgres",
                "pwd");
    } catch (SQLException e) {
        e.printStackTrace();
    }
    TableQuery tq = new TableQuery("Person", pool);
    SQLContainer sqlContainer = null;
    try {
        sqlContainer = new SQLContainer(tq);
    } catch (SQLException e) {
        e.printStackTrace();
    }
table.setContainerDataSource(sqlContainer);
My persistence.xml file:
<persistence-unit name="persistence-unit" transaction-type="RESOURCE_LOCAL">
  <jta-data-source>java:jboss/datasources/mfc-frontendDS</jta-data-source>
  <properties>
     <!-- Properties for Hibernate -->
    <property name="hibernate.archive.autodetection" value="class"/>
    <property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQLDialect"/>
    <property name="hibernate.show_sql" value="true"/>
    <property name="hibernate.format_sql" value="true"/>
    <property name="hibernate.use_sql_comments" value="true"/>
    <property name="hibernate.hbm2ddl.auto" value="update"/>
    <property name="hibernate.temp.use_jdbc_metadata_defaults" value="false"/>
    <property name="hibernate.transaction.jta.platform" value="org.hibernate.service.jta.platform.internal.JBossAppServerJtaPlatform" /> 
  </properties>
What am I doing wrong?
Stop fighting JPAContainer, there are too many abstraction layers behind it.

SQLContainer is good enough, fast and stable. I'm not saying SQLContainer is a replacement for JPAContainer, but the actual price seems to be too high. From the usability perspective responsiveness is a very important factor, so it is better not to start with seconds, spent on persistence layer.
Anyway, there are several options available if you really want to continue with JPAContainer:
Use CachingLocalEntityProvider
Rule of thumb: slow access -- use cache
If the number of database round-trips should be reduced, CachingLocalEntityProvider should be used instead. It maintains a local cache of entities and query results and hence should perform faster than LocalEntityProvider if database round-trips are slow. However, it also requires more memory than LocalEntityProvider.
Use paging (PagedTable)
It will greatly reduce number of queries, because pages are lazy loaded.
PagedTable is a component that behaves in the same matter as the Vaadin core Table, except that it has multiple pages instead of scrolling to show more entries.

Use JPAContainer filters
All filtering is done at the database level with queries, not in the container. The filtering implementation uses the JPA 2.0 Criteria API transparently. As the filtering is done at the database-level, custom filters that use the Filterable API do not work.
Please also check: JPAContainer Usage and Performance questions
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With