When one or more of the All filters is selected - only average normalized results are displayed. Please read Running and Results for more details.
Comparison of JPA/Database speed - the averages (normalized score, higher is better)
  | Derby embedded | H2 embedded | HSQLDB embedded | SQLite embedded | DB4O embedded | ObjectDB embedded | Derby server | H2 server | MySQL server | PostgreSQL server | ObjectDB server |
---|---|---|---|---|---|---|---|---|---|---|---|
DataNucleus | 8.0 | 9.6 | 9.0 | 0.022 | 3.8 | 2.9 | 1.7 | 8.0 | |||
EclipseLink | 12.7 | 21.9 | 20.1 | 0.22 | 7.9 | 5.1 | 1.2 | 13.1 | |||
Hibernate | 10.5 | 12.9 | 16.5 | 0.42 | 7.1 | 3.7 | 2.1 | 12.1 | |||
OpenJPA | 8.0 | 10.2 | 10.2 | 3.9 | 2.9 | 1.8 | 6.0 | ||||
ObjectDB | 99.6 | 33.1 |
Performance comparison chart - The Y-Axis represents normalized score in logarithmic scale - higher is better:
Performance comparison chart - The Y-Axis represents normalized score in linear scale - higher is better:
Best and Worst JPA/Database Performer in this comparison
The Most Efficient (the Fastest):
1. | ObjectDB embedded | 99.6 |
2. | ObjectDB server | 33.1 |
3. | EclipseLink with H2 embedded | 21.9 |
4. | EclipseLink with HSQLDB embedded | 20.1 |
5. | Hibernate with HSQLDB embedded | 16.5 |
6. | EclipseLink with PostgreSQL server | 13.1 |
7. | Hibernate with H2 embedded | 12.9 |
8. | EclipseLink with Derby embedded | 12.7 |
9. | Hibernate with PostgreSQL server | 12.1 |
10. | Hibernate with Derby embedded | 10.5 |
11. | OpenJPA with HSQLDB embedded | 10.2 |
12. | OpenJPA with H2 embedded | 10.2 |
13. | DataNucleus with H2 embedded | 9.6 |
14. | DataNucleus with HSQLDB embedded | 9.0 |
15. | DataNucleus with Derby embedded | 8.0 |
16. | DataNucleus with PostgreSQL server | 8.0 |
17. | OpenJPA with Derby embedded | 8.0 |
The Least Efficient (the Slowest):
18. | EclipseLink with Derby server | 7.9 |
19. | Hibernate with Derby server | 7.1 |
20. | OpenJPA with PostgreSQL server | 6.0 |
21. | EclipseLink with H2 server | 5.1 |
22. | OpenJPA with Derby server | 3.9 |
23. | DataNucleus with Derby server | 3.8 |
24. | Hibernate with H2 server | 3.7 |
25. | OpenJPA with H2 server | 2.9 |
26. | DataNucleus with H2 server | 2.9 |
27. | Hibernate with MySQL server | 2.1 |
28. | OpenJPA with MySQL server | 1.8 |
29. | DataNucleus with MySQL server | 1.7 |
30. | EclipseLink with MySQL server | 1.2 |
31. | Hibernate with SQLite embedded | 0.42 |
32. | EclipseLink with SQLite embedded | 0.22 |
33. | DataNucleus with DB4O embedded | 0.022 |
Total number of failed test runs (out of 29 tests in total) in this page results
Notes: Failed test runs are not included in any average score calculation. Click on failure numbers to see exception stack traces.
The results above are averages of the following 29 concrete test results
- Basic Person Test - Persistence Operations - Few Entities (5/100)
- Basic Person Test - Retrieval Operations - Few Entities (5/100)
- Basic Person Test - Query Operations - Few Entities (5/100)
- Basic Person Test - Update Operations - Few Entities (5/100)
- Basic Person Test - Removal Operations - Few Entities (5/100)
- Element Collection Test - Persistence Operations - Few Entities (5/100)
- Element Collection Test - Retrieval Operations - Few Entities (5/100)
- Element Collection Test - Query Operations - Few Entities (5/100)
- Element Collection Test - Update Operations - Few Entities (5/100)
- Element Collection Test - Removal Operations - Few Entities (5/100)
- Inheritance Test - Persistence Operations - Few Entities (5/100)
- Inheritance Test - Retrieval Operations - Few Entities (5/100)
- Inheritance Test - Query Operations - Few Entities (5/100)
- Inheritance Test - Update Operations - Few Entities (5/100)
- Inheritance Test - Removal Operations - Few Entities (5/100)
- Indexing Test - Persistence Operations - Few Entities (5/100)
- Indexing Test - Retrieval Operations - Few Entities (5/100)
- Indexing Test - Query Operations - Few Entities (5/100)
- Indexing Test - Update Operations - Few Entities (5/100)
- Indexing Test - Removal Operations - Few Entities (5/100)
- Graph (Binary Tree) Test - Persistence Operations - Few Entities (5/100)
- Graph (Binary Tree) Test - Retrieval Operations - Few Entities (5/100)
- Graph (Binary Tree) Test - Update Operations - Few Entities (5/100)
- Graph (Binary Tree) Test - Removal Operations - Few Entities (5/100)
- Multithreading Test - Persistence Operations - Few Entities (5/100)
- Multithreading Test - Retrieval Operations - Few Entities (5/100)
- Multithreading Test - Query Operations - Few Entities (5/100)
- Multithreading Test - Update Operations - Few Entities (5/100)
- Multithreading Test - Removal Operations - Few Entities (5/100)