I'm looking for information about DB4O object database. I know it has client/server mode, but I have no idea how scalable it is. I'm a big lover of object db idea, but still couldn't find an appropriate OODB to use in any of my projects. So my questions are:
- I'm interested if anyone deployed DB4O in a multi client environment and how does it perform compared to RDBMS?
- Is any web app to date powered by DB4O?
- Can I use DB4O as a replacement for SQL Server (SQL Express at least)?
- How many concurrent client can DB4O support in practice?
- Does performance degrades when DB size increases?
Thanks
P.S. I'm interested in C# edition.
Short answer: yes, db4o can be used as a replacement for RDBMs
Long answer: It depends.
I really don't believe in "one size fits all" so I IMHO, it depends on your object model, access pattern, machine configuration, db tunning, expected growth rate, # of indexes, etc.
The best advice I can think of has already been said in the comments: do not take any answer as definitive/reliable (even mine ;-)); do your own performance measurements with an object model / access pattern as close as possible to your real application and take your conclusions.
After saying that, if you'd like to see some benchmarks results you can take a look in the polepos results. Note however that these results are based on an old version of db4o (6.4 instead of current version 7.12) - we expect to publish new results in the near future.
I am sure there are web projects using db4o (for instance jease) but I am not sure exactly how.
Even if db4o performance does not meet your requirements I'd recommend you to not give up on OODBs (generally it make your live - development wise- so much easier). In this case check other options (such VOD - from the same vendor).
I in general agree with Vagaus and the other comments. db4o can replace in some cases, but it really depends on your scenario. An object database is only one tool and doesn't fit all needs. You probably should try it out.
I just want to add a few comments:
As said, db4o is designed for embedded scenarios. For bigger client server databases you probably need to look at other (object) databases.