KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > com > db4o > test > tuning > TuningIdentityQuery


1 /* Copyright (C) 2004 - 2006 db4objects Inc. http://www.db4o.com
2
3 This file is part of the db4o open source object database.
4
5 db4o is free software; you can redistribute it and/or modify it under
6 the terms of version 2 of the GNU General Public License as published
7 by the Free Software Foundation and as clarified by db4objects' GPL
8 interpretation policy, available at
9 http://www.db4o.com/about/company/legalpolicies/gplinterpretation/
10 Alternatively you can write to db4objects, Inc., 1900 S Norfolk Street,
11 Suite 350, San Mateo, CA 94403, USA.
12
13 db4o is distributed in the hope that it will be useful, but WITHOUT ANY
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 for more details.
17
18 You should have received a copy of the GNU General Public License along
19 with this program; if not, write to the Free Software Foundation, Inc.,
20 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */

21 package com.db4o.test.tuning;
22
23 import com.db4o.*;
24 import com.db4o.query.*;
25 import com.db4o.test.*;
26
27
28 /**
29  * Original performance on the server:
30  * Querying 10000 objects for member identity: 640ms
31  *
32  * Original performance on Carls machine with Skype on:
33  * Querying 10000 objects for member identity: 703ms
34  *
35  * Result after enabling member indices:
36  * Querying time too small to measure.
37  */

38
39 public class TuningIdentityQuery {
40     
41     static final int COUNT = 10000;
42     
43     TIMember member;
44     
45     public TuningIdentityQuery(){
46     }
47     
48     public TuningIdentityQuery(TIMember member){
49         this.member = member;
50     }
51     
52     public void configure() {
53         Db4o.configure().objectClass(this).objectField("member").indexed(true);
54     }
55     
56     public void store(){
57         for (int i = 0; i < COUNT; i++) {
58             Test.store(new TuningIdentityQuery(new TIMember("" + i)));
59         }
60     }
61     
62     public void test(){
63         Query q = Test.query();
64         q.constrain(TIMember.class);
65         ObjectSet objectSet = q.execute();
66         TIMember member = (TIMember) objectSet.next();
67         q = Test.query();
68         q.constrain(TuningIdentityQuery.class);
69         q.descend("member").constrain(member).identity();
70         
71         long start = System.currentTimeMillis();
72         objectSet = q.execute();
73         
74         long stop = System.currentTimeMillis();
75         
76         Test.ensure(objectSet.size() == 1);
77         TuningIdentityQuery ti = (TuningIdentityQuery)objectSet.next();
78         Test.ensure(ti.member == member);
79         
80         long duration = stop - start;
81         System.out.println("Querying " + COUNT + " objects for member identity: " + duration + "ms");
82     }
83     
84     public static class TIMember{
85         
86         String JavaDoc name;
87         
88         public TIMember(){
89             
90         }
91         
92         public TIMember(String JavaDoc name){
93             this.name = name;
94         }
95         
96     }
97     
98
99 }
100
Popular Tags