I have a BOM table with:
ParentProdID, Qty, ComponentProdID
and two others that need to be joined to the BOM table for conditions ie:
ParentProdID = ProdTable.ProdID ProdTable.TraitCode = SuppTable.TraitDesc
I'd like to have an end table with:
Parent code | Last component
where Parent code fills traits ProdID.A and Trait.B or Trait.C Last component in tree that fills Trait.B (Last component may be a parent that has children, but if none of the children have trait B I want to treat them as leaves)
As far as I can tell, SQL Server should be able to do that, or something close, but I'm pretty new to doing recursion with SQL. Most solutions I've seen use recursive CTEs to print the whole BOM in a hierarchical manner in two columns, which is close, but not quite as clean as I'd like.
Is it possible to make the trait stuff a CTE and refer to that in the (presumably a CTE) that finds the leaves for the parent product?
The parents don't have to be true root nodes and can be anything.
eg. for a BOM of:
Guitar(Wood, EndProduct) -Neck(Wood, Neck) --Strings(Metal, Neck) --Hardware(Metal, Neck) --NeckPiece(Wood, Neck) -Body(Wood, Body) --Bottom(Wood, Body) --Top(Wood, Body)
Parent|Leaf Guitar|NeckPiece Neck|NeckPiece
If this kind of thing isn't possible in SQL server, would printing a list of all of a parent's children along with a depth counter and then arranging the result set so the highest depth ratings are at the top get a functionally identical result for a top-down lookup function like MATCH or VLOOKUP in Excel?