Skip to main content

Relation

#[non_exhaustive]
pub struct Relation {
Show 18 fields pub dependency_targets: Vec<Target>, pub disabled: bool, pub tags: Vec<String>, pub relation_descriptor: Option<RelationDescriptor>, pub relation_type: RelationType, pub select_query: String, pub pre_operations: Vec<String>, pub post_operations: Vec<String>, pub incremental_table_config: Option<IncrementalTableConfig>, pub partition_expression: String, pub cluster_expressions: Vec<String>, pub partition_expiration_days: i32, pub require_partition_filter: bool, pub additional_options: HashMap<String, String>, pub connection: String, pub table_format: TableFormat, pub file_format: FileFormat, pub storage_uri: String, /* private fields */
}
Expand description

Represents a database relation.

Fields (Non-exhaustive)§

This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.
§dependency_targets: Vec<Target>

A list of actions that this action depends on.

§disabled: bool

Whether this action is disabled (i.e. should not be run).

§tags: Vec<String>

Arbitrary, user-defined tags on this action.

§relation_descriptor: Option<RelationDescriptor>

Descriptor for the relation and its columns.

§relation_type: RelationType

The type of this relation.

§select_query: String

The SELECT query which returns rows which this relation should contain.

§pre_operations: Vec<String>

SQL statements to be executed before creating the relation.

§post_operations: Vec<String>

SQL statements to be executed after creating the relation.

§incremental_table_config: Option<IncrementalTableConfig>

Configures INCREMENTAL_TABLE settings for this relation. Only set if relation_type is INCREMENTAL_TABLE.

§partition_expression: String

The SQL expression used to partition the relation.

§cluster_expressions: Vec<String>

A list of columns or SQL expressions used to cluster the table.

§partition_expiration_days: i32

Sets the partition expiration in days.

§require_partition_filter: bool

Specifies whether queries on this table must include a predicate filter that filters on the partitioning column.

§additional_options: HashMap<String, String>

Additional options that will be provided as key/value pairs into the options clause of a create table/view statement. See https://cloud.google.com/bigquery/docs/reference/standard-sql/data-definition-language for more information on which options are supported.

§connection: String

Optional. The connection specifying the credentials to be used to read and write to external storage, such as Cloud Storage. The connection can have the form {project}.{location}.{connection_id} or projects/{project}/locations/{location}/connections/{connection_id}, or be set to DEFAULT.

§table_format: TableFormat

Optional. The table format for the BigQuery table.

§file_format: FileFormat

Optional. The file format for the BigQuery table.

§storage_uri: String

Optional. The fully qualified location prefix of the external folder where table data is stored. The URI should be in the format gs://bucket/path_to_table/.

Implementations§

Source§

impl Relation

Source

pub fn new() -> Self

Source

pub fn set_dependency_targets<T, V>(self, v: T) -> Self
where T: IntoIterator<Item = V>, V: Into<Target>,

Sets the value of dependency_targets.

§Example
use google_cloud_dataform_v1::model::Target;
let x = Relation::new()
    .set_dependency_targets([
        Target::default()/* use setters */,
        Target::default()/* use (different) setters */,
    ]);
Source

pub fn set_disabled<T: Into<bool>>(self, v: T) -> Self

Sets the value of disabled.

§Example
let x = Relation::new().set_disabled(true);
Source

pub fn set_tags<T, V>(self, v: T) -> Self
where T: IntoIterator<Item = V>, V: Into<String>,

Sets the value of tags.

§Example
let x = Relation::new().set_tags(["a", "b", "c"]);
Source

pub fn set_relation_descriptor<T>(self, v: T) -> Self

Sets the value of relation_descriptor.

§Example
use google_cloud_dataform_v1::model::RelationDescriptor;
let x = Relation::new().set_relation_descriptor(RelationDescriptor::default()/* use setters */);
Source

pub fn set_or_clear_relation_descriptor<T>(self, v: Option<T>) -> Self

Sets or clears the value of relation_descriptor.

§Example
use google_cloud_dataform_v1::model::RelationDescriptor;
let x = Relation::new().set_or_clear_relation_descriptor(Some(RelationDescriptor::default()/* use setters */));
let x = Relation::new().set_or_clear_relation_descriptor(None::<RelationDescriptor>);
Source

pub fn set_relation_type<T: Into<RelationType>>(self, v: T) -> Self

Sets the value of relation_type.

§Example
use google_cloud_dataform_v1::model::compilation_result_action::relation::RelationType;
let x0 = Relation::new().set_relation_type(RelationType::Table);
let x1 = Relation::new().set_relation_type(RelationType::View);
let x2 = Relation::new().set_relation_type(RelationType::IncrementalTable);
Source

pub fn set_select_query<T: Into<String>>(self, v: T) -> Self

Sets the value of select_query.

§Example
let x = Relation::new().set_select_query("example");
Source

pub fn set_pre_operations<T, V>(self, v: T) -> Self
where T: IntoIterator<Item = V>, V: Into<String>,

Sets the value of pre_operations.

§Example
let x = Relation::new().set_pre_operations(["a", "b", "c"]);
Source

pub fn set_post_operations<T, V>(self, v: T) -> Self
where T: IntoIterator<Item = V>, V: Into<String>,

Sets the value of post_operations.

§Example
let x = Relation::new().set_post_operations(["a", "b", "c"]);
Source

pub fn set_incremental_table_config<T>(self, v: T) -> Self

Sets the value of incremental_table_config.

§Example
use google_cloud_dataform_v1::model::compilation_result_action::relation::IncrementalTableConfig;
let x = Relation::new().set_incremental_table_config(IncrementalTableConfig::default()/* use setters */);
Source

pub fn set_or_clear_incremental_table_config<T>(self, v: Option<T>) -> Self

Sets or clears the value of incremental_table_config.

§Example
use google_cloud_dataform_v1::model::compilation_result_action::relation::IncrementalTableConfig;
let x = Relation::new().set_or_clear_incremental_table_config(Some(IncrementalTableConfig::default()/* use setters */));
let x = Relation::new().set_or_clear_incremental_table_config(None::<IncrementalTableConfig>);
Source

pub fn set_partition_expression<T: Into<String>>(self, v: T) -> Self

Sets the value of partition_expression.

§Example
let x = Relation::new().set_partition_expression("example");
Source

pub fn set_cluster_expressions<T, V>(self, v: T) -> Self
where T: IntoIterator<Item = V>, V: Into<String>,

Sets the value of cluster_expressions.

§Example
let x = Relation::new().set_cluster_expressions(["a", "b", "c"]);
Source

pub fn set_partition_expiration_days<T: Into<i32>>(self, v: T) -> Self

Sets the value of partition_expiration_days.

§Example
let x = Relation::new().set_partition_expiration_days(42);
Source

pub fn set_require_partition_filter<T: Into<bool>>(self, v: T) -> Self

Sets the value of require_partition_filter.

§Example
let x = Relation::new().set_require_partition_filter(true);
Source

pub fn set_additional_options<T, K, V>(self, v: T) -> Self
where T: IntoIterator<Item = (K, V)>, K: Into<String>, V: Into<String>,

Sets the value of additional_options.

§Example
let x = Relation::new().set_additional_options([
    ("key0", "abc"),
    ("key1", "xyz"),
]);
Source

pub fn set_connection<T: Into<String>>(self, v: T) -> Self

Sets the value of connection.

§Example
let x = Relation::new().set_connection("example");
Source

pub fn set_table_format<T: Into<TableFormat>>(self, v: T) -> Self

Sets the value of table_format.

§Example
use google_cloud_dataform_v1::model::compilation_result_action::relation::TableFormat;
let x0 = Relation::new().set_table_format(TableFormat::Iceberg);
Source

pub fn set_file_format<T: Into<FileFormat>>(self, v: T) -> Self

Sets the value of file_format.

§Example
use google_cloud_dataform_v1::model::compilation_result_action::relation::FileFormat;
let x0 = Relation::new().set_file_format(FileFormat::Parquet);
Source

pub fn set_storage_uri<T: Into<String>>(self, v: T) -> Self

Sets the value of storage_uri.

§Example
let x = Relation::new().set_storage_uri("example");

Trait Implementations§

Source§

impl Clone for Relation

Source§

fn clone(&self) -> Relation

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Relation

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for Relation

Source§

fn default() -> Relation

Returns the “default value” for a type. Read more
Source§

impl Message for Relation

Source§

fn typename() -> &'static str

The typename of this message.
Source§

impl PartialEq for Relation

Source§

fn eq(&self, other: &Relation) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl StructuralPartialEq for Relation

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> FutureExt for T

Source§

fn with_context(self, otel_cx: Context) -> WithContext<Self>

Attaches the provided Context to this type, returning a WithContext wrapper. Read more
Source§

fn with_current_context(self) -> WithContext<Self>

Attaches the current Context to this type, returning a WithContext wrapper. Read more
Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,