Document your process for your own reference

Document your process for your own reference

I am writing this article over a week late, having been deeply immersed in a project that made me rethink my approach to documentation. I will begin by discussing documentation in the “traditional” sense, as I have practiced it for the past 10 years. In the context of a data project, my personal documentation serves several key purposes:

  • Tracking project decisions
  • Documenting exceptions made, along with justifications
  • Recording reasons for delays, if any
  • Organizing and preserving important emails
  • Summarizing key meetings
  • Technical documentation to be handed over to the client

Technical documentation is always valuable - for the developer and for the client.

One instance where thorough documentation saved me was during a migration project, which I have previously written about. I ended up working two weeks over the original budget due to various factors, primarily a lack of time and support from the business side, as well as additional features not included in the original project scope. When my boss questioned why I billed for an extra ten days, I was able to justify it using my detailed notes. I could explain how much time the extra features took and the delays caused by waiting for business validation. My boss, understanding the situation, shared this information with the client, whose IT team agreed on the value of the added features, and the client covered the additional days.

I have many similar examples where, months after a decision was made, the client forgot why we took certain actions. This is especially common when dealing with exceptions—many clients believe their data is flawless. In reality, I frequently encounter outliers and exceptions, whether in data engineering or dashboarding. With my current approach to documentation, I’ve always been able to remind clients of the decisions we made and the reasons behind them. ?

However, a recent project highlighted a blind spot in my approach. While I create meticulous documentation to track project milestones and decisions, I hadn’t fully considered the importance of the client’s own documentation. Let me explain with an example.

I was wrapping up a data warehousing project where I had to deliver data warehouse entities like dimension and fact tables, as well as de-normalized tables for analytics. At the beginning of the project, the client shared a document detailing their expected deliverables, including definitions of the various tables. This document resided in their SharePoint. Over the course of six months of development, I made the decision to split one of the fact tables into two, as it represented two distinct types of facts. This change made sense, as I would create two separate de-normalized tables in the analytics layer anyway. I documented this decision and had emails confirming that the client had validated the new architecture.

However, when it came time to deliver the project in early October, I realized my mistake: I hadn’t referred to the client’s original document often enough. The way I split the fact table conflicted with another analytics project that would be using the data warehouse downstream. The fact that the project had other downstream users was mentioned during the project kick-off, I had forgotten about it. The lesson here is clear: always refer back to the original project documentation.

This experience made me realize that a bigger mistake than failing to document is not revisiting the existing documentation. It’s easy to begin a project with a shared understanding, only to deviate from that understanding over time because we forget previously established decisions or constraints. In such cases, the client can come back to us and request additional work, claiming we diverged from the specs, even though the deviation was approved at some point.


I once read, “The faintest ink is more powerful than the strongest memory,” and I’ve always lived by this mantra. I strive to document as much detail as possible. However, the example I shared—which brought significant stress, anxiety, and a week of lost billable hours—taught me that documenting solely for myself is not enough. To ensure project alignment, I must:

  • Verify that the client, at all levels, shares the same understanding of the project details and decisions as I do.
  • Regularly consult the original documentation throughout the project, ensuring that all new decisions align with the initial parameters and avoid unintended conflicts.

I hope this piece encourages you to continue documenting your work, but also to consult the documentation from time to time, and avoid drifting from the original project scope or decisions made along the way.

See you next week for lesson 6 of 10.

For reference, the original post : https://www.dhirubhai.net/feed/update/urn:li:activity:7239299421488754692/

要查看或添加评论,请登录

社区洞察

其他会员也浏览了