Package com.gpudb.protocol
Class AppendRecordsRequest
java.lang.Object
com.gpudb.protocol.AppendRecordsRequest
All Implemented Interfaces:
org.apache.avro.generic.GenericContainer, org.apache.avro.generic.IndexedRecordA set of parameters for
GPUdb.appendRecords.
Append (or insert) all records from a source table (specified by sourceTableName) to a particular target table (specified by tableName). The field map (specified by fieldMap) holds the user specified map of target table column names with their mapped source column names.
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic final classA set of string constants for theAppendRecordsRequestparameteroptions.Constructor Summary
ConstructorsMethod Summary
Modifier and TypeMethodDescriptionbooleanget(int index) This method supports the Avro framework and is not intended to be called directly by the user.static org.apache.avro.SchemaThis method supports the Avro framework and is not intended to be called directly by the user.Contains the mapping of column names from the target table (specified bytableName) as the keys, and corresponding column names or expressions (e.g., ‘col_name+1’) from the source table (specified bysourceTableName).Optional parameters.org.apache.avro.SchemaThis method supports the Avro framework and is not intended to be called directly by the user.The source table name to get records from, in [schema_name.]table_name format, using standard name resolution rules.The table name for the records to be appended, in [schema_name.]table_name format, using standard name resolution rules.inthashCode()voidThis method supports the Avro framework and is not intended to be called directly by the user.setFieldMap(Map<String, String> fieldMap) Contains the mapping of column names from the target table (specified bytableName) as the keys, and corresponding column names or expressions (e.g., ‘col_name+1’) from the source table (specified bysourceTableName).setOptions(Map<String, String> options) Optional parameters.setSourceTableName(String sourceTableName) The source table name to get records from, in [schema_name.]table_name format, using standard name resolution rules.setTableName(String tableName) The table name for the records to be appended, in [schema_name.]table_name format, using standard name resolution rules.toString()
Constructor Details
AppendRecordsRequest
public AppendRecordsRequest()Constructs an AppendRecordsRequest object with default parameters.AppendRecordsRequest
public AppendRecordsRequest(String tableName, String sourceTableName, Map<String, String> fieldMap, Map<String, String> options) Constructs an AppendRecordsRequest object with the specified parameters.Parameters:tableName- The table name for the records to be appended, in [schema_name.]table_name format, using standard name resolution rules. Must be an existing table.sourceTableName- The source table name to get records from, in [schema_name.]table_name format, using standard name resolution rules. Must be an existing table name.fieldMap- Contains the mapping of column names from the target table (specified bytableName) as the keys, and corresponding column names or expressions (e.g., ‘col_name+1’) from the source table (specified bysourceTableName). Must be existing column names in source table and target table, and their types must be matched. For details on using expressions, see Expressions.options- Optional parameters.OFFSET: A positive integer indicating the number of initial results to skip fromsourceTableName. Default is 0. The minimum allowed value is 0. The maximum allowed value is MAX_INT. The default value is ‘0’.LIMIT: A positive integer indicating the maximum number of results to be returned fromsourceTableName. Or END_OF_SET (-9999) to indicate that the max number of results should be returned. The default value is ‘-9999’.EXPRESSION: Filter expression to apply to thesourceTableName. The default value is ”.ORDER_BY: Comma-separated list of the columns to be sorted by from source table (specified bysourceTableName), e.g., ‘timestamp asc, x desc’. TheORDER_BYcolumns do not have to be present infieldMap. The default value is ”.UPDATE_ON_EXISTING_PK: Specifies the record collision policy for inserting source table records (specified bysourceTableName) into a target table (specified bytableName) with a primary key. If set toTRUE, any existing table record with primary key values that match those of a source table record being inserted will be replaced by that new record (the new data will be “upserted”). If set toFALSE, any existing table record with primary key values that match those of a source table record being inserted will remain unchanged, while the source record will be rejected and an error handled as determined byIGNORE_EXISTING_PK. If the specified table does not have a primary key, then this option has no effect. Supported values:TRUE: Upsert new records when primary keys match existing records.FALSE: Reject new records when primary keys match existing records.
FALSE.ENABLE_INPLACE_UPDATES: Applies only when upserting (whenUPDATE_ON_EXISTING_PKisTRUE). If set toTRUE, an existing record matched by primary key is modified in place. If set toFALSE, it is updated by deleting the existing record and inserting a replacement (delete and insert), which prevents the change from being reflected in dependent materialized views until they are refreshed. Supported values:The default value isTRUE.IGNORE_EXISTING_PK: Specifies the record collision error-suppression policy for inserting source table records (specified bysourceTableName) into a target table (specified bytableName) with a primary key, only used when not in upsert mode (upsert mode is disabled whenUPDATE_ON_EXISTING_PKisFALSE). If set toTRUE, any source table record being inserted that is rejected for having primary key values that match those of an existing target table record will be ignored with no error generated. IfFALSE, the rejection of any source table record for having primary key values matching an existing target table record will result in an error being raised. If the specified table does not have a primary key or if upsert mode is in effect (UPDATE_ON_EXISTING_PKisTRUE), then this option has no effect. Supported values:TRUE: Ignore source table records whose primary key values collide with those of target table records.FALSE: Raise an error for any source table record whose primary key values collide with those of a target table record.
FALSE.PK_CONFLICT_PREDICATE_HIGHER: The record with higher value for the column resolves the primary-key insert conflict. The default value is ”.PK_CONFLICT_PREDICATE_LOWER: The record with lower value for the column resolves the primary-key insert conflict. The default value is ”.TRUNCATE_STRINGS: If set toTRUE, it allows inserting longer strings into smaller charN string columns by truncating the longer strings to fit. Supported values:The default value isFALSE.
Map.
Method Details
getClassSchema
public static org.apache.avro.Schema getClassSchema()This method supports the Avro framework and is not intended to be called directly by the user.Returns:The schema for the class.getTableName
The table name for the records to be appended, in [schema_name.]table_name format, using standard name resolution rules. Must be an existing table.Returns:The current value oftableName.setTableName
The table name for the records to be appended, in [schema_name.]table_name format, using standard name resolution rules. Must be an existing table.Parameters:tableName- The new value fortableName.Returns:thisto mimic the builder pattern.getSourceTableName
The source table name to get records from, in [schema_name.]table_name format, using standard name resolution rules. Must be an existing table name.Returns:The current value ofsourceTableName.setSourceTableName
The source table name to get records from, in [schema_name.]table_name format, using standard name resolution rules. Must be an existing table name.Parameters:sourceTableName- The new value forsourceTableName.Returns:thisto mimic the builder pattern.getFieldMap
Contains the mapping of column names from the target table (specified bytableName) as the keys, and corresponding column names or expressions (e.g., ‘col_name+1’) from the source table (specified bysourceTableName). Must be existing column names in source table and target table, and their types must be matched. For details on using expressions, see Expressions.Returns:The current value offieldMap.setFieldMap
Contains the mapping of column names from the target table (specified bytableName) as the keys, and corresponding column names or expressions (e.g., ‘col_name+1’) from the source table (specified bysourceTableName). Must be existing column names in source table and target table, and their types must be matched. For details on using expressions, see Expressions.Parameters:fieldMap- The new value forfieldMap.Returns:thisto mimic the builder pattern.getOptions
Optional parameters.OFFSET: A positive integer indicating the number of initial results to skip fromsourceTableName. Default is 0. The minimum allowed value is 0. The maximum allowed value is MAX_INT. The default value is ‘0’.LIMIT: A positive integer indicating the maximum number of results to be returned fromsourceTableName. Or END_OF_SET (-9999) to indicate that the max number of results should be returned. The default value is ‘-9999’.EXPRESSION: Filter expression to apply to thesourceTableName. The default value is ”.ORDER_BY: Comma-separated list of the columns to be sorted by from source table (specified bysourceTableName), e.g., ‘timestamp asc, x desc’. TheORDER_BYcolumns do not have to be present infieldMap. The default value is ”.UPDATE_ON_EXISTING_PK: Specifies the record collision policy for inserting source table records (specified bysourceTableName) into a target table (specified bytableName) with a primary key. If set toTRUE, any existing table record with primary key values that match those of a source table record being inserted will be replaced by that new record (the new data will be “upserted”). If set toFALSE, any existing table record with primary key values that match those of a source table record being inserted will remain unchanged, while the source record will be rejected and an error handled as determined byIGNORE_EXISTING_PK. If the specified table does not have a primary key, then this option has no effect. Supported values:TRUE: Upsert new records when primary keys match existing records.FALSE: Reject new records when primary keys match existing records.
FALSE.ENABLE_INPLACE_UPDATES: Applies only when upserting (whenUPDATE_ON_EXISTING_PKisTRUE). If set toTRUE, an existing record matched by primary key is modified in place. If set toFALSE, it is updated by deleting the existing record and inserting a replacement (delete and insert), which prevents the change from being reflected in dependent materialized views until they are refreshed. Supported values:The default value isTRUE.IGNORE_EXISTING_PK: Specifies the record collision error-suppression policy for inserting source table records (specified bysourceTableName) into a target table (specified bytableName) with a primary key, only used when not in upsert mode (upsert mode is disabled whenUPDATE_ON_EXISTING_PKisFALSE). If set toTRUE, any source table record being inserted that is rejected for having primary key values that match those of an existing target table record will be ignored with no error generated. IfFALSE, the rejection of any source table record for having primary key values matching an existing target table record will result in an error being raised. If the specified table does not have a primary key or if upsert mode is in effect (UPDATE_ON_EXISTING_PKisTRUE), then this option has no effect. Supported values:TRUE: Ignore source table records whose primary key values collide with those of target table records.FALSE: Raise an error for any source table record whose primary key values collide with those of a target table record.
FALSE.PK_CONFLICT_PREDICATE_HIGHER: The record with higher value for the column resolves the primary-key insert conflict. The default value is ”.PK_CONFLICT_PREDICATE_LOWER: The record with lower value for the column resolves the primary-key insert conflict. The default value is ”.TRUNCATE_STRINGS: If set toTRUE, it allows inserting longer strings into smaller charN string columns by truncating the longer strings to fit. Supported values:The default value isFALSE.
Map.Returns:The current value ofoptions.setOptions
Optional parameters.OFFSET: A positive integer indicating the number of initial results to skip fromsourceTableName. Default is 0. The minimum allowed value is 0. The maximum allowed value is MAX_INT. The default value is ‘0’.LIMIT: A positive integer indicating the maximum number of results to be returned fromsourceTableName. Or END_OF_SET (-9999) to indicate that the max number of results should be returned. The default value is ‘-9999’.EXPRESSION: Filter expression to apply to thesourceTableName. The default value is ”.ORDER_BY: Comma-separated list of the columns to be sorted by from source table (specified bysourceTableName), e.g., ‘timestamp asc, x desc’. TheORDER_BYcolumns do not have to be present infieldMap. The default value is ”.UPDATE_ON_EXISTING_PK: Specifies the record collision policy for inserting source table records (specified bysourceTableName) into a target table (specified bytableName) with a primary key. If set toTRUE, any existing table record with primary key values that match those of a source table record being inserted will be replaced by that new record (the new data will be “upserted”). If set toFALSE, any existing table record with primary key values that match those of a source table record being inserted will remain unchanged, while the source record will be rejected and an error handled as determined byIGNORE_EXISTING_PK. If the specified table does not have a primary key, then this option has no effect. Supported values:TRUE: Upsert new records when primary keys match existing records.FALSE: Reject new records when primary keys match existing records.
FALSE.ENABLE_INPLACE_UPDATES: Applies only when upserting (whenUPDATE_ON_EXISTING_PKisTRUE). If set toTRUE, an existing record matched by primary key is modified in place. If set toFALSE, it is updated by deleting the existing record and inserting a replacement (delete and insert), which prevents the change from being reflected in dependent materialized views until they are refreshed. Supported values:The default value isTRUE.IGNORE_EXISTING_PK: Specifies the record collision error-suppression policy for inserting source table records (specified bysourceTableName) into a target table (specified bytableName) with a primary key, only used when not in upsert mode (upsert mode is disabled whenUPDATE_ON_EXISTING_PKisFALSE). If set toTRUE, any source table record being inserted that is rejected for having primary key values that match those of an existing target table record will be ignored with no error generated. IfFALSE, the rejection of any source table record for having primary key values matching an existing target table record will result in an error being raised. If the specified table does not have a primary key or if upsert mode is in effect (UPDATE_ON_EXISTING_PKisTRUE), then this option has no effect. Supported values:TRUE: Ignore source table records whose primary key values collide with those of target table records.FALSE: Raise an error for any source table record whose primary key values collide with those of a target table record.
FALSE.PK_CONFLICT_PREDICATE_HIGHER: The record with higher value for the column resolves the primary-key insert conflict. The default value is ”.PK_CONFLICT_PREDICATE_LOWER: The record with lower value for the column resolves the primary-key insert conflict. The default value is ”.TRUNCATE_STRINGS: If set toTRUE, it allows inserting longer strings into smaller charN string columns by truncating the longer strings to fit. Supported values:The default value isFALSE.
Map.Parameters:options- The new value foroptions.Returns:thisto mimic the builder pattern.getSchema
public org.apache.avro.Schema getSchema()This method supports the Avro framework and is not intended to be called directly by the user.Specified by:getSchemain interfaceorg.apache.avro.generic.GenericContainerReturns:The schema object describing this class.get
This method supports the Avro framework and is not intended to be called directly by the user.Specified by:getin interfaceorg.apache.avro.generic.IndexedRecordParameters:index- the position of the field to getReturns:value of the field with the given index.Throws:put
This method supports the Avro framework and is not intended to be called directly by the user.Specified by:putin interfaceorg.apache.avro.generic.IndexedRecordParameters:index- the position of the field to setvalue- the value to setThrows: