Deluge Script In CRM To Deal With More Than 200 Records

Deluge Script In CRM To Deal With More Than 200 Records

Hi,

I have a Deluge script, which works perfectly. We have a custom field in the Campaigns module called Total_Raised which looks at the Donation_Amount field in the custom module, Donations. The idea is to sum up the total of all donation amounts.

However, it stops at 200 records, the Zoho default cut-off, as I understand it. Is there any way of being able to search through more than 200 records, possibly up to 2000? My existing working code is:

  1. void automation.UpdateDonationTotal(Int campaignId)
  2. {
  3.     if(campaignId != null)
  4.     {
  5.         // Fetch related donations for the given Campaign ID
  6.         donations = zoho.crm.getRelatedRecords("Donations", "Campaigns", campaignId, 1, 200);

  7.         // Initialize the total amount
  8.         totalRaised = 0.0;

  9.         // Iterate over each donation and sum the Donation Amount
  10.         for each donation in donations
  11.         {
  12.             if(donation.get("Donation_Amount") != null)
  13.             {
  14.                 totalRaised = totalRaised + donation.get("Donation_Amount");
  15.             }
  16.         }

  17.         // Fetch the current Campaign record to compare Total_Raised
  18.         campaignRecord = zoho.crm.getRecordById("Campaigns", campaignId);
  19.         existingTotal = campaignRecord.get("Total_Raised");

  20.         // Debugging log
  21.         info "Campaign ID: " + campaignId;
  22.         info "Total Raised (calculated): " + totalRaised;
  23.         info "Existing Total Raised: " + existingTotal;

  24.         // Update only if the calculated value differs from the existing value
  25.         if(existingTotal != totalRaised)
  26.         {
  27.             // Prepare data for updating the Campaign's Total Raised field
  28.             updateMap = Map();
  29.             updateMap.put("Total_Raised", totalRaised);

  30.             // Update the Campaign record
  31.             response = zoho.crm.updateRecord("Campaigns", campaignId, updateMap);

  32.             if(response.get("code") == "SUCCESS")
  33.             {
  34.                 info "Successfully updated Total Raised for Campaign ID: " + campaignId;
  35.             }
  36.             else
  37.             {
  38.                 info "Failed to update Total Raised for Campaign ID: " + campaignId + ". Response: " + response;
  39.             }
  40.         }
  41.         else
  42.         {
  43.             info "No update needed. Total Raised is already correct.";
  44.         }
  45.     }
  46.     else
  47.     {
  48.         info "Invalid Campaign ID: " + campaignId;
  49.     }
  50. }
Is there any way we can search more than 200 records and make the calculation? 
    • Sticky Posts

    • Function #46: Auto-Calculate Sales Margin on a Quote

      Welcome back everyone! Last week's function was about displaying the discount amount in words. This week, it's going to be about automatically calculating the sales margin for a particular quote, sales order or an invoice. Business scenario Where there is sales, there's also evaluation and competition between sales reps. A healthy rivalry helps to better motivate your employees to do smart work and close deals faster and more efficiently. But how does a sales rep get evaluated? 90% of the time, it's
    • Zoho CRM Functions 53: Automatically name your Deals during lead conversion.

      Welcome back everyone! Last week's function was about automatically updating the recent Event date in the Accounts module. This week, it's going to be about automatically giving a custom Deal name whenever a lead is converted. Business scenario Deals are the most important records in CRM. After successful prospecting, the sales cycle is followed by deal creation, follow-up, and its subsequent closure. Being a critical function of your sales cycle, it's good to follow certain best practices. One such
    • User Tips: Auto-Create Opportunity/Deal upon Quote Save (PART 1)

      Problem: We use quotes which convert to sales orders but Users / Sales Reps do not create opportunities / deals and go straight to creating a quote. This leads to poor reporting. Implementing this solution improves reporting and makes it easier for users.
    • Custom Function : Automatically send the Quote to the related contact

      Scenario: Automatically send the Quote to the related contact.  We create Quotes for customers regularly and when we want to send the quote to the customer, we have to send it manually. We can automate this, using Custom Functions. Based on a criteria, you can trigger a workflow rule and the custom function associated to the rule and automatically send the quote to customer through an email. Please note that the quote will be sent as an inline email content and not as a PDF attachment. Please follow
    • Function #50: Schedule Calls to records

      Welcome back everyone! Last week's function was about changing ownership of multiple records concurrently. This week, it's going to be about scheduling calls for records in various modules. Business scenario Calls are an integral part of most sales routines.. Sales, Management, Support, all the branches of the business structure would work in cohesion only through calls. You could say they are akin to engine oil, which is required by the engine to make all of it's components function perfectly. CRM