Forum Discussion
Subform for Subform
PO1 - abc123, def456, ghi789
PO2 - zyx098
PO3 - def456, jkl135
PO4 - qrs369, abc123
CT1 might contain abc123 (PO1), def456 (PO3), jkl135 (PO3), zyx098 (PO2)
CT2 might contain qrs369 (PO4), abc123 (PO4), ghi789 (PO1), def456 (PO3), and zyx098 (PO2)
So you see that some POs are split between containers, and some items are ordered more than once.
I hope that makes some semblance of sense.
Yes, that makes perfect sense and fits with my prior experience, so it sounds right 🙂 too.
It may take a bit to think through all of it, but my first impression is that you need FOUR tables, at the very least:
Container, which identifies each container by some sort of identification code or name. Only attributes of containers are in this table.
PO, which are the orders from customers.
PO Detail, which are the items ordered on each PO. Lists products and quantities of each item for each order.
ContainerPODetail, which is a table for Containers and the item(s) in each PO Detail record.
This allows you to apply the splits you describe.
The ContainerPODetail table will have two Foreign Keys, one from a Container and one from a PO Detail Record. When an item is placed into a container, its Primary Key is entered into a record in this table, along with the Primary Key for the Container into which it is placed. You'll probably also need a field to identify the shipment for which that container is used because, I assume containers are re-used for many shipments (and that calls for a fifth table, by the way, for Shipments). There is no need to put POs in the ContainerPODetail table because they are related to the PODetails and need not be repeated. It also occurs to me that a PO might be split across multiple shipments, so you need to account for that possibility.
I would rather keep all PO Detail items in one container, but I doubt that matches your business reality.
Try that out first by creating the tables and populating a few records manually. See if that raises and problems with the DATA. Once it's clear it works, you can design your tables accordingly.
I think you should separate the tasks. Create one form and subform for POs and PODetails. One to many.
Create another form for Containers and a subform for PODetails. One to many, again.
If a PO can be split across multiple shipments, that calls for an additional main form and subform for them.