Published 2021-02-13.
Last modified 2021-03-28.
Time to read: 1 minutes.
django
collection.
A complete set of standard entity relationship diagrams
for django-oscar
webapps has at least 161 tables.
This is how I counted them:
$ psql -U postgres -h localhost -d frobshop \ -tc "select count(*) as tables from information_schema.tables where table_type = 'BASE TABLE';" 161
I used Dbeaver to create the following entity relationship diagrams of the django-oscar
schema.
There were too many table to examine in one diagram, so I examined them piecemeal.
Update 2021-03-28: When I first saw the table names I could not understand the naming convention.
After having spent some time looking at the source code and playing with the software,
I now believe that a table name is constructed from a Django app name,
concatenated with the corresponding app model's class name, like this:
{appname}_{classname}
.
If a class field joins to another class, the naming convention becomes:
{appname}_{classname}{join_table_name}
The remainder of this article shows most of the 161 django-oscar
tables.
Some tables are shown more than once in the interest of clarity.
address_country
data:image/s3,"s3://crabby-images/612e9/612e93b6ff92ce9d8fd96bef04259b489ff803b2" alt="Centered around the <code>address_country</code> table Centered around the <code>address_country</code> table"
address_country
table
auth_user
data:image/s3,"s3://crabby-images/e2c2f/e2c2f679b1ca4642f4eb38c7d0c9f917888486fb" alt="Centered around the <code>auth_user</code> table Centered around the <code>auth_user</code> table"
auth_user
table
basket_basket
data:image/s3,"s3://crabby-images/5d479/5d479184307bfea340428c2512544213567aa875" alt="Centered around the <code>basket_basket</code> table Centered around the <code>basket_basket</code> table"
basket_basket
table
catalogue_product
data:image/s3,"s3://crabby-images/a058e/a058eab6c064d3f189bf0fec08d9c40a6c1c21a3" alt="Centered around the <code>catalogue_product</code> table Centered around the <code>catalogue_product</code> table"
catalogue_product
table
offer_range
data:image/s3,"s3://crabby-images/2e982/2e982e9335c290a24f2a2bd591b56562d7b57d63" alt="Centered around the <code>offer_range</code> table Centered around the <code>offer_range</code> table"
offer_range
table
order_order
data:image/s3,"s3://crabby-images/c0c94/c0c94257521741661c15c6ad431b52774a467de1" alt="Centered around the <code>order_order</code> table Centered around the <code>order_order</code> table"
order_order
table
partner_partner
data:image/s3,"s3://crabby-images/ccae0/ccae0171520f5053eb571b085764711992315291" alt="Centered around the <code>partner_partner</code> table Centered around the <code>partner_partner</code> table"
partner_partner
table
payment_source
data:image/s3,"s3://crabby-images/56681/5668103dfcc8baf9a3bf8fe83a54acbaec76be0e" alt="Centered around the <code>payment_source</code> table Centered around the <code>payment_source</code> table"
payment_source
table
shipping
data:image/s3,"s3://crabby-images/efbca/efbca432b1a54c7aa924da053c4c83f467426919" alt="Centered around the <code>shipping</code> table Centered around the <code>shipping</code> table"
shipping
table
voucher_voucher
data:image/s3,"s3://crabby-images/52161/5216196400f9be36787d0ee0f4eb95795d447477" alt="Centered around the <code>voucher_voucher</code> table Centered around the <code>voucher_voucher</code> table"
voucher_voucher
table
wishlists_wishlist
data:image/s3,"s3://crabby-images/63783/637832121ad72a4901e8f9b9b586e87458707a7f" alt="Centered around the <code>wishlists_wishlist</code> table Centered around the <code>wishlists_wishlist</code> table"
wishlists_wishlist
table