Geoprocessing considerations for attribute domains

This ArcGIS 2.8 documentation has been archived and is no longer updated. Content and links may be outdated. See the latest documentation.

Attribute domains are used to regulate the values permitted in any particular attribute field for a table, feature class, or subtype. Domains are stored in a geodatabase and can be applied to multiple feature classes and tables within the geodatabase.

Depending on your requirements, attribute domains are either applied as range domains or coded value domains. Range domains define a field's minimum and maximum values. They can be used in short, long, float, double, and date attribute fields. Coded value domains specify a valid set of values for an attribute, giving both the allowed actual value and a more easily interpreted description of what the code represents.

The following geoprocessing tools allow you to create and manage attribute domains:

Why is it important to know if attribute domains are present?

The domain assigned to a field in a feature class or table is in many cases still relevant after the feature class or table has been processed. Whenever the output of a tool is not a geodatabase format (such as a shapefile), the fields will not have domains assigned to them.

Learn more about attribute domains

Rules

Domains are only supported in geodatabase tables and feature classes. If the tools below are used in a geodatabase on data with a domain, the output that is generated also has the domain. A conversion to any format other than geodatabase (such as shapefiles and coverages) will succeed, though the output will obviously not have domains.

The following tools support domains when processing features between geodatabases:

When the output is written to a different geodatabase than the input, the domain is copied over into the output geodatabase.

In the circumstance that there is a preexistent domain in the output geodatabase with the same name but different properties, the copied domain will be renamed by appending _<n> (where n is a unique number such as 1).

Related topics