Avoiding full table scans. Unless your entity is mapped to a very small table, you must avoid using SELECT statements that perform full table scans. For example, you can retrieve all items in a query like this The query will be much faster and you dont have to do any extra filtering work in the middle tier. Next, you retrieve the returned collection, iterate through the collection, and perform one or more operations on the resulting data. Article-Images/javaee-article-image%201.png' alt='Jpa Merge Insert Instead Updated' title='Jpa Merge Insert Instead Updated' />The persistence provider will generate the following SQL There are two problems here. First, this code will retrieve and bring in a lot of rows into the middle tier and consume a lot of memory. Second, it will cause a FULL TABLE SCAN in your database and the query will be very slow. Your DBA will advise you to avoid such SQL. Realistically, the number of available items you want is much less than the total number of items in your database. You must utilize the full potential of database filtering by changing your query to limit the number of rows retrieved as follows Using indexes to make queries faster. Indexes make your query faster. Your DBAs are probably responsible for building the indexes on tables, but theres a good chance that they dont know the details of how your application works. You should work with them so that they understand the queries used by your application. Only then can they build appropriate indexes for your application. Queries that include the primary key always use an indexed scan, meaning that no additional indexes are required. In spite of this, here are some additional cases where youll want to use an index to improve performance. Filtering based on a nonidentity field. This is very prevalent in applications. For example, suppose you want to retrieve your Item entities by item. Title as follows This JPQL statement will be translated to SQL as follows If you do not have an index on ITEMTITLE, the query will include a FULL TABLE scan. Therefore, we recommend you create an index in these situations. In this case, the index would be created on itemtitle. Using indexes for relationship fields. Relationships are implemented in the database by using foreign key constraints. However, you may not have indexes on the foreign key columns. Ragnarok Online 2 Sea Download. When you retrieve an associated entity, a join between the two underlying tables is performed. But this is slow because a FULL TABLE s. CAN will be executed on the associated entities. Creating an index on the underlying table will allow the database to use that index while joining the tables, which is must faster than joining two large tables without an index. In Action. Bazaar, Item and Bid have a one to many relationship due to eager loading. If you have a JPQL query that uses a JOIN clause, the persistence provider could generate the following SQL statement If we assume that there is no index on the bids. Oracle database handles this SQL statement like so If you add an index on the itemid column for the bids table, youll see the query plan for our SQL statement change as follows Review your queries with your DBAs and they should be able to determine whether adding an index for a column makes sense. Ordering a collection of entities. You can order the entities retrieved in a collection by using the Order. By annotation. In Action. Bazaar, if we want to retrieve Bids in descending order of bid. Price, we can do this Ordering of rows is an expensive operation in the database, especially when a lot of rows are retrieved. Therefore, it doesnt always make sense to retrieve the entities in an ordered collection. Unless another sort order is required, lets set the default order using a JPQL query as follows The database will try to order the matching records by BIDPRICE. We expect your DBA will agree that adding an index on BIDPRICE for the BIDS table will improve query performance. Using functions in the WHERE clause of JPQLYou can use JPQL functions in the WHERE clause of a query. For example, you can create a JPQL query as follows This statement will be translated to SQL as follows Check the documentation for your persistence provider to find out whether setting the JDBC fetch size is supported. Remember that when you use a function in the WHERE clause, the database wont use an indexed scan, even if an index exists on the firstname column. Because of this, you should avoid using functions in the WHERE clause. Some databases support creating function based indexes and you can use them if needed. Just be aware that the function based indexes may not be portable. For our example, you could consider storing the names in uppercase instead of using the JPQL Upper function. Reducing round trips to the database. If your query retrieves a lot of entities, that means a lot of rows are retrieved from the database, and this translates into multiple round trips between your application and the database. Some JDBC drivers provide facilities to reduce the number of round trips to the database by setting the number of rows to be prefetched in the middle tier while a result set is being populated. This improves performance of queries that retrieve a large number of rows. Caching. The EJB 3 JPA does not require persistence providers to do any type of caching. On the other hand, one of the primary benefits of using most OR mapping frameworks is that they provide a certain level of caching to reduce trips to the database. Some people think caching is the solution for every performance problem. The reality is that improper use of caching may lead to stale data and a whole different set of performance issues. Before jumping into using a cache, you need to understand how your vendor supports caching. In most cases, you can improve performance of your applications with the appropriate use of caching. Most persistence providers support caching either entity objects, queries, or both. Caching probably makes sense for data that is read only or is not frequently updated read mostly. For example, in Action. Bazaar some entities such as Category rarely change. Knowing this helps us decide that it makes sense to cache Catalog entity objects. Some queries may always result in the same data within a specific time interval. For example, a named query find. Five. Most. Popularitems may always return the same set of entities for a four to five hour interval. You may wish to cache the results of that query because almost all users of Action. Bazaar would probably wish to see the most popular items.