Skip to content

Commit

Permalink
Add a system table to list all ANALYZE properties
Browse files Browse the repository at this point in the history
  • Loading branch information
jessesleeping committed Mar 4, 2019
1 parent c61787e commit 75473c1
Show file tree
Hide file tree
Showing 8 changed files with 54 additions and 1 deletion.
4 changes: 3 additions & 1 deletion presto-docs/src/main/sphinx/sql/analyze.rst
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,9 @@ Description
Collects table and column statistics for a given table.

The optional ``WITH`` clause can be used to provide
connector-specific properties.
connector-specific properties. To list all available properties, run the following query::

SELECT * FROM system.metadata.analyze_properties

Currently, this statement is only supported by the
:ref:`Hive connector <hive_analyze>`.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3083,6 +3083,13 @@ public void testCollectColumnStatisticsOnInsert()
assertUpdate(format("DROP TABLE %s", tableName));
}

@Test
public void testAnalyzePropertiesSystemTable()
{
assertQuery("SELECT * FROM system.metadata.analyze_properties WHERE catalog_name = 'hive'",
"SELECT 'hive', 'partitions', '', 'array(array(varchar))', 'Partitions to be analyzed'");
}

@Test
public void testAnalyzeEmptyTable()
{
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
/*
* 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
*
* 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.facebook.presto.connector.system;

import com.facebook.presto.metadata.Metadata;
import com.facebook.presto.transaction.TransactionManager;

import javax.inject.Inject;

public class AnalyzePropertiesSystemTable
extends AbstractPropertiesSystemTable
{
@Inject
public AnalyzePropertiesSystemTable(TransactionManager transactionManager, Metadata metadata)
{
super("analyze_properties", transactionManager, () -> metadata.getAnalyzePropertyManager().getAllProperties());
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,7 @@ public void configure(Binder binder)
globalTableBinder.addBinding().to(SchemaPropertiesSystemTable.class).in(Scopes.SINGLETON);
globalTableBinder.addBinding().to(TablePropertiesSystemTable.class).in(Scopes.SINGLETON);
globalTableBinder.addBinding().to(ColumnPropertiesSystemTable.class).in(Scopes.SINGLETON);
globalTableBinder.addBinding().to(AnalyzePropertiesSystemTable.class).in(Scopes.SINGLETON);
globalTableBinder.addBinding().to(TransactionsSystemTable.class).in(Scopes.SINGLETON);

globalTableBinder.addBinding().to(AttributeJdbcTable.class).in(Scopes.SINGLETON);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
import com.facebook.presto.block.BlockEncodingManager;
import com.facebook.presto.connector.ConnectorId;
import com.facebook.presto.connector.ConnectorManager;
import com.facebook.presto.connector.system.AnalyzePropertiesSystemTable;
import com.facebook.presto.connector.system.CatalogSystemTable;
import com.facebook.presto.connector.system.ColumnPropertiesSystemTable;
import com.facebook.presto.connector.system.GlobalSystemConnector;
Expand Down Expand Up @@ -345,6 +346,7 @@ private LocalQueryRunner(Session defaultSession, FeaturesConfig featuresConfig,
new SchemaPropertiesSystemTable(transactionManager, metadata),
new TablePropertiesSystemTable(transactionManager, metadata),
new ColumnPropertiesSystemTable(transactionManager, metadata),
new AnalyzePropertiesSystemTable(transactionManager, metadata),
new TransactionsSystemTable(typeRegistry, transactionManager)),
ImmutableSet.of());

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,11 @@ system| information_schema| views| table_catalog| varchar| YES| null| null|
system| information_schema| views| table_schema| varchar| YES| null| null|
system| information_schema| views| table_name| varchar| YES| null| null|
system| information_schema| views| view_definition| varchar| YES| null| null|
system| metadata| analyze_properties| catalog_name| varchar| YES| null| null|
system| metadata| analyze_properties| property_name| varchar| YES| null| null|
system| metadata| analyze_properties| default_value| varchar| YES| null| null|
system| metadata| analyze_properties| type| varchar| YES| null| null|
system| metadata| analyze_properties| description| varchar| YES| null| null|
system| metadata| catalogs| catalog_name| varchar| YES| null| null|
system| metadata| catalogs| connector_id| varchar| YES| null| null|
system| metadata| column_properties| catalog_name| varchar| YES| null| null|
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
-- delimiter: |; ignoreOrder: true;
catalogs|
analyze_properties|
schema_properties|
table_properties|
column_properties|
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,12 @@ public void testTooLongQuery()
assertQueryFails(longQuery, "Query text length \\(1000037\\) exceeds the maximum length \\(1000000\\)");
}

@Test
public void testAnalyzePropertiesSystemTable()
{
assertQuery("SELECT COUNT(*) FROM system.metadata.analyze_properties WHERE catalog_name = 'tpch'", "SELECT 0");
}

@Test
public void testAnalyze()
{
Expand Down

0 comments on commit 75473c1

Please sign in to comment.