I categorized a table with the method introduced here to categorize my items to folders with a limit size of 100.
mixing_order id num_items cat order_in_cat cumulative_sum folder
1 1 4 1 1 4 1
2 2 33 1 2 37 1
3 3 74 2 1 74 2
4 4 41 1 3 41 3
5 5 24 1 4 65 3
6 6 44 2 2 44 4
7 7 16 1 5 57 4
8 8 55 1 6 55 5
9 9 11 1 7 66 5
10 10 37 1 8 37 6
Now, I want to go further and re-arrange the rows to better fit within folders. Consider that the records are of two categories (indicated by column cat
). We can make a better fit just by altering the order of mixing
. Then, we can produce the following table as each folder has a cumulative_sum
close to the folder size limit (i.e. 100 here). As you can see, the order in each category (order_in_cat
) has not been changed, only the order that the rows from different categories are mixed.
mixing_order id num_items cat order_in_cat cumulative_sum folder
1 1 4 1 1 4 1
2 2 33 1 2 37 1
3 4 41 1 3 78 1
4 3 74 2 1 74 2
5 5 24 1 4 98 2
6 7 16 1 5 16 3
7 8 55 1 6 67 3
8 9 11 1 7 78 3
9 6 44 2 2 44 4
10 10 37 1 8 81 4
In other words, the mixing_order
was random in order of INSERT
, but now we want to re-arrange the mixing_order
to best fit within folder.
Probably, we need a loop in which re-calculating SUM
to find the best match out of possible choices, but I have no idea how to conduct such loop in SQL
.
Best Answer
Here it the code from @DTest's Answer
Staring at this query, I would shudder to even think about writing of a Stored Procedure Technique for fitting items in folders. Then, it hit me ...
You could simply take the same query and
ORDER BY num_items
. That would actually pack as many items into a folder as possible before switching to another folder.This packing would be somewhat lopsided in iterms of the number of entries per folder but the sum of the items per folder are pressed as close to 100 as possible.
Please note that if you want later folder with more items, simply change
ORDER BY num_items
toORDER BY num_items DESC
.Give it a Try !!!
UPDATE 2013-01-09 12:52 EDT
What you need are three(3) mechanisms:
Here is the new code:
Here is it execution:
Give it a Try !!!