summaryrefslogtreecommitdiffstats
path: root/docs/03_performance.mkd
blob: 34e545cecd516023479c2d02c42581725650285e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
## Performance

The information provided here may be based on flawed test procedures.  You have to be the judge of what is performant and non-performant.

### iciql statement generation

Performance of iciql statement generation is not currently benchmarked.

### iciql+database performance comparison

The following data was generated by running the *single-threaded* iciql test suite.  All database connections are pooled and re-used within each execution of the test suite using [Apache Commons DBCP](http://commons.apache.org/dbcp).

Connections are pooled to normalize embedded database performance with out-of-process database performance.  Some of the Java embedded database configurations have a very high startup-time penalty.  Notably, H2 is slow to open a database and its performance is substantially affected if connection pooling is not enabled to keep the embedded database open.

All tables are created as CACHED when the database distinguishes between CACHED and MEMORY tables.
  
All performance numbers include the combined overhead of iciql statement generation and JUnit 4 test framework execution so they are not bare-metal database metrics.  

<pre>
%DBPERFORMANCE%
</pre>