All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.google.cloud.hadoop.io.bigquery.output.BigQueryTableSchema Maven / Gradle / Ivy

/*
 * Copyright 2018 Google LLC
 *
 *  Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
 * in compliance with the License. You may obtain a copy of the License at
 *
 *     https://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software distributed under the
 * License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
 * express or implied. See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.google.cloud.hadoop.io.bigquery.output;

import com.google.api.services.bigquery.model.TableFieldSchema;
import com.google.api.services.bigquery.model.TableSchema;
import com.google.common.base.Preconditions;
import java.util.ArrayList;
import java.util.List;

/**
 * Wrapper for BigQuery {@link TableSchema}.
 *
 * 

This class is used to avoid client code to depend on BigQuery API classes, so that there is no * potential conflict between different versions of BigQuery API libraries in the client. * * @see TableSchema */ public class BigQueryTableSchema { private final TableSchema tableSchema; public BigQueryTableSchema() { this.tableSchema = new TableSchema(); } BigQueryTableSchema(TableSchema tableSchema) { Preconditions.checkNotNull(tableSchema, "tableSchema is null."); this.tableSchema = tableSchema; } /** @see TableSchema#setFields(List) */ public BigQueryTableSchema setFields(List bigQueryTableFields) { Preconditions.checkArgument(!bigQueryTableFields.isEmpty(), "Empty fields."); List fields = new ArrayList<>(bigQueryTableFields.size()); for (BigQueryTableFieldSchema bigQueryTableField : bigQueryTableFields) { fields.add(bigQueryTableField.get()); } tableSchema.setFields(fields); return this; } @Override public int hashCode() { return tableSchema.hashCode(); } @Override public boolean equals(Object object) { if (!(object instanceof BigQueryTableSchema)) { return false; } BigQueryTableSchema another = (BigQueryTableSchema) object; return tableSchema.equals(another.tableSchema); } TableSchema get() { return tableSchema; } static BigQueryTableSchema wrap(TableSchema tableSchema) { return new BigQueryTableSchema(tableSchema); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy