Recently I've followed a CQRS workshop which made me wonder how events are stored when using event sourcing.
I think that after every single event the entire application should be in a valid state (otherwise the replay functionality is useless). This means that event should be stored in exactly the order they happened. I also believe that the order of events for all aggregates is important. For example, a user could make a product and an order (product and order both being separate aggregates, order references product through an ID). This means that the 'create product event' should be stored before the 'add product to event'. Otherwise replaying would could lead to an invalid state where the order, referencing the product, exists before the product exists.
How is this situation handled? Should you always send events to the database using a synchronous methods, for example by locking the database? Is this solution scalable? Or should you store events for each aggregate in a different table? But how do you ensure ordering then? Another option would be to store the time for each event, and sort by that. Is the precision of timers on a PC high enough to be able to do that?