Following on from my previous question, I’m looking to run some performance tests on various potential schema representations of an object model. However, the catch is that while the model is conceptually complete, it’s not actually finalised yet – and so the exact number of tables, and numbers/types of attributes in each table aren’t definite.
From my (possibly naive) perspective it seems like it should be possible to put together a representative prototype model for each approach, and test the performance of each of these to determine which is the fastest approach for each case.
And that’s where the question comes in. I’m aware that the performance characteristics of databases can be very non-intuitive, such that a small (even “trivial”) change can lead to an order of magnitude difference. Thus I’m wondering what common pitfalls there might be when setting up a dummy table structure and populating it with dummy data. Since the environment is likely to make a massive difference here, the target is Oracle 10.2.0.3.0 running on RHEL 3.
(In particular, I’m looking for examples such as “make sure that one of your tables has a much more selective index than the other”; “make sure you have more than x rows/columns because below this you won’t hit page faults and the performance will be different”; “ensure you test with the DATETIME datatype if you’re going to use it because it will change the query plan greatly”, and so on. I tried Google, expecting there would be lots of pages/blog posts on best practices in this area, but couldn’t find the trees for the wood (lots of pages about tuning performance of an existing DB instead).)
As a note, I’m willing to accept an answer along the lines of “it’s not feasible to perform a test like this with any degree of confidence in the transitivity of the result”, if that is indeed the case.
There are a few things that you can do to position yourself to meet performance objectives. I think they happen in this order:
More on each:
Architectures, best practices and patterns: one of the most common reasons for reporting databases to fail to perform is that those who build them are completely unfamiliar with the reporting domain. They may be experts on the transactional database domain – but the techniques from that domain do not translate to the warehouse/reporting domain. So, you need to know your domain well – and if you do you’ll be able to quickly identify an appropriate approach that will work almost always – and that you can tweak from there.
How the database works: you need to understand in general what options the optimizer/planner has for your queries. What’s the impact to different statements of adding indexes? What’s the impact of indexing a 256 byte varchar? Will reporting queries even use your indexes? etc
Now that you’ve got the right approach, and generally understand how 90% of your model will perform – you’re often done forecasting performance with most small to medium size databases. If you’ve got a huge one, there’s a ton at stake, you’ve got to get more precise (might need to order more hardware), or have a few wacky spots in the design – then focus your tests on just this. Generate reasonable test data – and (important) stats that you’d see in production. And look to see what the database will do with that data. Unless you’ve got real data and real prod-sized servers you’ll still have to extrapolate – but you should at least be able to get reasonably close.