At the turn of the century (around a quarter of a decade ago), over 99% of the data management industry used row-oriented storage to store data for all workloads involving structured data — including transactional and analytical workloads. These systems store data from tables row-by-row, so that all data found in the same row are located together. Since each row corresponds to real-world entities (or relationships between those entities), such as users, employees, products, orders, or other read-world “things” or “objects”, storing data row-by-row stores all attributes about those entities together (see figure below).
Storing data row-by-row isn’t the only option. It can also be stored column-by-column (e.g. all names together, all addresses together, etc.). There has always been a niche in the database industry that sold column-oriented database systems (see Chapter 2 from one of my publications from 2013 which goes through the long history starting from the 1970s). However, the early columnar solutions were slower than row-oriented systems for the vast majority of real-world workloads.
This all changed in the early 2000s with the introduction of new approaches to column-storage via projects such as C-Store (my PhD thesis), X100 (from CWI), and other efforts in academia and industry, including: