How to rematch a geocoded feature class


Rematching a geocoded feature class

After geocoding a table of addresses, you can review the results. If you are not satisfied with the results, you can modify the address locator's settings and try to geocode the table of addresses or records that were not matched again. This process is known as rematching.
There are a number of ways to specify addresses in a geocoded feature class that you want to rematch including:  
  • Only the addresses that are unmatched
  • All the addresses with a match score less than a certain value
  • All the addresses with two or more candidates with the best match score
  • All the addresses
  • Addresses based on a specified query
 
The IBatchGeocoding interface has methods to match a record set or rematch a table.  Usually, you use the IBatchGeocoding interface to rematch a geocoded feature class using the RematchTable method.
The RematchTable method takes a number of parameters. Most of these parameters can be retrieved directly from the AttachedLocator object associated with the geocoded feature class. See the following:
[Java]
// Open an ArcSDE workspace.
IPropertySet connProperties = new PropertySet();
connProperties.setProperty("server", "mendota");
connProperties.setProperty("instance", "esri_sde");
connProperties.setProperty("database", "arcobjects");
connProperties.setProperty("user", "sde");
connProperties.setProperty("password", "sde");
connProperties.setProperty("version", "SDE.Default");
IWorkspaceFactory factory = new SdeWorkspaceFactory();
IFeatureWorkspace featureWorkspace = new IFeatureWorkspaceProxy(factory.open
    (connProperties, 0));


// Open the feature class to rematch.
IFeatureClass pFeatureClass = featureWorkspace.openFeatureClass(
    "arcobjects.SDE.REDLANDS_LOCATION");

// Get the locator that is attached to the feature class.
ILocatorManager pLocatorManager = new LocatorManager();
IAttachedLocator pAttachedLocator = pLocatorManager.getLocatorFromDataset(new
    IDatasetProxy(pFeatureClass));
IBatchGeocoding batchGeocoding = new IBatchGeocodingProxy
    (pAttachedLocator.getLocator());

// Modify the geocoding properties on the locator and rematch the feature class.
IGeocodingProperties pGeocodingProperties = new IGeocodingPropertiesProxy
    (batchGeocoding);
pGeocodingProperties.setMinimumMatchScore(100);

batchGeocoding.rematchTable(pAttachedLocator.getInputTable(),
    pAttachedLocator.getInputFieldNamesList(),
    pAttachedLocator.getInputJoinFieldName(), new IFeatureClassProxy
    (pAttachedLocator.getOutputTable()), pAttachedLocator.getOutputFieldNamesList(),
    pAttachedLocator.getOutputJoinFieldName(), "", null);


See Also:

Location library overview




Development licensing Deployment licensing
Engine Developer Kit Engine Runtime
ArcView ArcView
ArcEditor ArcEditor
ArcInfo ArcInfo