In this topic
Each table in a database has an ordered collection of fields; there is always at least one field in a table. The ordered collection behaves like a list; therefore, it is possible to access individual fields by a numbered position (or index) in the list.
A Fields collection can also exist independently of a table; for example, when creating an index on a table, you need to define which fields take part in the index. Many interfaces either require or return a Fields collection; these include IClass (therefore, also IObjectClass and IFeatureClass), ICursor, IIndex, IFeatureClassDraw, IRowBuffer, ISimpleDataConverter, ITableSort, and IValidate.
The IFields interface provides information about a Fields collection and provides access to individual fields. The following code example finds any fields in a feature class that have a distinct alias name:
[Java]
static void printDistinctFieldAliasNames(IFeatureClass featureClass)throws Exception{
// get the Fields collection from the feature class
IFields fields = featureClass.getFields();
IField field;
// on a zero based index iterate through the fields in the collection
for (int i = 0; i < fields.getFieldCount(); i++){
// get the field at the given index
field = fields.getField(i);
if (!field.getName().equals(field.getAliasName())){
System.out.println(field.getName() + ":" + field.getAliasName());
}
}
}
When using IFields.FindField, remember that there are equivalent methods on IClass and ICursor—shortcuts that save you from having to get the Fields collection.
The following code example shows how you can get a reference to a specific field in a collection using the field's name:
[Java]
static IField getFieldByName(IFeatureClass featureClass, String fieldName)throws
Exception{
// Get the feature class' fields collection.
IFields fields = featureClass.getFields();
// Find the index of the requested field, access it, and return it.
int fieldIndex = fields.findField(fieldName);
IField field = fields.getField(fieldIndex);
return field;
}
A field has many properties; the most obvious ones are the name and data types. The esriFieldType enumeration lists the possible data types.
The IField interface is used for read-only access to the field's properties.
In the following code example, the IField interface is used to print the properties of each field in a feature class. If the field is of the type of esriFieldType::esriFieldTypeGeometry, the IField.GeometryDef property is used to return the geometry definition (IGeometryDef).
Field objects do not provide access to all Arc/INFO-based data types (coverages) and attributes. If access to coverage-specific characteristics is required, use the IArcInfoItem interface.
static void displayFieldProperties(IFeatureClass featureClass)throws Exception{
// Get the fields collection for the feature class.
IFields fields = featureClass.getFields();
IField field = null;
for (int i = 0; i < fields.getFieldCount(); i++){
field = fields.getField(i);
// Get the standard field properties.
System.out.println("Name: " + field.getName());
System.out.println("Alias: " + field.getAliasName());
System.out.println("Type: " + field.getType());
System.out.println("VarType: " + field.getVarType());
System.out.println("Default Value: " + field.getDefaultValue());
System.out.println("Length: " + field.getLength());
System.out.println("Precision: " + field.getPrecision());
System.out.println("Scale: " + field.getScale());
System.out.println("Is Editable: " + field.isEditable());
System.out.println("Is Nullable: " + field.isNullable());
System.out.println("Is Required: " + field.isRequired());
// Check if the field is the shape field.
if (field.getType() == esriFieldType.esriFieldTypeGeometry){
IGeometryDef geometryDef = field.getGeometryDef();
System.out.println("Geometry Type: " + geometryDef.getGeometryType());
System.out.println("Has M Values: " + geometryDef.isHasM());
System.out.println("Has Z Values: " + geometryDef.isHasZ());
}
// Insert an empty line for readability.
System.out.println();
}
}
See Also:
How to create new fieldsHow to display field properties for a feature class
Development licensing | Deployment licensing |
---|---|
ArcGIS for Desktop Basic | ArcGIS for Desktop Basic |
ArcGIS for Desktop Standard | ArcGIS for Desktop Standard |
ArcGIS for Desktop Advanced | ArcGIS for Desktop Advanced |
Engine Developer Kit | Engine |