| 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 | }}} |