Index
- ReservationService(interface)
- Assignment(message)
- Assignment.JobType(enum)
- Assignment.State(enum)
- BiReservation(message)
- CapacityCommitment(message)
- CapacityCommitment.CommitmentPlan(enum)
- CapacityCommitment.State(enum)
- CreateAssignmentRequest(message)
- CreateCapacityCommitmentRequest(message)
- CreateReservationRequest(message)
- DeleteAssignmentRequest(message)
- DeleteCapacityCommitmentRequest(message)
- DeleteReservationRequest(message)
- Edition(enum)
- FailoverMode(enum)
- FailoverReservationRequest(message)
- GetBiReservationRequest(message)
- GetCapacityCommitmentRequest(message)
- GetReservationRequest(message)
- ListAssignmentsRequest(message)
- ListAssignmentsResponse(message)
- ListCapacityCommitmentsRequest(message)
- ListCapacityCommitmentsResponse(message)
- ListReservationsRequest(message)
- ListReservationsResponse(message)
- MergeCapacityCommitmentsRequest(message)
- MoveAssignmentRequest(message)
- Reservation(message)
- Reservation.Autoscale(message)
- Reservation.ReplicationStatus(message)
- Reservation.ScalingMode(enum)
- SearchAllAssignmentsRequest(message)
- SearchAllAssignmentsResponse(message)
- SearchAssignmentsRequest(message)
- SearchAssignmentsResponse(message)
- SplitCapacityCommitmentRequest(message)
- SplitCapacityCommitmentResponse(message)
- TableReference(message)
- UpdateAssignmentRequest(message)
- UpdateBiReservationRequest(message)
- UpdateCapacityCommitmentRequest(message)
- UpdateReservationRequest(message)
ReservationService
This API allows users to manage their BigQuery reservations.
A reservation provides computational resource guarantees, in the form of slots, to users. A slot is a unit of computational power in BigQuery, and serves as the basic unit of parallelism. In a scan of a multi-partitioned table, a single slot operates on a single partition of the table. A reservation resource exists as a child resource of the admin project and location, e.g.:  projects/myproject/locations/US/reservations/reservationName.
A capacity commitment is a way to purchase compute capacity for BigQuery jobs (in the form of slots) with some committed period of usage. A capacity commitment resource exists as a child resource of the admin project and location, e.g.:  projects/myproject/locations/US/capacityCommitments/id.
| CreateAssignment | 
|---|
| 
 Creates an assignment object which allows the given project to submit jobs of a certain type using slots from the specified reservation. Currently a resource (project, folder, organization) can only have one assignment per each (job_type, location) combination, and that reservation will be used for all jobs of the matching type. Different assignments can be created on different levels of the projects, folders or organization hierarchy. During query execution, the assignment is looked up at the project, folder and organization levels in that order. The first assignment found is applied to the query. When creating assignments, it does not matter if other assignments exist at higher levels. Example: 
 "None" assignments represent an absence of the assignment. Projects assigned to None use on-demand pricing. To create a "None" assignment, use "none" as a reservation_id in the parent. Example parent:  Returns  Returns  
 | 
| CreateCapacityCommitment | 
|---|
| 
 Creates a new capacity commitment resource. 
 | 
| CreateReservation | 
|---|
| 
 Creates a new reservation resource. 
 | 
| DeleteAssignment | 
|---|
| 
 Deletes a assignment. No expansion will happen. Example: 
 In this example, deletion of the  
 | 
| DeleteCapacityCommitment | 
|---|
| 
 Deletes a capacity commitment. Attempting to delete capacity commitment before its commitment_end_time will fail with the error code  
 | 
| DeleteReservation | 
|---|
| 
 Deletes a reservation. Returns  
 | 
| FailoverReservation | 
|---|
| 
 Fail over a reservation to the secondary location. The operation should be done in the current secondary location, which will be promoted to the new primary location for the reservation. Attempting to failover a reservation in the current primary location will fail with the error code  
 | 
| GetBiReservation | 
|---|
| 
 Retrieves a BI reservation. 
 | 
| GetCapacityCommitment | 
|---|
| 
 Returns information about the capacity commitment. 
 | 
| GetIamPolicy | 
|---|
| 
 Gets the access control policy for a resource. May return: 
 Supported resources are: - Reservations - ReservationAssignments To call this method, you must have the following Google IAM permissions: 
 
 | 
| GetReservation | 
|---|
| 
 Returns information about the reservation. 
 | 
| ListAssignments | 
|---|
| 
 Lists assignments. Only explicitly created assignments will be returned. Example: 
 In this example, ListAssignments will just return the above two assignments for reservation  The wildcard "-" can be used for reservations in the request. In that case all assignments belongs to the specified project and location will be listed. Note "-" cannot be used for projects nor locations. 
 | 
| ListCapacityCommitments | 
|---|
| 
 Lists all the capacity commitments for the admin project. 
 | 
| ListReservations | 
|---|
| 
 Lists all the reservations for the project in the specified location. 
 | 
| MergeCapacityCommitments | 
|---|
| 
 Merges capacity commitments of the same plan into a single commitment. The resulting capacity commitment has the greater commitment_end_time out of the to-be-merged capacity commitments. Attempting to merge capacity commitments of different plan will fail with the error code  
 | 
| MoveAssignment | 
|---|
| 
 Moves an assignment under a new reservation. This differs from removing an existing assignment and recreating a new one by providing a transactional change that ensures an assignee always has an associated reservation. 
 | 
| SearchAllAssignments | 
|---|
| 
 Looks up assignments for a specified resource for a particular region. If the request is about a project: 
 The same logic applies if the request is about a folder. If the request is about an organization, then assignments created on the organization will be returned (organization doesn't have ancestors). Comparing to ListAssignments, there are some behavior differences: 
 
 | 
| SearchAssignments | 
|---|
| 
 Deprecated: Looks up assignments for a specified resource for a particular region. If the request is about a project: 
 The same logic applies if the request is about a folder. If the request is about an organization, then assignments created on the organization will be returned (organization doesn't have ancestors). Comparing to ListAssignments, there are some behavior differences: 
 Note "-" cannot be used for projects nor locations. 
 | 
| SetIamPolicy | 
|---|
| 
 Sets an access control policy for a resource. Replaces any existing policy. Supported resources are: - Reservations To call this method, you must have the following Google IAM permissions: 
 
 | 
| SplitCapacityCommitment | 
|---|
| 
 Splits capacity commitment to two commitments of the same plan and  A common use case is to enable downgrading commitments. For example, in order to downgrade from 10000 slots to 8000, you might split a 10000 capacity commitment into commitments of 2000 and 8000. Then, you delete the first one after the commitment end time passes. 
 | 
| TestIamPermissions | 
|---|
| 
 Gets your permissions on a resource. Returns an empty set of permissions if the resource doesn't exist. Supported resources are: - Reservations No Google IAM permissions are required to call this method. 
 | 
| UpdateAssignment | 
|---|
| 
 Updates an existing assignment. Only the  
 | 
| UpdateBiReservation | 
|---|
| 
 Updates a BI reservation. Only fields specified in the  A singleton BI reservation always exists with default size 0. In order to reserve BI capacity it needs to be updated to an amount greater than 0. In order to release BI capacity reservation size must be set to 0. 
 | 
| UpdateCapacityCommitment | 
|---|
| 
 Updates an existing capacity commitment. Only  Plan can only be changed to a plan of a longer commitment period. Attempting to change to a plan with shorter commitment period will fail with the error code  
 | 
| UpdateReservation | 
|---|
| 
 Updates an existing reservation resource. 
 | 
Assignment
An assignment allows a project to submit jobs of a certain type using slots from the specified reservation.
| Fields | |
|---|---|
| name | 
 Output only. Name of the resource. E.g.:  | 
| assignee | 
 Optional. The resource which will use the reservation. E.g.  | 
| job_type | Optional. Which type of jobs will use the reservation. | 
| state | Output only. State of the assignment. | 
| enable_gemini_in_bigquery | 
 Optional. This field controls if "Gemini in BigQuery" (https://cloud.google.com/gemini/docs/bigquery/overview) features should be enabled for this reservation assignment, which is not on by default. "Gemini in BigQuery" has a distinct compliance posture from BigQuery. If this field is set to true, the assignment job type is QUERY, and the parent reservation edition is ENTERPRISE_PLUS, then the assignment will give the grantee project/organization access to "Gemini in BigQuery" features. | 
JobType
Types of job, which could be specified when using the reservation.
| Enums | |
|---|---|
| JOB_TYPE_UNSPECIFIED | Invalid type. Requests with this value will be rejected with error code google.rpc.Code.INVALID_ARGUMENT. | 
| PIPELINE | Pipeline (load/export) jobs from the project will use the reservation. | 
| QUERY | Query jobs from the project will use the reservation. | 
| ML_EXTERNAL | BigQuery ML jobs that use services external to BigQuery for model training. These jobs will not utilize idle slots from other reservations. | 
| BACKGROUND | Background jobs that BigQuery runs for the customers in the background. | 
| CONTINUOUS | Continuous SQL jobs will use this reservation. Reservations with continuous assignments cannot be mixed with non-continuous assignments. | 
| BACKGROUND_CHANGE_DATA_CAPTURE | Finer granularity background jobs for capturing changes in a source database and streaming them into BigQuery. Reservations with this job type take priority over a default BACKGROUND reservation assignment (if it exists). | 
| BACKGROUND_COLUMN_METADATA_INDEX | Finer granularity background jobs for refreshing cached metadata for BigQuery tables. Reservations with this job type take priority over a default BACKGROUND reservation assignment (if it exists). | 
| BACKGROUND_SEARCH_INDEX_REFRESH | Finer granularity background jobs for refreshing search indexes upon BigQuery table columns. Reservations with this job type take priority over a default BACKGROUND reservation assignment (if it exists). | 
State
Assignment will remain in PENDING state if no active capacity commitment is present. It will become ACTIVE when some capacity commitment becomes active.
| Enums | |
|---|---|
| STATE_UNSPECIFIED | Invalid state value. | 
| PENDING | Queries from assignee will be executed as on-demand, if related assignment is pending. | 
| ACTIVE | Assignment is ready. | 
BiReservation
Represents a BI Reservation.
| Fields | |
|---|---|
| name | 
 Identifier. The resource name of the singleton BI reservation. Reservation names have the form  | 
| update_time | Output only. The last update timestamp of a reservation. | 
| size | 
 Optional. Size of a reservation, in bytes. | 
| preferred_tables[] | Optional. Preferred tables to use BI capacity for. | 
CapacityCommitment
Capacity commitment is a way to purchase compute capacity for BigQuery jobs (in the form of slots) with some committed period of usage. Annual commitments renew by default. Commitments can be removed after their commitment end time passes.
In order to remove annual commitment, its plan needs to be changed to monthly or flex first.
A capacity commitment resource exists as a child resource of the admin project.
| Fields | |
|---|---|
| name | 
 Output only. The resource name of the capacity commitment, e.g.,  | 
| slot_count | 
 Optional. Number of slots in this commitment. | 
| plan | Optional. Capacity commitment commitment plan. | 
| state | Output only. State of the commitment. | 
| commitment_start_time | Output only. The start of the current commitment period. It is applicable only for ACTIVE capacity commitments. Note after the commitment is renewed, commitment_start_time won't be changed. It refers to the start time of the original commitment. | 
| commitment_end_time | Output only. The end of the current commitment period. It is applicable only for ACTIVE capacity commitments. Note after renewal, commitment_end_time is the time the renewed commitment expires. So itwould be at a time after commitment_start_time + committed period, because we don't change commitment_start_time , | 
| failure_status | Output only. For FAILED commitment plan, provides the reason of failure. | 
| renewal_plan | Optional. The plan this capacity commitment is converted to after commitment_end_time passes. Once the plan is changed, committed period is extended according to commitment plan. Only applicable for ANNUAL and TRIAL commitments. | 
| edition | Optional. Edition of the capacity commitment. | 
| is_flat_rate | 
 Output only. If true, the commitment is a flat-rate commitment, otherwise, it's an edition commitment. | 
CommitmentPlan
Commitment plan defines the current committed period. Capacity commitment cannot be deleted during it's committed period.
| Enums | |
|---|---|
| COMMITMENT_PLAN_UNSPECIFIED | Invalid plan value. Requests with this value will be rejected with error code google.rpc.Code.INVALID_ARGUMENT. | 
| FLEX | Flex commitments have committed period of 1 minute after becoming ACTIVE. After that, they are not in a committed period anymore and can be removed any time. | 
| FLEX_FLAT_RATE | Same as FLEX, should only be used if flat-rate commitments are still available. | 
| TRIAL | Trial commitments have a committed period of 182 days after becoming ACTIVE. After that, they are converted to a new commitment based on the  | 
| MONTHLY | Monthly commitments have a committed period of 30 days after becoming ACTIVE. After that, they are not in a committed period anymore and can be removed any time. | 
| MONTHLY_FLAT_RATE | Same as MONTHLY, should only be used if flat-rate commitments are still available. | 
| ANNUAL | Annual commitments have a committed period of 365 days after becoming ACTIVE. After that they are converted to a new commitment based on the renewal_plan. | 
| ANNUAL_FLAT_RATE | Same as ANNUAL, should only be used if flat-rate commitments are still available. | 
| THREE_YEAR | 3-year commitments have a committed period of 1095(3 * 365) days after becoming ACTIVE. After that they are converted to a new commitment based on the renewal_plan. | 
| NONE | Should only be used for renewal_planand is only meaningful if edition is specified to values other than EDITION_UNSPECIFIED. Otherwise CreateCapacityCommitmentRequest or UpdateCapacityCommitmentRequest will be rejected with error codegoogle.rpc.Code.INVALID_ARGUMENT. If the renewal_plan is NONE, capacity commitment will be removed at the end of its commitment period. | 
State
Capacity commitment can either become ACTIVE right away or transition from PENDING to ACTIVE or FAILED.
| Enums | |
|---|---|
| STATE_UNSPECIFIED | Invalid state value. | 
| PENDING | Capacity commitment is pending provisioning. Pending capacity commitment does not contribute to the project's slot_capacity. | 
| ACTIVE | Once slots are provisioned, capacity commitment becomes active. slot_count is added to the project's slot_capacity. | 
| FAILED | Capacity commitment is failed to be activated by the backend. | 
CreateAssignmentRequest
The request for ReservationService.CreateAssignment. Note: "bigquery.reservationAssignments.create" permission is required on the related assignee.
| Fields | |
|---|---|
| parent | 
 Required. The parent resource name of the assignment E.g.  Authorization requires the following IAM permission on the specified resource  
 | 
| assignment | Assignment resource to create. | 
| assignment_id | 
 The optional assignment ID. Assignment name will be generated automatically if this field is empty. This field must only contain lower case alphanumeric characters or dashes. Max length is 64 characters. | 
CreateCapacityCommitmentRequest
The request for ReservationService.CreateCapacityCommitment.
| Fields | |
|---|---|
| parent | 
 Required. Resource name of the parent reservation. E.g.,   Authorization requires the following IAM permission on the specified resource  
 | 
| capacity_commitment | Content of the capacity commitment to create. | 
| enforce_single_admin_project_per_org | 
 If true, fail the request if another project in the organization has a capacity commitment. | 
| capacity_commitment_id | 
 The optional capacity commitment ID. Capacity commitment name will be generated automatically if this field is empty. This field must only contain lower case alphanumeric characters or dashes. The first and last character cannot be a dash. Max length is 64 characters. NOTE: this ID won't be kept if the capacity commitment is split or merged. | 
CreateReservationRequest
The request for ReservationService.CreateReservation.
| Fields | |
|---|---|
| parent | 
 Required. Project, location. E.g.,  Authorization requires the following IAM permission on the specified resource  
 | 
| reservation_id | 
 The reservation ID. It must only contain lower case alphanumeric characters or dashes. It must start with a letter and must not end with a dash. Its maximum length is 64 characters. | 
| reservation | Definition of the new reservation to create. | 
DeleteAssignmentRequest
The request for ReservationService.DeleteAssignment. Note: "bigquery.reservationAssignments.delete" permission is required on the related assignee.
| Fields | |
|---|---|
| name | 
 Required. Name of the resource, e.g.   Authorization requires the following IAM permission on the specified resource  
 | 
DeleteCapacityCommitmentRequest
The request for ReservationService.DeleteCapacityCommitment.
| Fields | |
|---|---|
| name | 
 Required. Resource name of the capacity commitment to delete. E.g.,   Authorization requires the following IAM permission on the specified resource  
 | 
| force | 
 Can be used to force delete commitments even if assignments exist. Deleting commitments with assignments may cause queries to fail if they no longer have access to slots. | 
DeleteReservationRequest
The request for ReservationService.DeleteReservation.
| Fields | |
|---|---|
| name | 
 Required. Resource name of the reservation to retrieve. E.g.,   Authorization requires the following IAM permission on the specified resource  
 | 
Edition
The type of editions. Different features and behaviors are provided to different editions Capacity commitments and reservations are linked to editions.
| Enums | |
|---|---|
| EDITION_UNSPECIFIED | Default value, which will be treated as ENTERPRISE. | 
| STANDARD | Standard edition. | 
| ENTERPRISE | Enterprise edition. | 
| ENTERPRISE_PLUS | Enterprise Plus edition. | 
FailoverMode
The failover mode when a user initiates a failover on a reservation determines how writes that are pending replication are handled after the failover is initiated.
| Enums | |
|---|---|
| FAILOVER_MODE_UNSPECIFIED | Invalid value. | 
| SOFT | When customers initiate a soft failover, BigQuery will wait until all committed writes are replicated to the secondary. This mode requires both regions to be available for the failover to succeed and prevents data loss. | 
| HARD | When customers initiate a hard failover, BigQuery will not wait until all committed writes are replicated to the secondary. There can be data loss for hard failover. | 
FailoverReservationRequest
The request for ReservationService.FailoverReservation.
| Fields | |
|---|---|
| name | 
 Required. Resource name of the reservation to failover. E.g.,   Authorization requires the following IAM permission on the specified resource  
 | 
| failover_mode | Optional. A parameter that determines how writes that are pending replication are handled after a failover is initiated. If not specified, HARD failover mode is used by default. | 
GetBiReservationRequest
A request to get a singleton BI reservation.
| Fields | |
|---|---|
| name | 
 Required. Name of the requested reservation, for example:  Authorization requires the following IAM permission on the specified resource  
 | 
GetCapacityCommitmentRequest
The request for ReservationService.GetCapacityCommitment.
| Fields | |
|---|---|
| name | 
 Required. Resource name of the capacity commitment to retrieve. E.g.,   Authorization requires the following IAM permission on the specified resource  
 | 
GetReservationRequest
The request for ReservationService.GetReservation.
| Fields | |
|---|---|
| name | 
 Required. Resource name of the reservation to retrieve. E.g.,   Authorization requires the following IAM permission on the specified resource  
 | 
ListAssignmentsRequest
The request for ReservationService.ListAssignments.
| Fields | |
|---|---|
| parent | 
 Required. The parent resource name e.g.: 
 Or: 
 Authorization requires the following IAM permission on the specified resource  
 | 
| page_size | 
 The maximum number of items to return per page. | 
| page_token | 
 The next_page_token value returned from a previous List request, if any. | 
ListAssignmentsResponse
The response for ReservationService.ListAssignments.
| Fields | |
|---|---|
| assignments[] | List of assignments visible to the user. | 
| next_page_token | 
 Token to retrieve the next page of results, or empty if there are no more results in the list. | 
ListCapacityCommitmentsRequest
The request for ReservationService.ListCapacityCommitments.
| Fields | |
|---|---|
| parent | 
 Required. Resource name of the parent reservation. E.g.,   Authorization requires the following IAM permission on the specified resource  
 | 
| page_size | 
 The maximum number of items to return. | 
| page_token | 
 The next_page_token value returned from a previous List request, if any. | 
ListCapacityCommitmentsResponse
The response for ReservationService.ListCapacityCommitments.
| Fields | |
|---|---|
| capacity_commitments[] | List of capacity commitments visible to the user. | 
| next_page_token | 
 Token to retrieve the next page of results, or empty if there are no more results in the list. | 
ListReservationsRequest
The request for ReservationService.ListReservations.
| Fields | |
|---|---|
| parent | 
 Required. The parent resource name containing project and location, e.g.:   Authorization requires the following IAM permission on the specified resource  
 | 
| page_size | 
 The maximum number of items to return per page. | 
| page_token | 
 The next_page_token value returned from a previous List request, if any. | 
ListReservationsResponse
The response for ReservationService.ListReservations.
| Fields | |
|---|---|
| reservations[] | List of reservations visible to the user. | 
| next_page_token | 
 Token to retrieve the next page of results, or empty if there are no more results in the list. | 
MergeCapacityCommitmentsRequest
The request for ReservationService.MergeCapacityCommitments.
| Fields | |
|---|---|
| parent | 
 Parent resource that identifies admin project and location e.g.,   Authorization requires the following IAM permission on the specified resource  
 | 
| capacity_commitment_ids[] | 
 Ids of capacity commitments to merge. These capacity commitments must exist under admin project and location specified in the parent. ID is the last portion of capacity commitment name e.g., 'abc' for projects/myproject/locations/US/capacityCommitments/abc | 
| capacity_commitment_id | 
 Optional. The optional resulting capacity commitment ID. Capacity commitment name will be generated automatically if this field is empty. This field must only contain lower case alphanumeric characters or dashes. The first and last character cannot be a dash. Max length is 64 characters. | 
MoveAssignmentRequest
The request for ReservationService.MoveAssignment.
Note: "bigquery.reservationAssignments.create" permission is required on the destination_id.
Note: "bigquery.reservationAssignments.create" and "bigquery.reservationAssignments.delete" permission are required on the related assignee.
| Fields | |
|---|---|
| name | 
 Required. The resource name of the assignment, e.g.  Authorization requires the following IAM permission on the specified resource  
 | 
| destination_id | 
 The new reservation ID, e.g.:   | 
| assignment_id | 
 The optional assignment ID. A new assignment name is generated if this field is empty. This field can contain only lowercase alphanumeric characters or dashes. Max length is 64 characters. | 
Reservation
A reservation is a mechanism used to guarantee slots to users.
| Fields | |
|---|---|
| name | 
 Identifier. The resource name of the reservation, e.g.,  | 
| slot_capacity | 
 Optional. Baseline slots available to this reservation. A slot is a unit of computational power in BigQuery, and serves as the unit of parallelism. Queries using this reservation might use more slots during runtime if ignore_idle_slots is set to false, or autoscaling is enabled. The total slot_capacity of the reservation and its siblings may exceed the total slot_count of capacity commitments. In that case, the exceeding slots will be charged with the autoscale SKU. You can increase the number of baseline slots in a reservation every few minutes. If you want to decrease your baseline slots, you are limited to once an hour if you have recently changed your baseline slot capacity and your baseline slots exceed your committed slots. Otherwise, you can decrease your baseline slots every few minutes. | 
| ignore_idle_slots | 
 Optional. If false, any query or pipeline job using this reservation will use idle slots from other reservations within the same admin project. If true, a query or pipeline job using this reservation will execute with the slot capacity specified in the slot_capacity field at most. | 
| autoscale | Optional. The configuration parameters for the auto scaling feature. | 
| concurrency | 
 Optional. Job concurrency target which sets a soft upper bound on the number of jobs that can run concurrently in this reservation. This is a soft target due to asynchronous nature of the system and various optimizations for small queries. Default value is 0 which means that concurrency target will be automatically computed by the system. NOTE: this field is exposed as target job concurrency in the Information Schema, DDL and BigQuery CLI. | 
| creation_time | Output only. Creation time of the reservation. | 
| update_time | Output only. Last update time of the reservation. | 
| edition | Optional. Edition of the reservation. | 
| primary_location | 
 Output only. The current location of the reservation's primary replica. This field is only set for reservations using the managed disaster recovery feature. | 
| secondary_location | 
 Optional. The current location of the reservation's secondary replica. This field is only set for reservations using the managed disaster recovery feature. Users can set this in create reservation calls to create a failover reservation or in update reservation calls to convert a non-failover reservation to a failover reservation(or vice versa). | 
| original_primary_location | 
 Output only. The location where the reservation was originally created. This is set only during the failover reservation's creation. All billing charges for the failover reservation will be applied to this location. | 
| scaling_mode | Optional. The scaling mode for the reservation. If the field is present but max_slots is not present, requests will be rejected with error code  | 
| replication_status | Output only. The Disaster Recovery(DR) replication status of the reservation. This is only available for the primary replicas of DR/failover reservations and provides information about the both the staleness of the secondary and the last error encountered while trying to replicate changes from the primary to the secondary. If this field is blank, it means that the reservation is either not a DR reservation or the reservation is a DR secondary or that any replication operations on the reservation have succeeded. | 
| max_slots | 
 Optional. The overall max slots for the reservation, covering slot_capacity (baseline), idle slots (if ignore_idle_slots is false) and scaled slots. If present, the reservation won't use more than the specified number of slots, even if there is demand and supply (from idle slots). NOTE: capping a reservation's idle slot usage is best effort and its usage may exceed the max_slots value. However, in terms of autoscale.current_slots (which accounts for the additional added slots), it will never exceed the max_slots - baseline. This field must be set together with the scaling_mode enum value, otherwise the request will be rejected with error code  If the max_slots and scaling_mode are set, the autoscale or autoscale.max_slots field must be unset. Otherwise the request will be rejected with error code  If the max_slots is 1000, scaling_mode is ALL_SLOTS, the baseline is 100 and idle slots usage is 200, then in the output, the autoscaler.max_slots will be 0 and the autoscaler.current_slots will not be higher than 700. If the max_slots is 1000, scaling_mode is IDLE_SLOTS_ONLY, then in the output, the autoscaler field will be null. If the max_slots and scaling_mode are set, then the ignore_idle_slots field must be aligned with the scaling_mode enum value.(See details in ScalingMode comments). Otherwise the request will be rejected with error code  Please note, the max_slots is for user to manage the part of slots greater than the baseline. Therefore, we don't allow users to set max_slots smaller or equal to the baseline as it will not be meaningful. If the field is present and slot_capacity>=max_slots, requests will be rejected with error code  Please note that if max_slots is set to 0, we will treat it as unset. Customers can set max_slots to 0 and set scaling_mode to SCALING_MODE_UNSPECIFIED to disable the max_slots feature. | 
Autoscale
Auto scaling settings.
| Fields | |
|---|---|
| current_slots | 
 Output only. The slot capacity added to this reservation when autoscale happens. Will be between [0, max_slots]. Note: after users reduce max_slots, it may take a while before it can be propagated, so current_slots may stay in the original value and could be larger than max_slots for that brief period (less than one minute) | 
| max_slots | 
 Optional. Number of slots to be scaled when needed. | 
ReplicationStatus
Disaster Recovery(DR) replication status of the reservation.
| Fields | |
|---|---|
| error | Output only. The last error encountered while trying to replicate changes from the primary to the secondary. This field is only available if the replication has not succeeded since. | 
| last_error_time | Output only. The time at which the last error was encountered while trying to replicate changes from the primary to the secondary. This field is only available if the replication has not succeeded since. | 
| last_replication_time | Output only. A timestamp corresponding to the last change on the primary that was successfully replicated to the secondary. | 
| soft_failover_start_time | Output only. The time at which a soft failover for the reservation and its associated datasets was initiated. After this field is set, all subsequent changes to the reservation will be rejected unless a hard failover overrides this operation. This field will be cleared once the failover is complete. | 
ScalingMode
The scaling mode for the reservation. This enum determines how the reservation scales up and down.
| Enums | |
|---|---|
| SCALING_MODE_UNSPECIFIED | Default value of ScalingMode. | 
| AUTOSCALE_ONLY | The reservation will scale up only using slots from autoscaling. It will not use any idle slots even if there may be some available. The upper limit that autoscaling can scale up to will be max_slots - baseline. For example, if max_slots is 1000, baseline is 200 and customer sets ScalingMode to AUTOSCALE_ONLY, then autoscalerg will scale up to 800 slots and no idle slots will be used. Please note, in this mode, the ignore_idle_slots field must be set to true. Otherwise the request will be rejected with error code  | 
| IDLE_SLOTS_ONLY | The reservation will scale up using only idle slots contributed by other reservations or from unassigned commitments. If no idle slots are available it will not scale up further. If the idle slots which it is using are reclaimed by the contributing reservation(s) it may be forced to scale down. The max idle slots the reservation can be max_slots - baseline capacity. For example, if max_slots is 1000, baseline is 200 and customer sets ScalingMode to IDLE_SLOTS_ONLY, 1. if there are 1000 idle slots available in other reservations, the reservation will scale up to 1000 slots with 200 baseline and 800 idle slots. 2. if there are 500 idle slots available in other reservations, the reservation will scale up to 700 slots with 200 baseline and 300 idle slots. Please note, in this mode, the reservation might not be able to scale up to max_slots. Please note, in this mode, the ignore_idle_slots field must be set to false. Otherwise the request will be rejected with error code  | 
| ALL_SLOTS | The reservation will scale up using all slots available to it. It will use idle slots contributed by other reservations or from unassigned commitments first. If no idle slots are available it will scale up using autoscaling. For example, if max_slots is 1000, baseline is 200 and customer sets ScalingMode to ALL_SLOTS, 1. if there are 800 idle slots available in other reservations, the reservation will scale up to 1000 slots with 200 baseline and 800 idle slots. 2. if there are 500 idle slots available in other reservations, the reservation will scale up to 1000 slots with 200 baseline, 500 idle slots and 300 autoscaling slots. 3. if there are no idle slots available in other reservations, it will scale up to 1000 slots with 200 baseline and 800 autoscaling slots. Please note, in this mode, the ignore_idle_slots field must be set to false. Otherwise the request will be rejected with error code  | 
SearchAllAssignmentsRequest
The request for ReservationService.SearchAllAssignments. Note: "bigquery.reservationAssignments.search" permission is required on the related assignee.
| Fields | |
|---|---|
| parent | 
 Required. The resource name with location (project name could be the wildcard '-'), e.g.:   Authorization requires the following IAM permission on the specified resource  
 | 
| query | 
 Please specify resource name as assignee in the query. Examples: 
 | 
| page_size | 
 The maximum number of items to return per page. | 
| page_token | 
 The next_page_token value returned from a previous List request, if any. | 
SearchAllAssignmentsResponse
The response for ReservationService.SearchAllAssignments.
| Fields | |
|---|---|
| assignments[] | List of assignments visible to the user. | 
| next_page_token | 
 Token to retrieve the next page of results, or empty if there are no more results in the list. | 
SearchAssignmentsRequest
The request for ReservationService.SearchAssignments. Note: "bigquery.reservationAssignments.search" permission is required on the related assignee.
| Fields | |
|---|---|
| parent | 
 Required. The resource name of the admin project(containing project and location), e.g.:   Authorization requires the following IAM permission on the specified resource  
 | 
| query | 
 Please specify resource name as assignee in the query. Examples: 
 | 
| page_size | 
 The maximum number of items to return per page. | 
| page_token | 
 The next_page_token value returned from a previous List request, if any. | 
SearchAssignmentsResponse
The response for ReservationService.SearchAssignments.
| Fields | |
|---|---|
| assignments[] | List of assignments visible to the user. | 
| next_page_token | 
 Token to retrieve the next page of results, or empty if there are no more results in the list. | 
SplitCapacityCommitmentRequest
The request for ReservationService.SplitCapacityCommitment.
| Fields | |
|---|---|
| name | 
 Required. The resource name e.g.,:   Authorization requires the following IAM permission on the specified resource  
 | 
| slot_count | 
 Number of slots in the capacity commitment after the split. | 
SplitCapacityCommitmentResponse
The response for ReservationService.SplitCapacityCommitment.
| Fields | |
|---|---|
| first | First capacity commitment, result of a split. | 
| second | Second capacity commitment, result of a split. | 
TableReference
Fully qualified reference to BigQuery table. Internally stored as google.cloud.bi.v1.BqTableReference.
| Fields | |
|---|---|
| project_id | 
 Optional. The assigned project ID of the project. | 
| dataset_id | 
 Optional. The ID of the dataset in the above project. | 
| table_id | 
 Optional. The ID of the table in the above dataset. | 
UpdateAssignmentRequest
The request for ReservationService.UpdateAssignment.
| Fields | |
|---|---|
| assignment | Content of the assignment to update. Authorization requires the following IAM permission on the specified resource  
 | 
| update_mask | Standard field mask for the set of fields to be updated. | 
UpdateBiReservationRequest
A request to update a BI reservation.
| Fields | |
|---|---|
| bi_reservation | A reservation to update. Authorization requires the following IAM permission on the specified resource  
 | 
| update_mask | A list of fields to be updated in this request. | 
UpdateCapacityCommitmentRequest
The request for ReservationService.UpdateCapacityCommitment.
| Fields | |
|---|---|
| capacity_commitment | Content of the capacity commitment to update. Authorization requires the following IAM permission on the specified resource  
 | 
| update_mask | Standard field mask for the set of fields to be updated. | 
UpdateReservationRequest
The request for ReservationService.UpdateReservation.
| Fields | |
|---|---|
| reservation | Content of the reservation to update. Authorization requires the following IAM permission on the specified resource  
 | 
| update_mask | Standard field mask for the set of fields to be updated. |