TeradataSource.java

// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
// Code generated by Microsoft (R) AutoRest Code Generator.

package com.azure.analytics.synapse.artifacts.models;

import com.azure.core.annotation.Fluent;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonTypeInfo;
import com.fasterxml.jackson.annotation.JsonTypeName;

/** A copy activity Teradata source. */
@JsonTypeInfo(use = JsonTypeInfo.Id.NAME, include = JsonTypeInfo.As.PROPERTY, property = "type")
@JsonTypeName("TeradataSource")
@Fluent
public final class TeradataSource extends TabularSource {
    /*
     * Teradata query. Type: string (or Expression with resultType string).
     */
    @JsonProperty(value = "query")
    private Object query;

    /*
     * The partition mechanism that will be used for teradata read in parallel.
     */
    @JsonProperty(value = "partitionOption")
    private TeradataPartitionOption partitionOption;

    /*
     * The settings that will be leveraged for teradata source partitioning.
     */
    @JsonProperty(value = "partitionSettings")
    private TeradataPartitionSettings partitionSettings;

    /**
     * Get the query property: Teradata query. Type: string (or Expression with resultType string).
     *
     * @return the query value.
     */
    public Object getQuery() {
        return this.query;
    }

    /**
     * Set the query property: Teradata query. Type: string (or Expression with resultType string).
     *
     * @param query the query value to set.
     * @return the TeradataSource object itself.
     */
    public TeradataSource setQuery(Object query) {
        this.query = query;
        return this;
    }

    /**
     * Get the partitionOption property: The partition mechanism that will be used for teradata read in parallel.
     *
     * @return the partitionOption value.
     */
    public TeradataPartitionOption getPartitionOption() {
        return this.partitionOption;
    }

    /**
     * Set the partitionOption property: The partition mechanism that will be used for teradata read in parallel.
     *
     * @param partitionOption the partitionOption value to set.
     * @return the TeradataSource object itself.
     */
    public TeradataSource setPartitionOption(TeradataPartitionOption partitionOption) {
        this.partitionOption = partitionOption;
        return this;
    }

    /**
     * Get the partitionSettings property: The settings that will be leveraged for teradata source partitioning.
     *
     * @return the partitionSettings value.
     */
    public TeradataPartitionSettings getPartitionSettings() {
        return this.partitionSettings;
    }

    /**
     * Set the partitionSettings property: The settings that will be leveraged for teradata source partitioning.
     *
     * @param partitionSettings the partitionSettings value to set.
     * @return the TeradataSource object itself.
     */
    public TeradataSource setPartitionSettings(TeradataPartitionSettings partitionSettings) {
        this.partitionSettings = partitionSettings;
        return this;
    }
}