| | 27 | |
| | 28 | == 統計情報の取得 == |
| | 29 | Hibernateには、エンティティクラス毎にCRUDの操作の統計情報を取るAPIが用意されています。このAPIを利用すると、パフォーマンスチューニング等で有用な情報を取得することができます。このAPIを利用するには次のようにします。 |
| | 30 | {{{ |
| | 31 | EntityManagerFactoryImpl factoryImpl = (EntityManagerFactoryImpl)factory; |
| | 32 | Statistics stat = factoryImpl.getSessionFactory().getStatistics(); |
| | 33 | String[] entities = stat.getEntityNames(); |
| | 34 | System.out.println("[dump]"); |
| | 35 | for(int i=0;i<entities.length;i++){ |
| | 36 | System.out.println(entities[i]+":"+stat.getEntityStatistics(entities[i])); |
| | 37 | } |
| | 38 | }}} |
| | 39 | 実行結果は、次のようになります。 |
| | 40 | {{{ |
| | 41 | org.ultimania.ejb.Purchaseorder:EntityStatistics |
| | 42 | [loadCount=0,updateCount=0,insertCount=0,deleteCount=0,fetchCount=0,optimisticLockFailureCount=0] |
| | 43 | org.ultimania.ejb.Orderdetail:EntityStatistics |
| | 44 | [loadCount=0,updateCount=0,insertCount=0,deleteCount=0,fetchCount=0,optimisticLockFailureCount=0] |
| | 45 | org.ultimania.ejb.Customer:EntityStatistics |
| | 46 | [loadCount=0,updateCount=0,insertCount=0,deleteCount=0,fetchCount=0,optimisticLockFailureCount=0] |
| | 47 | org.ultimania.ejb.Item:EntityStatistics |
| | 48 | [loadCount=2,updateCount=0,insertCount=0,deleteCount=0,fetchCount=0,optimisticLockFailureCount=0] |
| | 49 | }}} |