Multiversion concurrency control (MCC or MVCC), is a non-locking concurrency control method commonly used by database management systems to provide concurrent access to the database and in programming languages to implement transactional memory.[1] Without concurrency control, if someone is reading from a database at the same time as someone else is writing to it, it is possible that the reader wi