Class: Google::Cloud::Datastream::V1::BigQueryDestinationConfig

Inherits:
Object
  • Object
show all
Extended by:
Protobuf::MessageExts::ClassMethods
Includes:
Protobuf::MessageExts
Defined in:
proto_docs/google/cloud/datastream/v1/datastream_resources.rb

Overview

BigQuery destination configuration

Defined Under Namespace

Classes: AppendOnly, BlmtConfig, Merge, SingleTargetDataset, SourceHierarchyDatasets

Instance Attribute Summary collapse

Instance Attribute Details

#append_only::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::AppendOnly

Returns Append only mode

Note: The following fields are mutually exclusive: append_only, merge. If a field in that set is populated, all other fields in the set will automatically be cleared.

Returns:



1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591
1592
1593
1594
1595
1596
1597
1598
# File 'proto_docs/google/cloud/datastream/v1/datastream_resources.rb', line 1491

class BigQueryDestinationConfig
  include ::Google::Protobuf::MessageExts
  extend ::Google::Protobuf::MessageExts::ClassMethods

  # A single target dataset to which all data will be streamed.
  # @!attribute [rw] dataset_id
  #   @return [::String]
  #     The dataset ID of the target dataset.
  #     DatasetIds allowed characters:
  #     https://cloud.google.com/bigquery/docs/reference/rest/v2/datasets#datasetreference.
  class SingleTargetDataset
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods
  end

  # Destination datasets are created so that hierarchy of the destination data
  # objects matches the source hierarchy.
  # @!attribute [rw] dataset_template
  #   @return [::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::SourceHierarchyDatasets::DatasetTemplate]
  #     The dataset template to use for dynamic dataset creation.
  # @!attribute [rw] project_id
  #   @return [::String]
  #     Optional. The project id of the BigQuery dataset. If not specified, the
  #     project will be inferred from the stream resource.
  class SourceHierarchyDatasets
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods

    # Dataset template used for dynamic dataset creation.
    # @!attribute [rw] location
    #   @return [::String]
    #     Required. The geographic location where the dataset should reside. See
    #     https://cloud.google.com/bigquery/docs/locations for supported
    #     locations.
    # @!attribute [rw] dataset_id_prefix
    #   @return [::String]
    #     If supplied, every created dataset will have its name prefixed by the
    #     provided value. The prefix and name will be separated by an underscore.
    #     i.e. <prefix>_<dataset_name>.
    # @!attribute [rw] kms_key_name
    #   @return [::String]
    #     Describes the Cloud KMS encryption key that will be used to
    #     protect destination BigQuery table. The BigQuery Service Account
    #     associated with your project requires access to this encryption key.
    #     i.e.
    #     projects/\\{project}/locations/\\{location}/keyRings/\\{key_ring}/cryptoKeys/\\{cryptoKey}.
    #     See https://cloud.google.com/bigquery/docs/customer-managed-encryption
    #     for more information.
    class DatasetTemplate
      include ::Google::Protobuf::MessageExts
      extend ::Google::Protobuf::MessageExts::ClassMethods
    end
  end

  # The configuration for BLMT.
  # @!attribute [rw] bucket
  #   @return [::String]
  #     Required. The Cloud Storage bucket name.
  # @!attribute [rw] root_path
  #   @return [::String]
  #     The root path inside the Cloud Storage bucket.
  # @!attribute [rw] connection_name
  #   @return [::String]
  #     Required. The bigquery connection.
  #     Format: `{project}.{location}.{name}`
  # @!attribute [rw] file_format
  #   @return [::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::BlmtConfig::FileFormat]
  #     Required. The file format.
  # @!attribute [rw] table_format
  #   @return [::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::BlmtConfig::TableFormat]
  #     Required. The table format.
  class BlmtConfig
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods

    # Supported file formats for BigLake managed tables.
    module FileFormat
      # Default value.
      FILE_FORMAT_UNSPECIFIED = 0

      # Parquet file format.
      PARQUET = 1
    end

    # Supported table formats for BigLake managed tables.
    module TableFormat
      # Default value.
      TABLE_FORMAT_UNSPECIFIED = 0

      # Iceberg table format.
      ICEBERG = 1
    end
  end

  # AppendOnly mode defines that all changes to a table will be written to the
  # destination table.
  class AppendOnly
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods
  end

  # Merge mode defines that all changes to a table will be merged at the
  # destination table.
  class Merge
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods
  end
end

#blmt_config::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::BlmtConfig

Returns Optional. Big Lake Managed Tables (BLMT) configuration.

Returns:



1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591
1592
1593
1594
1595
1596
1597
1598
# File 'proto_docs/google/cloud/datastream/v1/datastream_resources.rb', line 1491

class BigQueryDestinationConfig
  include ::Google::Protobuf::MessageExts
  extend ::Google::Protobuf::MessageExts::ClassMethods

  # A single target dataset to which all data will be streamed.
  # @!attribute [rw] dataset_id
  #   @return [::String]
  #     The dataset ID of the target dataset.
  #     DatasetIds allowed characters:
  #     https://cloud.google.com/bigquery/docs/reference/rest/v2/datasets#datasetreference.
  class SingleTargetDataset
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods
  end

  # Destination datasets are created so that hierarchy of the destination data
  # objects matches the source hierarchy.
  # @!attribute [rw] dataset_template
  #   @return [::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::SourceHierarchyDatasets::DatasetTemplate]
  #     The dataset template to use for dynamic dataset creation.
  # @!attribute [rw] project_id
  #   @return [::String]
  #     Optional. The project id of the BigQuery dataset. If not specified, the
  #     project will be inferred from the stream resource.
  class SourceHierarchyDatasets
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods

    # Dataset template used for dynamic dataset creation.
    # @!attribute [rw] location
    #   @return [::String]
    #     Required. The geographic location where the dataset should reside. See
    #     https://cloud.google.com/bigquery/docs/locations for supported
    #     locations.
    # @!attribute [rw] dataset_id_prefix
    #   @return [::String]
    #     If supplied, every created dataset will have its name prefixed by the
    #     provided value. The prefix and name will be separated by an underscore.
    #     i.e. <prefix>_<dataset_name>.
    # @!attribute [rw] kms_key_name
    #   @return [::String]
    #     Describes the Cloud KMS encryption key that will be used to
    #     protect destination BigQuery table. The BigQuery Service Account
    #     associated with your project requires access to this encryption key.
    #     i.e.
    #     projects/\\{project}/locations/\\{location}/keyRings/\\{key_ring}/cryptoKeys/\\{cryptoKey}.
    #     See https://cloud.google.com/bigquery/docs/customer-managed-encryption
    #     for more information.
    class DatasetTemplate
      include ::Google::Protobuf::MessageExts
      extend ::Google::Protobuf::MessageExts::ClassMethods
    end
  end

  # The configuration for BLMT.
  # @!attribute [rw] bucket
  #   @return [::String]
  #     Required. The Cloud Storage bucket name.
  # @!attribute [rw] root_path
  #   @return [::String]
  #     The root path inside the Cloud Storage bucket.
  # @!attribute [rw] connection_name
  #   @return [::String]
  #     Required. The bigquery connection.
  #     Format: `{project}.{location}.{name}`
  # @!attribute [rw] file_format
  #   @return [::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::BlmtConfig::FileFormat]
  #     Required. The file format.
  # @!attribute [rw] table_format
  #   @return [::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::BlmtConfig::TableFormat]
  #     Required. The table format.
  class BlmtConfig
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods

    # Supported file formats for BigLake managed tables.
    module FileFormat
      # Default value.
      FILE_FORMAT_UNSPECIFIED = 0

      # Parquet file format.
      PARQUET = 1
    end

    # Supported table formats for BigLake managed tables.
    module TableFormat
      # Default value.
      TABLE_FORMAT_UNSPECIFIED = 0

      # Iceberg table format.
      ICEBERG = 1
    end
  end

  # AppendOnly mode defines that all changes to a table will be written to the
  # destination table.
  class AppendOnly
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods
  end

  # Merge mode defines that all changes to a table will be merged at the
  # destination table.
  class Merge
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods
  end
end

#data_freshness::Google::Protobuf::Duration

Returns The guaranteed data freshness (in seconds) when querying tables created by the stream. Editing this field will only affect new tables created in the future, but existing tables will not be impacted. Lower values mean that queries will return fresher data, but may result in higher cost.

Returns:

  • (::Google::Protobuf::Duration)

    The guaranteed data freshness (in seconds) when querying tables created by the stream. Editing this field will only affect new tables created in the future, but existing tables will not be impacted. Lower values mean that queries will return fresher data, but may result in higher cost.



1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591
1592
1593
1594
1595
1596
1597
1598
# File 'proto_docs/google/cloud/datastream/v1/datastream_resources.rb', line 1491

class BigQueryDestinationConfig
  include ::Google::Protobuf::MessageExts
  extend ::Google::Protobuf::MessageExts::ClassMethods

  # A single target dataset to which all data will be streamed.
  # @!attribute [rw] dataset_id
  #   @return [::String]
  #     The dataset ID of the target dataset.
  #     DatasetIds allowed characters:
  #     https://cloud.google.com/bigquery/docs/reference/rest/v2/datasets#datasetreference.
  class SingleTargetDataset
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods
  end

  # Destination datasets are created so that hierarchy of the destination data
  # objects matches the source hierarchy.
  # @!attribute [rw] dataset_template
  #   @return [::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::SourceHierarchyDatasets::DatasetTemplate]
  #     The dataset template to use for dynamic dataset creation.
  # @!attribute [rw] project_id
  #   @return [::String]
  #     Optional. The project id of the BigQuery dataset. If not specified, the
  #     project will be inferred from the stream resource.
  class SourceHierarchyDatasets
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods

    # Dataset template used for dynamic dataset creation.
    # @!attribute [rw] location
    #   @return [::String]
    #     Required. The geographic location where the dataset should reside. See
    #     https://cloud.google.com/bigquery/docs/locations for supported
    #     locations.
    # @!attribute [rw] dataset_id_prefix
    #   @return [::String]
    #     If supplied, every created dataset will have its name prefixed by the
    #     provided value. The prefix and name will be separated by an underscore.
    #     i.e. <prefix>_<dataset_name>.
    # @!attribute [rw] kms_key_name
    #   @return [::String]
    #     Describes the Cloud KMS encryption key that will be used to
    #     protect destination BigQuery table. The BigQuery Service Account
    #     associated with your project requires access to this encryption key.
    #     i.e.
    #     projects/\\{project}/locations/\\{location}/keyRings/\\{key_ring}/cryptoKeys/\\{cryptoKey}.
    #     See https://cloud.google.com/bigquery/docs/customer-managed-encryption
    #     for more information.
    class DatasetTemplate
      include ::Google::Protobuf::MessageExts
      extend ::Google::Protobuf::MessageExts::ClassMethods
    end
  end

  # The configuration for BLMT.
  # @!attribute [rw] bucket
  #   @return [::String]
  #     Required. The Cloud Storage bucket name.
  # @!attribute [rw] root_path
  #   @return [::String]
  #     The root path inside the Cloud Storage bucket.
  # @!attribute [rw] connection_name
  #   @return [::String]
  #     Required. The bigquery connection.
  #     Format: `{project}.{location}.{name}`
  # @!attribute [rw] file_format
  #   @return [::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::BlmtConfig::FileFormat]
  #     Required. The file format.
  # @!attribute [rw] table_format
  #   @return [::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::BlmtConfig::TableFormat]
  #     Required. The table format.
  class BlmtConfig
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods

    # Supported file formats for BigLake managed tables.
    module FileFormat
      # Default value.
      FILE_FORMAT_UNSPECIFIED = 0

      # Parquet file format.
      PARQUET = 1
    end

    # Supported table formats for BigLake managed tables.
    module TableFormat
      # Default value.
      TABLE_FORMAT_UNSPECIFIED = 0

      # Iceberg table format.
      ICEBERG = 1
    end
  end

  # AppendOnly mode defines that all changes to a table will be written to the
  # destination table.
  class AppendOnly
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods
  end

  # Merge mode defines that all changes to a table will be merged at the
  # destination table.
  class Merge
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods
  end
end

#merge::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::Merge

Returns The standard mode

Note: The following fields are mutually exclusive: merge, append_only. If a field in that set is populated, all other fields in the set will automatically be cleared.

Returns:



1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591
1592
1593
1594
1595
1596
1597
1598
# File 'proto_docs/google/cloud/datastream/v1/datastream_resources.rb', line 1491

class BigQueryDestinationConfig
  include ::Google::Protobuf::MessageExts
  extend ::Google::Protobuf::MessageExts::ClassMethods

  # A single target dataset to which all data will be streamed.
  # @!attribute [rw] dataset_id
  #   @return [::String]
  #     The dataset ID of the target dataset.
  #     DatasetIds allowed characters:
  #     https://cloud.google.com/bigquery/docs/reference/rest/v2/datasets#datasetreference.
  class SingleTargetDataset
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods
  end

  # Destination datasets are created so that hierarchy of the destination data
  # objects matches the source hierarchy.
  # @!attribute [rw] dataset_template
  #   @return [::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::SourceHierarchyDatasets::DatasetTemplate]
  #     The dataset template to use for dynamic dataset creation.
  # @!attribute [rw] project_id
  #   @return [::String]
  #     Optional. The project id of the BigQuery dataset. If not specified, the
  #     project will be inferred from the stream resource.
  class SourceHierarchyDatasets
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods

    # Dataset template used for dynamic dataset creation.
    # @!attribute [rw] location
    #   @return [::String]
    #     Required. The geographic location where the dataset should reside. See
    #     https://cloud.google.com/bigquery/docs/locations for supported
    #     locations.
    # @!attribute [rw] dataset_id_prefix
    #   @return [::String]
    #     If supplied, every created dataset will have its name prefixed by the
    #     provided value. The prefix and name will be separated by an underscore.
    #     i.e. <prefix>_<dataset_name>.
    # @!attribute [rw] kms_key_name
    #   @return [::String]
    #     Describes the Cloud KMS encryption key that will be used to
    #     protect destination BigQuery table. The BigQuery Service Account
    #     associated with your project requires access to this encryption key.
    #     i.e.
    #     projects/\\{project}/locations/\\{location}/keyRings/\\{key_ring}/cryptoKeys/\\{cryptoKey}.
    #     See https://cloud.google.com/bigquery/docs/customer-managed-encryption
    #     for more information.
    class DatasetTemplate
      include ::Google::Protobuf::MessageExts
      extend ::Google::Protobuf::MessageExts::ClassMethods
    end
  end

  # The configuration for BLMT.
  # @!attribute [rw] bucket
  #   @return [::String]
  #     Required. The Cloud Storage bucket name.
  # @!attribute [rw] root_path
  #   @return [::String]
  #     The root path inside the Cloud Storage bucket.
  # @!attribute [rw] connection_name
  #   @return [::String]
  #     Required. The bigquery connection.
  #     Format: `{project}.{location}.{name}`
  # @!attribute [rw] file_format
  #   @return [::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::BlmtConfig::FileFormat]
  #     Required. The file format.
  # @!attribute [rw] table_format
  #   @return [::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::BlmtConfig::TableFormat]
  #     Required. The table format.
  class BlmtConfig
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods

    # Supported file formats for BigLake managed tables.
    module FileFormat
      # Default value.
      FILE_FORMAT_UNSPECIFIED = 0

      # Parquet file format.
      PARQUET = 1
    end

    # Supported table formats for BigLake managed tables.
    module TableFormat
      # Default value.
      TABLE_FORMAT_UNSPECIFIED = 0

      # Iceberg table format.
      ICEBERG = 1
    end
  end

  # AppendOnly mode defines that all changes to a table will be written to the
  # destination table.
  class AppendOnly
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods
  end

  # Merge mode defines that all changes to a table will be merged at the
  # destination table.
  class Merge
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods
  end
end

#single_target_dataset::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::SingleTargetDataset

Returns Single destination dataset.

Note: The following fields are mutually exclusive: single_target_dataset, source_hierarchy_datasets. If a field in that set is populated, all other fields in the set will automatically be cleared.

Returns:



1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591
1592
1593
1594
1595
1596
1597
1598
# File 'proto_docs/google/cloud/datastream/v1/datastream_resources.rb', line 1491

class BigQueryDestinationConfig
  include ::Google::Protobuf::MessageExts
  extend ::Google::Protobuf::MessageExts::ClassMethods

  # A single target dataset to which all data will be streamed.
  # @!attribute [rw] dataset_id
  #   @return [::String]
  #     The dataset ID of the target dataset.
  #     DatasetIds allowed characters:
  #     https://cloud.google.com/bigquery/docs/reference/rest/v2/datasets#datasetreference.
  class SingleTargetDataset
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods
  end

  # Destination datasets are created so that hierarchy of the destination data
  # objects matches the source hierarchy.
  # @!attribute [rw] dataset_template
  #   @return [::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::SourceHierarchyDatasets::DatasetTemplate]
  #     The dataset template to use for dynamic dataset creation.
  # @!attribute [rw] project_id
  #   @return [::String]
  #     Optional. The project id of the BigQuery dataset. If not specified, the
  #     project will be inferred from the stream resource.
  class SourceHierarchyDatasets
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods

    # Dataset template used for dynamic dataset creation.
    # @!attribute [rw] location
    #   @return [::String]
    #     Required. The geographic location where the dataset should reside. See
    #     https://cloud.google.com/bigquery/docs/locations for supported
    #     locations.
    # @!attribute [rw] dataset_id_prefix
    #   @return [::String]
    #     If supplied, every created dataset will have its name prefixed by the
    #     provided value. The prefix and name will be separated by an underscore.
    #     i.e. <prefix>_<dataset_name>.
    # @!attribute [rw] kms_key_name
    #   @return [::String]
    #     Describes the Cloud KMS encryption key that will be used to
    #     protect destination BigQuery table. The BigQuery Service Account
    #     associated with your project requires access to this encryption key.
    #     i.e.
    #     projects/\\{project}/locations/\\{location}/keyRings/\\{key_ring}/cryptoKeys/\\{cryptoKey}.
    #     See https://cloud.google.com/bigquery/docs/customer-managed-encryption
    #     for more information.
    class DatasetTemplate
      include ::Google::Protobuf::MessageExts
      extend ::Google::Protobuf::MessageExts::ClassMethods
    end
  end

  # The configuration for BLMT.
  # @!attribute [rw] bucket
  #   @return [::String]
  #     Required. The Cloud Storage bucket name.
  # @!attribute [rw] root_path
  #   @return [::String]
  #     The root path inside the Cloud Storage bucket.
  # @!attribute [rw] connection_name
  #   @return [::String]
  #     Required. The bigquery connection.
  #     Format: `{project}.{location}.{name}`
  # @!attribute [rw] file_format
  #   @return [::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::BlmtConfig::FileFormat]
  #     Required. The file format.
  # @!attribute [rw] table_format
  #   @return [::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::BlmtConfig::TableFormat]
  #     Required. The table format.
  class BlmtConfig
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods

    # Supported file formats for BigLake managed tables.
    module FileFormat
      # Default value.
      FILE_FORMAT_UNSPECIFIED = 0

      # Parquet file format.
      PARQUET = 1
    end

    # Supported table formats for BigLake managed tables.
    module TableFormat
      # Default value.
      TABLE_FORMAT_UNSPECIFIED = 0

      # Iceberg table format.
      ICEBERG = 1
    end
  end

  # AppendOnly mode defines that all changes to a table will be written to the
  # destination table.
  class AppendOnly
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods
  end

  # Merge mode defines that all changes to a table will be merged at the
  # destination table.
  class Merge
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods
  end
end

#source_hierarchy_datasets::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::SourceHierarchyDatasets

Returns Source hierarchy datasets.

Note: The following fields are mutually exclusive: source_hierarchy_datasets, single_target_dataset. If a field in that set is populated, all other fields in the set will automatically be cleared.

Returns:



1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591
1592
1593
1594
1595
1596
1597
1598
# File 'proto_docs/google/cloud/datastream/v1/datastream_resources.rb', line 1491

class BigQueryDestinationConfig
  include ::Google::Protobuf::MessageExts
  extend ::Google::Protobuf::MessageExts::ClassMethods

  # A single target dataset to which all data will be streamed.
  # @!attribute [rw] dataset_id
  #   @return [::String]
  #     The dataset ID of the target dataset.
  #     DatasetIds allowed characters:
  #     https://cloud.google.com/bigquery/docs/reference/rest/v2/datasets#datasetreference.
  class SingleTargetDataset
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods
  end

  # Destination datasets are created so that hierarchy of the destination data
  # objects matches the source hierarchy.
  # @!attribute [rw] dataset_template
  #   @return [::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::SourceHierarchyDatasets::DatasetTemplate]
  #     The dataset template to use for dynamic dataset creation.
  # @!attribute [rw] project_id
  #   @return [::String]
  #     Optional. The project id of the BigQuery dataset. If not specified, the
  #     project will be inferred from the stream resource.
  class SourceHierarchyDatasets
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods

    # Dataset template used for dynamic dataset creation.
    # @!attribute [rw] location
    #   @return [::String]
    #     Required. The geographic location where the dataset should reside. See
    #     https://cloud.google.com/bigquery/docs/locations for supported
    #     locations.
    # @!attribute [rw] dataset_id_prefix
    #   @return [::String]
    #     If supplied, every created dataset will have its name prefixed by the
    #     provided value. The prefix and name will be separated by an underscore.
    #     i.e. <prefix>_<dataset_name>.
    # @!attribute [rw] kms_key_name
    #   @return [::String]
    #     Describes the Cloud KMS encryption key that will be used to
    #     protect destination BigQuery table. The BigQuery Service Account
    #     associated with your project requires access to this encryption key.
    #     i.e.
    #     projects/\\{project}/locations/\\{location}/keyRings/\\{key_ring}/cryptoKeys/\\{cryptoKey}.
    #     See https://cloud.google.com/bigquery/docs/customer-managed-encryption
    #     for more information.
    class DatasetTemplate
      include ::Google::Protobuf::MessageExts
      extend ::Google::Protobuf::MessageExts::ClassMethods
    end
  end

  # The configuration for BLMT.
  # @!attribute [rw] bucket
  #   @return [::String]
  #     Required. The Cloud Storage bucket name.
  # @!attribute [rw] root_path
  #   @return [::String]
  #     The root path inside the Cloud Storage bucket.
  # @!attribute [rw] connection_name
  #   @return [::String]
  #     Required. The bigquery connection.
  #     Format: `{project}.{location}.{name}`
  # @!attribute [rw] file_format
  #   @return [::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::BlmtConfig::FileFormat]
  #     Required. The file format.
  # @!attribute [rw] table_format
  #   @return [::Google::Cloud::Datastream::V1::BigQueryDestinationConfig::BlmtConfig::TableFormat]
  #     Required. The table format.
  class BlmtConfig
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods

    # Supported file formats for BigLake managed tables.
    module FileFormat
      # Default value.
      FILE_FORMAT_UNSPECIFIED = 0

      # Parquet file format.
      PARQUET = 1
    end

    # Supported table formats for BigLake managed tables.
    module TableFormat
      # Default value.
      TABLE_FORMAT_UNSPECIFIED = 0

      # Iceberg table format.
      ICEBERG = 1
    end
  end

  # AppendOnly mode defines that all changes to a table will be written to the
  # destination table.
  class AppendOnly
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods
  end

  # Merge mode defines that all changes to a table will be merged at the
  # destination table.
  class Merge
    include ::Google::Protobuf::MessageExts
    extend ::Google::Protobuf::MessageExts::ClassMethods
  end
end