How can I have one insert statement and call procedure after FORALL in plsql?
I have the following in procedure
FORALL indx IN p_product.FIRST .. p_product.LAST
        INSERT INTO   my_table
              VALUES   (p_product(indx),p_product_desc(indx),p_msg);
After the insert I would like to call another procedure which inserts values into another table.
remove_dup_products(p_product(indx));
When I had tried to call the above procedure after insert statement, I am getting error
INDX must be declared
 
                        
A FORALL statement is just that; a statement; you can only do one thing in it. You have to loop through your type again.
It's worth nothing that you're not doing two DML statements; you're doing one and calling a procedure. You cannot therefore use FORALL twice, you have to use a regular for loop.
If you're only doing DML in the second procedure you could pass in the entire collection and then use FORALL then. You would need to declare a global variable:
and then you could reuse this everywhere