com.hazelcast.org.apache.calcite.config.CalciteConnectionConfig Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to you 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
*
* http://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.hazelcast.org.apache.calcite.config;
import com.hazelcast.org.apache.calcite.avatica.ConnectionConfig;
import com.hazelcast.org.apache.calcite.avatica.util.Casing;
import com.hazelcast.org.apache.calcite.avatica.util.Quoting;
import com.hazelcast.org.apache.calcite.model.JsonSchema;
import com.hazelcast.org.apache.calcite.sql.validate.SqlConformance;
import com.hazelcast.org.checkerframework.checker.nullness.qual.Nullable;
import com.hazelcast.org.checkerframework.checker.nullness.qual.PolyNull;
import java.util.Properties;
/** Interface for reading connection properties within Calcite code. There is
* a method for every property. At some point there will be similar config
* classes for system and statement properties. */
public interface CalciteConnectionConfig extends ConnectionConfig {
/** Default configuration. */
CalciteConnectionConfigImpl DEFAULT =
new CalciteConnectionConfigImpl(new Properties());
/** Returns the value of
* {@link CalciteConnectionProperty#APPROXIMATE_DISTINCT_COUNT}. */
boolean approximateDistinctCount();
/** Returns the value of
* {@link CalciteConnectionProperty#APPROXIMATE_TOP_N}. */
boolean approximateTopN();
/** Returns the value of
* {@link CalciteConnectionProperty#APPROXIMATE_DECIMAL}. */
boolean approximateDecimal();
/** Returns the value of
* {@link CalciteConnectionProperty#NULL_EQUAL_TO_EMPTY}. */
boolean nullEqualToEmpty();
/** Returns the value of
* {@link CalciteConnectionProperty#AUTO_TEMP}. */
boolean autoTemp();
/** Returns the value of
* {@link CalciteConnectionProperty#MATERIALIZATIONS_ENABLED}. */
boolean materializationsEnabled();
/** Returns the value of
* {@link CalciteConnectionProperty#CREATE_MATERIALIZATIONS}. */
boolean createMaterializations();
/** Returns the value of
* {@link CalciteConnectionProperty#DEFAULT_NULL_COLLATION}. */
NullCollation defaultNullCollation();
/** Returns the value of {@link CalciteConnectionProperty#FUN},
* or a default operator table if not set. If {@code defaultOperatorTable}
* is not null, the result is never null. */
@PolyNull T fun(Class operatorTableClass,
@PolyNull T defaultOperatorTable);
/** Returns the value of {@link CalciteConnectionProperty#MODEL}. */
@Nullable String model();
/** Returns the value of {@link CalciteConnectionProperty#LEX}. */
Lex lex();
/** Returns the value of {@link CalciteConnectionProperty#QUOTING}. */
Quoting quoting();
/** Returns the value of {@link CalciteConnectionProperty#UNQUOTED_CASING}. */
Casing unquotedCasing();
/** Returns the value of {@link CalciteConnectionProperty#QUOTED_CASING}. */
Casing quotedCasing();
/** Returns the value of {@link CalciteConnectionProperty#CASE_SENSITIVE}. */
boolean caseSensitive();
/** Returns the value of {@link CalciteConnectionProperty#PARSER_FACTORY},
* or a default parser if not set. If {@code defaultParserFactory}
* is not null, the result is never null. */
@PolyNull T parserFactory(Class parserFactoryClass,
@PolyNull T defaultParserFactory);
/** Returns the value of {@link CalciteConnectionProperty#SCHEMA_FACTORY},
* or a default schema factory if not set. If {@code defaultSchemaFactory}
* is not null, the result is never null. */
@PolyNull T schemaFactory(Class schemaFactoryClass,
@PolyNull T defaultSchemaFactory);
/** Returns the value of {@link CalciteConnectionProperty#SCHEMA_TYPE}. */
JsonSchema.Type schemaType();
/** Returns the value of {@link CalciteConnectionProperty#SPARK}. */
boolean spark();
/** Returns the value of
* {@link CalciteConnectionProperty#FORCE_DECORRELATE}. */
boolean forceDecorrelate();
/** Returns the value of {@link CalciteConnectionProperty#TYPE_SYSTEM},
* or a default type system if not set. If {@code defaultTypeSystem}
* is not null, the result is never null. */
@PolyNull T typeSystem(Class typeSystemClass,
@PolyNull T defaultTypeSystem);
/** Returns the value of {@link CalciteConnectionProperty#CONFORMANCE}. */
SqlConformance conformance();
/** Returns the value of {@link CalciteConnectionProperty#TIME_ZONE}. */
@Override String timeZone();
/** Returns the value of {@link CalciteConnectionProperty#LOCALE}. */
String locale();
/** Returns the value of {@link CalciteConnectionProperty#TYPE_COERCION}. */
boolean typeCoercion();
/** Returns the value of
* {@link CalciteConnectionProperty#LENIENT_OPERATOR_LOOKUP}. */
boolean lenientOperatorLookup();
/** Returns the value of {@link CalciteConnectionProperty#TOPDOWN_OPT}. */
boolean topDownOpt();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy