diff --git a/src/catalog/src/information_schema.rs b/src/catalog/src/information_schema.rs index 5bbfb1c6d88f..232c2279d938 100644 --- a/src/catalog/src/information_schema.rs +++ b/src/catalog/src/information_schema.rs @@ -14,6 +14,7 @@ mod columns; mod memory_table; +mod schemata; mod table_names; mod tables; @@ -41,6 +42,7 @@ pub use table_names::*; use self::columns::InformationSchemaColumns; use crate::error::Result; use crate::information_schema::memory_table::{get_schema_columns, MemoryTable}; +use crate::information_schema::schemata::InformationSchemaSchemata; use crate::information_schema::tables::InformationSchemaTables; use crate::CatalogManager; @@ -126,6 +128,7 @@ impl InformationSchemaProvider { fn build_tables(&mut self) { let mut tables = HashMap::new(); tables.insert(TABLES.to_string(), self.build_table(TABLES).unwrap()); + tables.insert(SCHEMATA.to_string(), self.build_table(SCHEMATA).unwrap()); tables.insert(COLUMNS.to_string(), self.build_table(COLUMNS).unwrap()); // Add memory tables @@ -168,6 +171,10 @@ impl InformationSchemaProvider { } CHECK_CONSTRAINTS => setup_memory_table!(CHECK_CONSTRAINTS), EVENTS => setup_memory_table!(EVENTS), + SCHEMATA => Some(Arc::new(InformationSchemaSchemata::new( + self.catalog_name.clone(), + self.catalog_manager.clone(), + )) as _), _ => None, } } diff --git a/src/catalog/src/information_schema/columns.rs b/src/catalog/src/information_schema/columns.rs index 53f338783ad3..27d4921928e8 100644 --- a/src/catalog/src/information_schema/columns.rs +++ b/src/catalog/src/information_schema/columns.rs @@ -51,6 +51,10 @@ const TABLE_NAME: &str = "table_name"; const COLUMN_NAME: &str = "column_name"; const DATA_TYPE: &str = "data_type"; const SEMANTIC_TYPE: &str = "semantic_type"; +const COLUMN_DEFAULT: &str = "column_default"; +const IS_NULLABLE: &str = "is_nullable"; +const COLUMN_TYPE: &str = "column_type"; +const COLUMN_COMMENT: &str = "column_comment"; impl InformationSchemaColumns { pub(super) fn new(catalog_name: String, catalog_manager: Weak) -> Self { @@ -69,6 +73,10 @@ impl InformationSchemaColumns { ColumnSchema::new(COLUMN_NAME, ConcreteDataType::string_datatype(), false), ColumnSchema::new(DATA_TYPE, ConcreteDataType::string_datatype(), false), ColumnSchema::new(SEMANTIC_TYPE, ConcreteDataType::string_datatype(), false), + ColumnSchema::new(COLUMN_DEFAULT, ConcreteDataType::string_datatype(), true), + ColumnSchema::new(IS_NULLABLE, ConcreteDataType::string_datatype(), false), + ColumnSchema::new(COLUMN_TYPE, ConcreteDataType::string_datatype(), false), + ColumnSchema::new(COLUMN_COMMENT, ConcreteDataType::string_datatype(), true), ])) } @@ -126,6 +134,11 @@ struct InformationSchemaColumnsBuilder { column_names: StringVectorBuilder, data_types: StringVectorBuilder, semantic_types: StringVectorBuilder, + + column_defaults: StringVectorBuilder, + is_nullables: StringVectorBuilder, + column_types: StringVectorBuilder, + column_comments: StringVectorBuilder, } impl InformationSchemaColumnsBuilder { @@ -144,6 +157,10 @@ impl InformationSchemaColumnsBuilder { column_names: StringVectorBuilder::with_capacity(42), data_types: StringVectorBuilder::with_capacity(42), semantic_types: StringVectorBuilder::with_capacity(42), + column_defaults: StringVectorBuilder::with_capacity(42), + is_nullables: StringVectorBuilder::with_capacity(42), + column_types: StringVectorBuilder::with_capacity(42), + column_comments: StringVectorBuilder::with_capacity(42), } } @@ -187,9 +204,8 @@ impl InformationSchemaColumnsBuilder { &catalog_name, &schema_name, &table_name, - &column.name, - &column.data_type.name(), semantic_type, + column, ); } } else { @@ -206,16 +222,31 @@ impl InformationSchemaColumnsBuilder { catalog_name: &str, schema_name: &str, table_name: &str, - column_name: &str, - data_type: &str, semantic_type: &str, + column_schema: &ColumnSchema, ) { + let data_type = &column_schema.data_type.name(); + self.catalog_names.push(Some(catalog_name)); self.schema_names.push(Some(schema_name)); self.table_names.push(Some(table_name)); - self.column_names.push(Some(column_name)); + self.column_names.push(Some(&column_schema.name)); self.data_types.push(Some(data_type)); self.semantic_types.push(Some(semantic_type)); + self.column_defaults.push( + column_schema + .default_constraint() + .map(|s| format!("{}", s)) + .as_deref(), + ); + if column_schema.is_nullable() { + self.is_nullables.push(Some("Yes")); + } else { + self.is_nullables.push(Some("No")); + } + self.column_types.push(Some(data_type)); + self.column_comments + .push(column_schema.column_comment().map(|x| x.as_ref())); } fn finish(&mut self) -> Result { @@ -226,6 +257,10 @@ impl InformationSchemaColumnsBuilder { Arc::new(self.column_names.finish()), Arc::new(self.data_types.finish()), Arc::new(self.semantic_types.finish()), + Arc::new(self.column_defaults.finish()), + Arc::new(self.is_nullables.finish()), + Arc::new(self.column_types.finish()), + Arc::new(self.column_comments.finish()), ]; RecordBatch::new(self.schema.clone(), columns).context(CreateRecordBatchSnafu) diff --git a/src/catalog/src/information_schema/schemata.rs b/src/catalog/src/information_schema/schemata.rs new file mode 100644 index 000000000000..8f523f7a9383 --- /dev/null +++ b/src/catalog/src/information_schema/schemata.rs @@ -0,0 +1,210 @@ +// Copyright 2023 Greptime Team +// +// 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. + +use std::sync::{Arc, Weak}; + +use arrow_schema::SchemaRef as ArrowSchemaRef; +use common_catalog::consts::INFORMATION_SCHEMA_SCHEMATA_TABLE_ID; +use common_error::ext::BoxedError; +use common_query::physical_plan::TaskContext; +use common_recordbatch::adapter::RecordBatchStreamAdapter; +use common_recordbatch::{RecordBatch, SendableRecordBatchStream}; +use datafusion::physical_plan::stream::RecordBatchStreamAdapter as DfRecordBatchStreamAdapter; +use datafusion::physical_plan::streaming::PartitionStream as DfPartitionStream; +use datafusion::physical_plan::SendableRecordBatchStream as DfSendableRecordBatchStream; +use datatypes::prelude::{ConcreteDataType, ScalarVectorBuilder, VectorRef}; +use datatypes::schema::{ColumnSchema, Schema, SchemaRef}; +use datatypes::vectors::StringVectorBuilder; +use snafu::{OptionExt, ResultExt}; +use store_api::storage::TableId; + +use super::SCHEMATA; +use crate::error::{ + CreateRecordBatchSnafu, InternalSnafu, Result, UpgradeWeakCatalogManagerRefSnafu, +}; +use crate::information_schema::InformationTable; +use crate::CatalogManager; + +/// The `information_schema.schemata` table implementation. +pub(super) struct InformationSchemaSchemata { + schema: SchemaRef, + catalog_name: String, + catalog_manager: Weak, +} + +impl InformationSchemaSchemata { + pub(super) fn new(catalog_name: String, catalog_manager: Weak) -> Self { + Self { + schema: Self::schema(), + catalog_name, + catalog_manager, + } + } + + pub(crate) fn schema() -> SchemaRef { + Arc::new(Schema::new(vec![ + ColumnSchema::new("catalog_name", ConcreteDataType::string_datatype(), false), + ColumnSchema::new("schema_name", ConcreteDataType::string_datatype(), false), + ColumnSchema::new( + "default_character_set_name", + ConcreteDataType::string_datatype(), + false, + ), + ColumnSchema::new( + "default_collation_name", + ConcreteDataType::string_datatype(), + false, + ), + ColumnSchema::new("sql_path", ConcreteDataType::string_datatype(), true), + ])) + } + + fn builder(&self) -> InformationSchemaSchemataBuilder { + InformationSchemaSchemataBuilder::new( + self.schema.clone(), + self.catalog_name.clone(), + self.catalog_manager.clone(), + ) + } +} + +impl InformationTable for InformationSchemaSchemata { + fn table_id(&self) -> TableId { + INFORMATION_SCHEMA_SCHEMATA_TABLE_ID + } + + fn table_name(&self) -> &'static str { + SCHEMATA + } + + fn schema(&self) -> SchemaRef { + self.schema.clone() + } + + fn to_stream(&self) -> Result { + let schema = self.schema.arrow_schema().clone(); + let mut builder = self.builder(); + let stream = Box::pin(DfRecordBatchStreamAdapter::new( + schema, + futures::stream::once(async move { + builder + .make_schemata() + .await + .map(|x| x.into_df_record_batch()) + .map_err(Into::into) + }), + )); + Ok(Box::pin( + RecordBatchStreamAdapter::try_new(stream) + .map_err(BoxedError::new) + .context(InternalSnafu)?, + )) + } +} + +/// Builds the `information_schema.schemata` table row by row +/// +/// Columns are based on +struct InformationSchemaSchemataBuilder { + schema: SchemaRef, + catalog_name: String, + catalog_manager: Weak, + + catalog_names: StringVectorBuilder, + schema_names: StringVectorBuilder, + charset_names: StringVectorBuilder, + collation_names: StringVectorBuilder, + sql_paths: StringVectorBuilder, +} + +impl InformationSchemaSchemataBuilder { + fn new( + schema: SchemaRef, + catalog_name: String, + catalog_manager: Weak, + ) -> Self { + Self { + schema, + catalog_name, + catalog_manager, + catalog_names: StringVectorBuilder::with_capacity(42), + schema_names: StringVectorBuilder::with_capacity(42), + charset_names: StringVectorBuilder::with_capacity(42), + collation_names: StringVectorBuilder::with_capacity(42), + sql_paths: StringVectorBuilder::with_capacity(42), + } + } + + /// Construct the `information_schema.schemata` virtual table + async fn make_schemata(&mut self) -> Result { + let catalog_name = self.catalog_name.clone(); + let catalog_manager = self + .catalog_manager + .upgrade() + .context(UpgradeWeakCatalogManagerRefSnafu)?; + + for schema_name in catalog_manager.schema_names(&catalog_name).await? { + if !catalog_manager + .schema_exists(&catalog_name, &schema_name) + .await? + { + continue; + } + + self.add_schema(&catalog_name, &schema_name); + } + + self.finish() + } + + fn add_schema(&mut self, catalog_name: &str, schema_name: &str) { + self.catalog_names.push(Some(catalog_name)); + self.schema_names.push(Some(schema_name)); + self.charset_names.push(Some("utf8")); + self.collation_names.push(Some("utf8_bin")); + self.sql_paths.push(None); + } + + fn finish(&mut self) -> Result { + let columns: Vec = vec![ + Arc::new(self.catalog_names.finish()), + Arc::new(self.schema_names.finish()), + Arc::new(self.charset_names.finish()), + Arc::new(self.collation_names.finish()), + Arc::new(self.sql_paths.finish()), + ]; + RecordBatch::new(self.schema.clone(), columns).context(CreateRecordBatchSnafu) + } +} + +impl DfPartitionStream for InformationSchemaSchemata { + fn schema(&self) -> &ArrowSchemaRef { + self.schema.arrow_schema() + } + + fn execute(&self, _: Arc) -> DfSendableRecordBatchStream { + let schema = self.schema.arrow_schema().clone(); + let mut builder = self.builder(); + Box::pin(DfRecordBatchStreamAdapter::new( + schema, + futures::stream::once(async move { + builder + .make_schemata() + .await + .map(|x| x.into_df_record_batch()) + .map_err(Into::into) + }), + )) + } +} diff --git a/src/catalog/src/information_schema/table_names.rs b/src/catalog/src/information_schema/table_names.rs index 996a2e035f48..73ef00b81bd3 100644 --- a/src/catalog/src/information_schema/table_names.rs +++ b/src/catalog/src/information_schema/table_names.rs @@ -25,3 +25,4 @@ pub const COLLATIONS: &str = "collations"; pub const COLLATION_CHARACTER_SET_APPLICABILITY: &str = "collation_character_set_applicability"; pub const CHECK_CONSTRAINTS: &str = "check_constraints"; pub const EVENTS: &str = "events"; +pub const SCHEMATA: &str = "schemata"; diff --git a/src/common/catalog/src/consts.rs b/src/common/catalog/src/consts.rs index d9cb1ba54b50..75c176112db2 100644 --- a/src/common/catalog/src/consts.rs +++ b/src/common/catalog/src/consts.rs @@ -54,6 +54,8 @@ pub const INFORMATION_SCHEMA_COLLATION_CHARACTER_SET_APPLICABILITY_TABLE_ID: u32 pub const INFORMATION_SCHEMA_CHECK_CONSTRAINTS_TABLE_ID: u32 = 12; /// id for information_schema.EVENTS pub const INFORMATION_SCHEMA_EVENTS_TABLE_ID: u32 = 13; +/// id for information_schema.SCHEMATA +pub const INFORMATION_SCHEMA_SCHEMATA_TABLE_ID: u32 = 14; /// ----- End of information_schema tables ----- pub const MITO_ENGINE: &str = "mito"; diff --git a/src/datatypes/src/schema/column_schema.rs b/src/datatypes/src/schema/column_schema.rs index 04f715fbc1f1..17c39ee11bd9 100644 --- a/src/datatypes/src/schema/column_schema.rs +++ b/src/datatypes/src/schema/column_schema.rs @@ -109,6 +109,11 @@ impl ColumnSchema { &mut self.metadata } + /// Retrieve the column comment + pub fn column_comment(&self) -> Option<&String> { + self.metadata.get(COMMENT_KEY) + } + pub fn with_time_index(mut self, is_time_index: bool) -> Self { self.is_time_index = is_time_index; if is_time_index { @@ -315,12 +320,16 @@ mod tests { #[test] fn test_column_schema_with_metadata() { - let metadata = Metadata::from([("k1".to_string(), "v1".to_string())]); + let metadata = Metadata::from([ + ("k1".to_string(), "v1".to_string()), + (COMMENT_KEY.to_string(), "test comment".to_string()), + ]); let column_schema = ColumnSchema::new("test", ConcreteDataType::int32_datatype(), true) .with_metadata(metadata) .with_default_constraint(Some(ColumnDefaultConstraint::null_value())) .unwrap(); assert_eq!("v1", column_schema.metadata().get("k1").unwrap()); + assert_eq!("test comment", column_schema.column_comment().unwrap()); assert!(column_schema .metadata() .get(DEFAULT_CONSTRAINT_KEY) diff --git a/tests-integration/src/tests/instance_test.rs b/tests-integration/src/tests/instance_test.rs index 4ec29090e607..686b98a2ee1c 100644 --- a/tests-integration/src/tests/instance_test.rs +++ b/tests-integration/src/tests/instance_test.rs @@ -1775,45 +1775,53 @@ async fn test_information_schema_dot_columns(instance: Arc) { let output = execute_sql(&instance, sql).await; let expected = "\ -+---------------+--------------------+------------+---------------+-----------+---------------+ -| table_catalog | table_schema | table_name | column_name | data_type | semantic_type | -+---------------+--------------------+------------+---------------+-----------+---------------+ -| greptime | information_schema | columns | table_catalog | String | FIELD | -| greptime | information_schema | columns | table_schema | String | FIELD | -| greptime | information_schema | columns | table_name | String | FIELD | -| greptime | information_schema | columns | column_name | String | FIELD | -| greptime | information_schema | columns | data_type | String | FIELD | -| greptime | information_schema | columns | semantic_type | String | FIELD | -| greptime | public | numbers | number | UInt32 | TAG | -| greptime | information_schema | tables | table_catalog | String | FIELD | -| greptime | information_schema | tables | table_schema | String | FIELD | -| greptime | information_schema | tables | table_name | String | FIELD | -| greptime | information_schema | tables | table_type | String | FIELD | -| greptime | information_schema | tables | table_id | UInt32 | FIELD | -| greptime | information_schema | tables | engine | String | FIELD | -+---------------+--------------------+------------+---------------+-----------+---------------+"; ++---------------+--------------------+------------+----------------+-----------+---------------+ +| table_catalog | table_schema | table_name | column_name | data_type | semantic_type | ++---------------+--------------------+------------+----------------+-----------+---------------+ +| greptime | information_schema | columns | table_catalog | String | FIELD | +| greptime | information_schema | columns | table_schema | String | FIELD | +| greptime | information_schema | columns | table_name | String | FIELD | +| greptime | information_schema | columns | column_name | String | FIELD | +| greptime | information_schema | columns | data_type | String | FIELD | +| greptime | information_schema | columns | semantic_type | String | FIELD | +| greptime | information_schema | columns | column_default | String | FIELD | +| greptime | information_schema | columns | is_nullable | String | FIELD | +| greptime | information_schema | columns | column_type | String | FIELD | +| greptime | information_schema | columns | column_comment | String | FIELD | +| greptime | public | numbers | number | UInt32 | TAG | +| greptime | information_schema | tables | table_catalog | String | FIELD | +| greptime | information_schema | tables | table_schema | String | FIELD | +| greptime | information_schema | tables | table_name | String | FIELD | +| greptime | information_schema | tables | table_type | String | FIELD | +| greptime | information_schema | tables | table_id | UInt32 | FIELD | +| greptime | information_schema | tables | engine | String | FIELD | ++---------------+--------------------+------------+----------------+-----------+---------------+"; check_output_stream(output, expected).await; let output = execute_sql_with(&instance, sql, query_ctx).await; let expected = "\ -+-----------------+--------------------+---------------+---------------+----------------------+---------------+ -| table_catalog | table_schema | table_name | column_name | data_type | semantic_type | -+-----------------+--------------------+---------------+---------------+----------------------+---------------+ -| another_catalog | another_schema | another_table | i | TimestampMillisecond | TIMESTAMP | -| another_catalog | information_schema | columns | table_catalog | String | FIELD | -| another_catalog | information_schema | columns | table_schema | String | FIELD | -| another_catalog | information_schema | columns | table_name | String | FIELD | -| another_catalog | information_schema | columns | column_name | String | FIELD | -| another_catalog | information_schema | columns | data_type | String | FIELD | -| another_catalog | information_schema | columns | semantic_type | String | FIELD | -| another_catalog | information_schema | tables | table_catalog | String | FIELD | -| another_catalog | information_schema | tables | table_schema | String | FIELD | -| another_catalog | information_schema | tables | table_name | String | FIELD | -| another_catalog | information_schema | tables | table_type | String | FIELD | -| another_catalog | information_schema | tables | table_id | UInt32 | FIELD | -| another_catalog | information_schema | tables | engine | String | FIELD | -+-----------------+--------------------+---------------+---------------+----------------------+---------------+"; ++-----------------+--------------------+---------------+----------------+----------------------+---------------+ +| table_catalog | table_schema | table_name | column_name | data_type | semantic_type | ++-----------------+--------------------+---------------+----------------+----------------------+---------------+ +| another_catalog | another_schema | another_table | i | TimestampMillisecond | TIMESTAMP | +| another_catalog | information_schema | columns | table_catalog | String | FIELD | +| another_catalog | information_schema | columns | table_schema | String | FIELD | +| another_catalog | information_schema | columns | table_name | String | FIELD | +| another_catalog | information_schema | columns | column_name | String | FIELD | +| another_catalog | information_schema | columns | data_type | String | FIELD | +| another_catalog | information_schema | columns | semantic_type | String | FIELD | +| another_catalog | information_schema | columns | column_default | String | FIELD | +| another_catalog | information_schema | columns | is_nullable | String | FIELD | +| another_catalog | information_schema | columns | column_type | String | FIELD | +| another_catalog | information_schema | columns | column_comment | String | FIELD | +| another_catalog | information_schema | tables | table_catalog | String | FIELD | +| another_catalog | information_schema | tables | table_schema | String | FIELD | +| another_catalog | information_schema | tables | table_name | String | FIELD | +| another_catalog | information_schema | tables | table_type | String | FIELD | +| another_catalog | information_schema | tables | table_id | UInt32 | FIELD | +| another_catalog | information_schema | tables | engine | String | FIELD | ++-----------------+--------------------+---------------+----------------+----------------------+---------------+"; check_output_stream(output, expected).await; } diff --git a/tests/cases/standalone/common/show/show_databases_tables.result b/tests/cases/standalone/common/show/show_databases_tables.result index 0d43286ccc88..a407564c3b4c 100644 --- a/tests/cases/standalone/common/show/show_databases_tables.result +++ b/tests/cases/standalone/common/show/show_databases_tables.result @@ -30,6 +30,7 @@ show tables; | columns | | engines | | events | +| schemata | | tables | +---------------------------------------+ diff --git a/tests/cases/standalone/common/system/information_schema.result b/tests/cases/standalone/common/system/information_schema.result index c3949ca644ba..c7fc6543ee95 100644 --- a/tests/cases/standalone/common/system/information_schema.result +++ b/tests/cases/standalone/common/system/information_schema.result @@ -22,91 +22,101 @@ order by table_schema, table_name; | greptime | information_schema | columns | LOCAL TEMPORARY | 4 | | | greptime | information_schema | engines | LOCAL TEMPORARY | 5 | | | greptime | information_schema | events | LOCAL TEMPORARY | 13 | | +| greptime | information_schema | schemata | LOCAL TEMPORARY | 14 | | | greptime | information_schema | tables | LOCAL TEMPORARY | 3 | | | greptime | public | numbers | LOCAL TEMPORARY | 2 | test_engine | +---------------+--------------------+---------------------------------------+-----------------+----------+-------------+ select * from information_schema.columns order by table_schema, table_name; -+---------------+--------------------+---------------------------------------+----------------------+-----------+---------------+ -| table_catalog | table_schema | table_name | column_name | data_type | semantic_type | -+---------------+--------------------+---------------------------------------+----------------------+-----------+---------------+ -| greptime | information_schema | build_info | git_branch | String | FIELD | -| greptime | information_schema | build_info | git_commit | String | FIELD | -| greptime | information_schema | build_info | git_commit_short | String | FIELD | -| greptime | information_schema | build_info | git_dirty | String | FIELD | -| greptime | information_schema | build_info | pkg_version | String | FIELD | -| greptime | information_schema | character_sets | maxlen | Int64 | FIELD | -| greptime | information_schema | character_sets | character_set_name | String | FIELD | -| greptime | information_schema | character_sets | default_collate_name | String | FIELD | -| greptime | information_schema | character_sets | description | String | FIELD | -| greptime | information_schema | check_constraints | check_clause | String | FIELD | -| greptime | information_schema | check_constraints | constraint_name | String | FIELD | -| greptime | information_schema | check_constraints | constraint_schema | String | FIELD | -| greptime | information_schema | check_constraints | constraint_catalog | String | FIELD | -| greptime | information_schema | collation_character_set_applicability | character_set_name | String | FIELD | -| greptime | information_schema | collation_character_set_applicability | collation_name | String | FIELD | -| greptime | information_schema | collations | collation_name | String | FIELD | -| greptime | information_schema | collations | character_set_name | String | FIELD | -| greptime | information_schema | collations | id | Int64 | FIELD | -| greptime | information_schema | collations | is_default | String | FIELD | -| greptime | information_schema | collations | is_compiled | String | FIELD | -| greptime | information_schema | collations | sortlen | Int64 | FIELD | -| greptime | information_schema | column_privileges | table_catalog | String | FIELD | -| greptime | information_schema | column_privileges | grantee | String | FIELD | -| greptime | information_schema | column_privileges | privilege_type | String | FIELD | -| greptime | information_schema | column_privileges | is_grantable | String | FIELD | -| greptime | information_schema | column_privileges | column_name | String | FIELD | -| greptime | information_schema | column_privileges | table_name | String | FIELD | -| greptime | information_schema | column_privileges | table_schema | String | FIELD | -| greptime | information_schema | column_statistics | schema_name | String | FIELD | -| greptime | information_schema | column_statistics | table_name | String | FIELD | -| greptime | information_schema | column_statistics | column_name | String | FIELD | -| greptime | information_schema | column_statistics | histogram | String | FIELD | -| greptime | information_schema | columns | table_catalog | String | FIELD | -| greptime | information_schema | columns | table_schema | String | FIELD | -| greptime | information_schema | columns | semantic_type | String | FIELD | -| greptime | information_schema | columns | data_type | String | FIELD | -| greptime | information_schema | columns | column_name | String | FIELD | -| greptime | information_schema | columns | table_name | String | FIELD | -| greptime | information_schema | engines | savepoints | String | FIELD | -| greptime | information_schema | engines | xa | String | FIELD | -| greptime | information_schema | engines | transactions | String | FIELD | -| greptime | information_schema | engines | comment | String | FIELD | -| greptime | information_schema | engines | support | String | FIELD | -| greptime | information_schema | engines | engine | String | FIELD | -| greptime | information_schema | events | sql_mode | String | FIELD | -| greptime | information_schema | events | interval_value | Int64 | FIELD | -| greptime | information_schema | events | database_collation | String | FIELD | -| greptime | information_schema | events | collation_connection | String | FIELD | -| greptime | information_schema | events | character_set_client | String | FIELD | -| greptime | information_schema | events | originator | Int64 | FIELD | -| greptime | information_schema | events | event_catalog | String | FIELD | -| greptime | information_schema | events | event_schema | String | FIELD | -| greptime | information_schema | events | event_name | String | FIELD | -| greptime | information_schema | events | definer | String | FIELD | -| greptime | information_schema | events | time_zone | String | FIELD | -| greptime | information_schema | events | event_body | String | FIELD | -| greptime | information_schema | events | event_definition | String | FIELD | -| greptime | information_schema | events | event_type | String | FIELD | -| greptime | information_schema | events | execute_at | DateTime | FIELD | -| greptime | information_schema | events | event_comment | String | FIELD | -| greptime | information_schema | events | interval_field | String | FIELD | -| greptime | information_schema | events | last_executed | DateTime | FIELD | -| greptime | information_schema | events | starts | DateTime | FIELD | -| greptime | information_schema | events | ends | DateTime | FIELD | -| greptime | information_schema | events | status | String | FIELD | -| greptime | information_schema | events | on_completion | String | FIELD | -| greptime | information_schema | events | created | DateTime | FIELD | -| greptime | information_schema | events | last_altered | DateTime | FIELD | -| greptime | information_schema | tables | table_catalog | String | FIELD | -| greptime | information_schema | tables | table_schema | String | FIELD | -| greptime | information_schema | tables | table_name | String | FIELD | -| greptime | information_schema | tables | table_type | String | FIELD | -| greptime | information_schema | tables | table_id | UInt32 | FIELD | -| greptime | information_schema | tables | engine | String | FIELD | -| greptime | public | numbers | number | UInt32 | TAG | -+---------------+--------------------+---------------------------------------+----------------------+-----------+---------------+ ++---------------+--------------------+---------------------------------------+----------------------------+-----------+---------------+----------------+-------------+-------------+----------------+ +| table_catalog | table_schema | table_name | column_name | data_type | semantic_type | column_default | is_nullable | column_type | column_comment | ++---------------+--------------------+---------------------------------------+----------------------------+-----------+---------------+----------------+-------------+-------------+----------------+ +| greptime | information_schema | build_info | pkg_version | String | FIELD | | No | String | | +| greptime | information_schema | build_info | git_branch | String | FIELD | | No | String | | +| greptime | information_schema | build_info | git_commit | String | FIELD | | No | String | | +| greptime | information_schema | build_info | git_commit_short | String | FIELD | | No | String | | +| greptime | information_schema | build_info | git_dirty | String | FIELD | | No | String | | +| greptime | information_schema | character_sets | description | String | FIELD | | No | String | | +| greptime | information_schema | character_sets | maxlen | Int64 | FIELD | | No | Int64 | | +| greptime | information_schema | character_sets | default_collate_name | String | FIELD | | No | String | | +| greptime | information_schema | character_sets | character_set_name | String | FIELD | | No | String | | +| greptime | information_schema | check_constraints | constraint_schema | String | FIELD | | No | String | | +| greptime | information_schema | check_constraints | check_clause | String | FIELD | | No | String | | +| greptime | information_schema | check_constraints | constraint_name | String | FIELD | | No | String | | +| greptime | information_schema | check_constraints | constraint_catalog | String | FIELD | | No | String | | +| greptime | information_schema | collation_character_set_applicability | collation_name | String | FIELD | | No | String | | +| greptime | information_schema | collation_character_set_applicability | character_set_name | String | FIELD | | No | String | | +| greptime | information_schema | collations | collation_name | String | FIELD | | No | String | | +| greptime | information_schema | collations | sortlen | Int64 | FIELD | | No | Int64 | | +| greptime | information_schema | collations | is_compiled | String | FIELD | | No | String | | +| greptime | information_schema | collations | is_default | String | FIELD | | No | String | | +| greptime | information_schema | collations | id | Int64 | FIELD | | No | Int64 | | +| greptime | information_schema | collations | character_set_name | String | FIELD | | No | String | | +| greptime | information_schema | column_privileges | is_grantable | String | FIELD | | No | String | | +| greptime | information_schema | column_privileges | grantee | String | FIELD | | No | String | | +| greptime | information_schema | column_privileges | table_catalog | String | FIELD | | No | String | | +| greptime | information_schema | column_privileges | table_schema | String | FIELD | | No | String | | +| greptime | information_schema | column_privileges | table_name | String | FIELD | | No | String | | +| greptime | information_schema | column_privileges | column_name | String | FIELD | | No | String | | +| greptime | information_schema | column_privileges | privilege_type | String | FIELD | | No | String | | +| greptime | information_schema | column_statistics | table_name | String | FIELD | | No | String | | +| greptime | information_schema | column_statistics | schema_name | String | FIELD | | No | String | | +| greptime | information_schema | column_statistics | column_name | String | FIELD | | No | String | | +| greptime | information_schema | column_statistics | histogram | String | FIELD | | No | String | | +| greptime | information_schema | columns | table_catalog | String | FIELD | | No | String | | +| greptime | information_schema | columns | column_comment | String | FIELD | | Yes | String | | +| greptime | information_schema | columns | column_type | String | FIELD | | No | String | | +| greptime | information_schema | columns | is_nullable | String | FIELD | | No | String | | +| greptime | information_schema | columns | column_default | String | FIELD | | Yes | String | | +| greptime | information_schema | columns | semantic_type | String | FIELD | | No | String | | +| greptime | information_schema | columns | data_type | String | FIELD | | No | String | | +| greptime | information_schema | columns | column_name | String | FIELD | | No | String | | +| greptime | information_schema | columns | table_name | String | FIELD | | No | String | | +| greptime | information_schema | columns | table_schema | String | FIELD | | No | String | | +| greptime | information_schema | engines | xa | String | FIELD | | No | String | | +| greptime | information_schema | engines | support | String | FIELD | | No | String | | +| greptime | information_schema | engines | savepoints | String | FIELD | | No | String | | +| greptime | information_schema | engines | engine | String | FIELD | | No | String | | +| greptime | information_schema | engines | transactions | String | FIELD | | No | String | | +| greptime | information_schema | engines | comment | String | FIELD | | No | String | | +| greptime | information_schema | events | event_comment | String | FIELD | | No | String | | +| greptime | information_schema | events | sql_mode | String | FIELD | | No | String | | +| greptime | information_schema | events | database_collation | String | FIELD | | No | String | | +| greptime | information_schema | events | collation_connection | String | FIELD | | No | String | | +| greptime | information_schema | events | character_set_client | String | FIELD | | No | String | | +| greptime | information_schema | events | originator | Int64 | FIELD | | No | Int64 | | +| greptime | information_schema | events | event_catalog | String | FIELD | | No | String | | +| greptime | information_schema | events | event_schema | String | FIELD | | No | String | | +| greptime | information_schema | events | event_name | String | FIELD | | No | String | | +| greptime | information_schema | events | definer | String | FIELD | | No | String | | +| greptime | information_schema | events | time_zone | String | FIELD | | No | String | | +| greptime | information_schema | events | event_body | String | FIELD | | No | String | | +| greptime | information_schema | events | event_definition | String | FIELD | | No | String | | +| greptime | information_schema | events | event_type | String | FIELD | | No | String | | +| greptime | information_schema | events | execute_at | DateTime | FIELD | | No | DateTime | | +| greptime | information_schema | events | interval_value | Int64 | FIELD | | No | Int64 | | +| greptime | information_schema | events | interval_field | String | FIELD | | No | String | | +| greptime | information_schema | events | last_executed | DateTime | FIELD | | No | DateTime | | +| greptime | information_schema | events | starts | DateTime | FIELD | | No | DateTime | | +| greptime | information_schema | events | ends | DateTime | FIELD | | No | DateTime | | +| greptime | information_schema | events | status | String | FIELD | | No | String | | +| greptime | information_schema | events | on_completion | String | FIELD | | No | String | | +| greptime | information_schema | events | created | DateTime | FIELD | | No | DateTime | | +| greptime | information_schema | events | last_altered | DateTime | FIELD | | No | DateTime | | +| greptime | information_schema | schemata | catalog_name | String | FIELD | | No | String | | +| greptime | information_schema | schemata | schema_name | String | FIELD | | No | String | | +| greptime | information_schema | schemata | default_character_set_name | String | FIELD | | No | String | | +| greptime | information_schema | schemata | default_collation_name | String | FIELD | | No | String | | +| greptime | information_schema | schemata | sql_path | String | FIELD | | Yes | String | | +| greptime | information_schema | tables | table_catalog | String | FIELD | | No | String | | +| greptime | information_schema | tables | table_schema | String | FIELD | | No | String | | +| greptime | information_schema | tables | table_name | String | FIELD | | No | String | | +| greptime | information_schema | tables | table_type | String | FIELD | | No | String | | +| greptime | information_schema | tables | table_id | UInt32 | FIELD | | Yes | UInt32 | | +| greptime | information_schema | tables | engine | String | FIELD | | Yes | String | | +| greptime | public | numbers | number | UInt32 | TAG | | No | UInt32 | | ++---------------+--------------------+---------------------------------------+----------------------------+-----------+---------------+----------------+-------------+-------------+----------------+ create database my_db; @@ -173,6 +183,32 @@ use information_schema; Affected Rows: 0 +-- schemata -- +desc table schemata; + ++----------------------------+--------+-----+------+---------+---------------+ +| Column | Type | Key | Null | Default | Semantic Type | ++----------------------------+--------+-----+------+---------+---------------+ +| catalog_name | String | | NO | | FIELD | +| schema_name | String | | NO | | FIELD | +| default_character_set_name | String | | NO | | FIELD | +| default_collation_name | String | | NO | | FIELD | +| sql_path | String | | YES | | FIELD | ++----------------------------+--------+-----+------+---------+---------------+ + +select * from schemata where catalog_name = 'greptime' and schema_name != 'public' order by catalog_name, schema_name; + ++--------------+-----------------------+----------------------------+------------------------+----------+ +| catalog_name | schema_name | default_character_set_name | default_collation_name | sql_path | ++--------------+-----------------------+----------------------------+------------------------+----------+ +| greptime | greptime_private | utf8 | utf8_bin | | +| greptime | illegal-database | utf8 | utf8_bin | | +| greptime | information_schema | utf8 | utf8_bin | | +| greptime | my_db | utf8 | utf8_bin | | +| greptime | test_public_schema | utf8 | utf8_bin | | +| greptime | upper_case_table_name | utf8 | utf8_bin | | ++--------------+-----------------------+----------------------------+------------------------+----------+ + -- test engines select * from engines; diff --git a/tests/cases/standalone/common/system/information_schema.sql b/tests/cases/standalone/common/system/information_schema.sql index 34db6c144f4f..6550fb544c61 100644 --- a/tests/cases/standalone/common/system/information_schema.sql +++ b/tests/cases/standalone/common/system/information_schema.sql @@ -44,6 +44,12 @@ drop schema my_db; use information_schema; +-- schemata -- + +desc table schemata; + +select * from schemata where catalog_name = 'greptime' and schema_name != 'public' order by catalog_name, schema_name; + -- test engines select * from engines;