Get started now

Before You Start: Migration Prerequisites

Before exporting a single file, complete these three steps:

1. Finalise your Zoho CRM configuration first. Don’t migrate data into a system that hasn’t been fully configured. Custom fields, picklist values, and module structures need to be in place before data arrives — otherwise you’ll either import into the wrong fields or need to re-import after the configuration is fixed.

2. Assess your existing data quality honestly. Open your current system and look at your records with critical eyes. How many duplicates exist? What percentage of contacts have complete information? Are company names spelled consistently? Are deal stages up to date? The answers determine how much cleaning is required before import.

3. Decide what to migrate and how far back. Not all historical data deserves migration. Records that are years old, marked as lost with no follow-up activity, or incomplete may not be worth the migration effort. Define your cutoff — perhaps all active contacts, plus deals from the last two years — before you start exporting.

Step 1: Export Your Data

From Salesforce: Go to Setup → Data Export → Export Now. Select all relevant objects (Accounts, Contacts, Opportunities, Activities). Salesforce exports in CSV format with all fields included.

From HubSpot: Go to Contacts/Companies/Deals → Actions → Export. HubSpot exports include all properties. For activity history, export separately from the timeline view.

From Pipedrive: Go to Settings → Data Export. Pipedrive exports deals, contacts, organisations, and activities as separate CSV files.

From spreadsheets: Structure your data in separate sheets for contacts, companies, and deals before starting the mapping process.

Step 2: Create Your Field Mapping Document

A field mapping document is a table that shows exactly which field in your source system corresponds to which field in Zoho CRM. This is the most important preparation step and the one most frequently skipped.

Your mapping document should cover:

  • Every field in your source system that you’re migrating
  • The corresponding Zoho CRM field (module, field name, field type)
  • Any transformation required (e.g., date format conversion, picklist value renaming)
  • Fields in your source system with no Zoho equivalent that need a custom field created

Pay particular attention to:

Picklist values. If your source system uses “New Business” as a lead source but Zoho uses “Cold Call,” every record with “New Business” will either fail to import or land in the wrong category. Map every picklist value before importing.

Date formats. Different systems store dates differently. Zoho CRM expects dates in a specific format — confirm this before import to avoid widespread date errors.

Relationship fields. Zoho links Contacts to Accounts, and Deals to Contacts and Accounts. Your mapping needs to preserve these relationships — typically done by ensuring the Account name is consistent across all related records.

Phone number formats. Standardise phone number formatting (e.g., +1 xxx-xxx-xxxx) before import to avoid inconsistency in your new system.

Step 3: Clean Your Data Before Importing

Data cleaning before import is significantly easier than cleaning after. Zoho’s interface is designed for working with individual records, not bulk data editing.

Remove obvious duplicates. Sort your contact export by email address or phone number and identify records that appear more than once. Merge or delete duplicates before importing.

Standardise company names. “ABC Corp”, “ABC Corporation”, “ABC Corp.” and “ABC Corp” are four different companies in an unvalidated dataset. Standardise these before import or your Account records will fragment.

Fill critical gaps. Identify required fields in your Zoho configuration and ensure every record has a value for them. Records missing required fields will fail to import.

Normalise picklist values. Using your field mapping document, update your source data so all picklist values match their Zoho equivalents. This can be done with find-and-replace in Excel/Google Sheets.

Step 4: Import in the Correct Sequence

Import order matters because Zoho CRM needs parent records to exist before child records can be linked to them.

Correct import sequence:

  • Accounts/Companies — import first, as Contacts and Deals will reference them
  • Contacts — import second, with Account Name field matching your Accounts exactly
  • Deals/Opportunities — import third, referencing both Contact Name and Account Name
  • Activities — import last, referencing the Contacts and Deals they relate to

Importing in any other order means records can’t form their relationships correctly and will either fail or arrive as orphaned records.

Use Zoho’s import tool: Go to the relevant module → Import → Upload your CSV. The import wizard allows you to map source columns to Zoho fields and preview the import before committing. Always use the preview — it surfaces mapping errors before they affect your data.

Step 5: Validate Your Imported Data

Don’t mark migration complete until you’ve validated what arrived.

Spot-check 20–30 records per module. Select a sample of records from your source system and find the same records in Zoho. Verify that all fields migrated correctly, relationships are intact, and no data was truncated or corrupted.

Check relationship integrity. Open several Deals and confirm they’re linked to the correct Contacts and Accounts. Open several Contacts and confirm they’re linked to the correct Account.

Verify activity history. Check that historical emails, calls, and notes arrived against the correct records with the correct timestamps.

Run a duplicate report. Zoho CRM has a built-in duplicate detection tool. Run it after import to identify any duplicates that survived your pre-import cleaning.

Check picklist values. Review records and confirm that picklist fields show the expected values rather than blank or error states.

Migration From Specific Platforms

Migrating from Salesforce: The most complex migration type due to Salesforce’s extensive custom object and field structures. Field mapping is typically the most time-consuming step. Data export is comprehensive. See also: Zoho CRM vs Salesforce →

Migrating from HubSpot: HubSpot’s export is clean and well-structured. The main challenge is HubSpot’s contact-company relationship model, which differs slightly from Zoho’s. Map carefully. See also: Zoho CRM vs HubSpot →

Migrating from Pipedrive: Pipedrive exports are straightforward. The main challenge is that Pipedrive’s “Persons” and “Organisations” map to Zoho’s “Contacts” and “Accounts” respectively — rename columns accordingly before import.

Migrating from spreadsheets: Spreadsheet migrations are technically simple to execute. The real effort is in the data itself — spreadsheets tend to accumulate inconsistent naming, missing fields, and informal formatting that needs to be resolved before anything comes into Zoho. Budget more time for cleaning than for the import itself.

When to Get Professional Migration Help

DIY migration works well for small datasets (under 5,000 records) with clean, well-structured source data and a straightforward single-object structure.

Consider professional migration support when:

  • Your dataset is large (10,000+ records)
  • Your data is coming from Salesforce with extensive customisation
  • Your source data has significant quality issues requiring substantial cleaning
  • You have complex relationship structures between multiple object types
  • You can’t afford any downtime or data loss during the transition

Our Zoho CRM migration service handles the complete process including mapping, cleaning, import, validation, and go-live support.

Talk to Our Migration Team

Zoho One Premium Partner Image

Frequently Asked Questions

Do I need to migrate all my historical data?

Historical data is worth migrating when your team will genuinely reference it — active contacts, recent deals, and the last two to three years of activity history. Records from years ago that are inactive, incomplete, or marked as lost rarely justify the cleaning effort they require. Define your cutoff before exporting and stick to it.

How long does a Zoho CRM migration take?

Small, clean datasets (under 2,000 records, single source system) can be completed in a few days. Large migrations from Salesforce with extensive custom objects, or any dataset requiring significant data cleaning, typically take two to four weeks. The cleaning phase — not the import itself — is where most of the time goes.

Can I migrate if I'm still configuring Zoho?

Complete your Zoho configuration first. Custom fields, picklist values, and module structures must exist before data arrives. Importing into an incomplete configuration means re-importing later.