18-05-22 11:05 AM
Answered! Go to Answer.
19-05-22 12:18 AM
19-05-22 12:18 AM
19-05-22 02:09 PM
Thank you so much @devneetmohanty07, Could you please explain Mark Parent Queue Items As Completed page?
and what is this expression ?
19-05-22 02:21 PM
19-05-22 02:25 PM
19-05-22 02:37 PM
21-05-22 08:49 AM
13-02-25 09:41 AM
@devneetmohanty07 , Thanks for sharing the sample process. It's very helpful. However, I'd like to ask if we can give some advice on a situation where we have three queue sets connected together. For example:
1. I have many clients
2. I have many cases for each client
3. I have many transactions for each case.
The key element is the Case, which should be done in some way in another system, but it is necessary to check if all transakctions exist that are assigned to this case by ref no.
I would have no problem with this if I would like to handle together point 1 and 2 or 2 and 3 or if it were possible to add another collection to the one Item in the Queue, but I think it is not possible.
Do you have any idea or could you advise something to handle this in an efficient way.
I will be grateful for any tips
Many thanks
M
13-02-25 07:36 PM
Hi @Ernest1 ,
Whenever I've dealt with any problem where there is a dependency involved, my general rule of thumb is to start from the lowest atomic level possible, which in this case would be the transactions for each case. Now, the point of your approach should be to first see how many transactions you have in your other system first. So let say you got 500 transactions, what I would do is create 500 items in my Queue A for all these 500 items. Now, each of these transactions definitely should have a case which should be identifiable in some system or a business configuration file or in some database I assume that you should add as the Item key for each item in Queue A.
My next point of approach would be that I simply create another queue called Queue B let say and I will add all the unique cases that I can get from your source to this queue. Here, my Item key would be the name of the client and I will also assign the name/ID of the case as a field value within the queue item.
Ideally, this should be more than enough for you since when you process one item in Queue A, you will know which is the parent item in Queue B, so in your processing workflow, you first pick the first available item in Queue B, fetch case ID/number, use an action to get the next available item based on item key as the case ID from queue B which will return you next available item from queue A and then you process it and the mark the current item from queue A as completed. You again will check if there is any more pending item left from Queue A (if yes, you pick the next available item from queue A based on item key as the case ID from queue B and repeat, if no, you mark the current queue B item as completed and check if you have the next available item from Queue B (if yes, you repeat the steps I mentioned earlier or you go to the finalization steps where you may send out a process report and you can easily get the unique list of clients if needed from the item keys of your processed items in queue B)
I usually prefer to have a separate reporting process altogether when I go for parent-child architecture as it gives me freedom to choose how my reporting needs will get fulfilled. Here, you can see if any cases or transactions are not in exception or in some other state than completed for each of your unique clients and accordingly you can make decisions based on your process rules
17-02-25 06:07 PM
@devneetmohanty07 , thank you for your answer. Do I understand correctly that in such case you suggest to build a solution with the A-Transactions queue as Child (Iterm Key like: Transaction ID + Case ID) and the B-Cases (Item Key like: Case ID + Client ID)?
In my solution I did something like this:
A-Transactions queue as Child (Item Key like: Transaction ID + Case ID + Client ID) and the B-Clients as a Parent (Item Key like: Client ID). Additionally, to retrieve all transactions for one Case from the queue (child queue), I added the Case ID to each Item as a tag. In fact, in my process Client ID = Input File Name
Of course, I will analyze your proposal. Thank you.
I have one more question. Blue Prism templates are prepared to:
1. get an item from the queue
2. perform a task in system A
3. perform a task in system B
4. Mark an item in the queue as Completed /or Exception.
However, it seems to me that a much faster solution may be to switch to system B when all Items in system A are Completed.
Have you ever used such a solution?
The point is that switching between systems may rise the risk of automatic logout or disconnection of system B or A when a task is performed in system A or B respectively.
for example it could look like this:
1. get an element from the queue
2. execute the task in system A and get the next element from the queue.
After executing all the elements, repeat the same actions for system B, i.e. like this:
3. get an element from the queue
4. execute the task in system B and get the next element from the queue.
After executing all the elements from the queue, go to the steps that end the process.
I will be grateful for any suggestions
Many thanks,
Ernest1
