Project requirements #3: Database layout
This is part three on requirements for our blogging engine. See part 1 - the press release and part 2 - Personas
A diversion/pause
At this point in our set, we should be working through our whiteboards or other design options. But, I’m going to tell you a secret. I’ve been thinking about this project for … years. As such, some of our decisions have already been made. For instance, you might have noticed in the press release that we mentioned CouchDB. That’s what we’re going to use as a backend for the following reasons:
- I want to learn how to hook up Couch through Node.
- I eventually want to build a Pouch/React version of the website (that’s not our first version though).
- I eventually want to build a iOS version to test CouchbaseLite and Couch syncing.
I’ve spent time thinking about the database layer – the ‘tables’ or document types. It tends to be how I start my thought process (1. general idea of the functionality. 2. What are the objects that need to be there to express that functionality.)
I’m going to lay that on you now because I want to make sure we’re expressing all of the documents and their contents as part of a design (and, conversely, push design needs back into the document types).
There is at least one table missing at this point: some version of “roles”. We will get that thought out later.
See here: Database tables