public final class FieldDescriptor
extends java.lang.Object
FieldDescriptor contains the column metadata of the XSQLVAR server
 data structure used to describe one column for input or output.
 
 FieldDescriptor is an immutable type, the value of a field is maintained separately in RowValue.
 
| Constructor and Description | 
|---|
| FieldDescriptor(int position,
               DatatypeCoder datatypeCoder,
               int type,
               int subType,
               int scale,
               int length,
               java.lang.String fieldName,
               java.lang.String tableAlias,
               java.lang.String originalName,
               java.lang.String originalTableName,
               java.lang.String ownerName)Constructor for metadata FieldDescriptor. | 
| Modifier and Type | Method and Description | 
|---|---|
| boolean | equals(java.lang.Object obj) | 
| int | getCharacterLength()The length in characters of this field. | 
| int | getCharacterSetId()Determines the character set id (without collation id). | 
| DatatypeCoder | getDatatypeCoder() | 
| IEncodingFactory | getEncodingFactory() | 
| java.lang.String | getFieldName() | 
| int | getLength() | 
| java.lang.String | getOriginalName() | 
| java.lang.String | getOriginalTableName() | 
| java.lang.String | getOwnerName() | 
| byte | getPaddingByte()Padding to use for fields of this type. | 
| int | getPosition() | 
| int | getScale() | 
| int | getSubType() | 
| java.lang.String | getTableAlias() | 
| int | getType() | 
| int | hashCode() | 
| boolean | isDbKey()Determines if this is a db-key (RDB$DB_KEY) of a table. | 
| boolean | isFbType(int fbType)Check if the type of this field is the specified Firebird data type. | 
| boolean | isNullable() | 
| boolean | isVarying() | 
| java.lang.String | toString() | 
| boolean | typeEquals(FieldDescriptor other)Limited equals that only checks if the data type in the provided field descriptor is the same as this descriptor. | 
public FieldDescriptor(int position,
                       DatatypeCoder datatypeCoder,
                       int type,
                       int subType,
                       int scale,
                       int length,
                       java.lang.String fieldName,
                       java.lang.String tableAlias,
                       java.lang.String originalName,
                       java.lang.String originalTableName,
                       java.lang.String ownerName)
position - Position of this field (0-based), or -1 if position is not known (e.g. for test code)datatypeCoder - Instance of DatatypeCoder to use when decoding column data (note that another instance may be derived
         internally, which then will be returned by getDatatypeCoder())type - Column SQL typesubType - Column subtypescale - Column scalelength - Column defined lengthfieldName - Column alias nametableAlias - Column table aliasoriginalName - Column original nameoriginalTableName - Column original tableownerName - Owner of the column/tablepublic int getPosition()
-1)public DatatypeCoder getDatatypeCoder()
DatatypeCoder to use when decoding field data.public IEncodingFactory getEncodingFactory()
IEncodingFactory for the associated connection.public int getType()
public int getSubType()
public int getScale()
public int getLength()
public java.lang.String getFieldName()
public java.lang.String getTableAlias()
public java.lang.String getOriginalName()
public java.lang.String getOriginalTableName()
public java.lang.String getOwnerName()
public boolean isVarying()
true if the type is variable length (ie ISCConstants.SQL_VARYING).public boolean isFbType(int fbType)
 This method assumes the not-nullable data type is passed, on checking the nullable bit of getType() is
 set to 0.
 
fbType - One of the SQL_ data type identifier valuestrue if the type is the same as the type of this fieldpublic boolean isNullable()
true if this field is nullable.public boolean isDbKey()
 NOTE: Technically it could also be a normal CHAR CHARACTER SET OCTETS column called DB_KEY.
 
true if the field is a RDB$DB_KEYpublic int getCharacterLength()
This takes into account the max bytes per character of the character set.
-1 for non-character types (including blobs)public int getCharacterSetId()
ISCConstants.CS_dynamic
 is returnedpublic boolean typeEquals(FieldDescriptor other)
The fields checked are:
other - Field descriptor to checktrue when other is not null and has the same type definition as this instance,
 false otherwise.public byte getPaddingByte()
public java.lang.String toString()
toString in class java.lang.Objectpublic boolean equals(java.lang.Object obj)
equals in class java.lang.Objectpublic int hashCode()
hashCode in class java.lang.ObjectCopyright © 2001-2024 Jaybird (Firebird JDBC) team. All rights reserved.