Catalog
Catalog
is the entry point for accessing iceberg tables. You can use a catalog to:
- Create and list namespaces.
- Create, load, and drop tables
Currently only rest catalog has been implemented, and other catalogs are under active development. Here is an
example of how to create a RestCatalog
:
// 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.
use std::collections::HashMap;
use iceberg::{Catalog, NamespaceIdent};
use iceberg_catalog_rest::{RestCatalog, RestCatalogConfig};
/// It a simple example that demonstrates how to create a namespace in a REST catalog.
/// It requires a running instance of the iceberg-rest catalog for the port 8181.
/// You can find how to run the iceberg-rest catalog in the official documentation.
///
/// [Quickstart](https://iceberg.apache.org/spark-quickstart/)
#[tokio::main]
async fn main() {
// Create catalog
let config = RestCatalogConfig::builder()
.uri("http://localhost:8181".to_string())
.build();
let catalog = RestCatalog::new(config);
// List all namespaces
let all_namespaces = catalog.list_namespaces(None).await.unwrap();
println!("Namespaces in current catalog: {:?}", all_namespaces);
let namespace_id =
NamespaceIdent::from_vec(vec!["ns1".to_string(), "ns11".to_string()]).unwrap();
// Create namespace
let ns = catalog
.create_namespace(
&namespace_id,
HashMap::from([("key1".to_string(), "value1".to_string())]),
)
.await
.unwrap();
println!("Namespace created: {:?}", ns);
}
You can run following code to list all root namespaces:
// 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.
use std::collections::HashMap;
use iceberg::{Catalog, NamespaceIdent};
use iceberg_catalog_rest::{RestCatalog, RestCatalogConfig};
/// It a simple example that demonstrates how to create a namespace in a REST catalog.
/// It requires a running instance of the iceberg-rest catalog for the port 8181.
/// You can find how to run the iceberg-rest catalog in the official documentation.
///
/// [Quickstart](https://iceberg.apache.org/spark-quickstart/)
#[tokio::main]
async fn main() {
// Create catalog
let config = RestCatalogConfig::builder()
.uri("http://localhost:8181".to_string())
.build();
let catalog = RestCatalog::new(config);
// List all namespaces
let all_namespaces = catalog.list_namespaces(None).await.unwrap();
println!("Namespaces in current catalog: {:?}", all_namespaces);
let namespace_id =
NamespaceIdent::from_vec(vec!["ns1".to_string(), "ns11".to_string()]).unwrap();
// Create namespace
let ns = catalog
.create_namespace(
&namespace_id,
HashMap::from([("key1".to_string(), "value1".to_string())]),
)
.await
.unwrap();
println!("Namespace created: {:?}", ns);
}
Then you can run following code to create namespace:
// 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.
use std::collections::HashMap;
use iceberg::{Catalog, NamespaceIdent};
use iceberg_catalog_rest::{RestCatalog, RestCatalogConfig};
/// It a simple example that demonstrates how to create a namespace in a REST catalog.
/// It requires a running instance of the iceberg-rest catalog for the port 8181.
/// You can find how to run the iceberg-rest catalog in the official documentation.
///
/// [Quickstart](https://iceberg.apache.org/spark-quickstart/)
#[tokio::main]
async fn main() {
// Create catalog
let config = RestCatalogConfig::builder()
.uri("http://localhost:8181".to_string())
.build();
let catalog = RestCatalog::new(config);
// List all namespaces
let all_namespaces = catalog.list_namespaces(None).await.unwrap();
println!("Namespaces in current catalog: {:?}", all_namespaces);
let namespace_id =
NamespaceIdent::from_vec(vec!["ns1".to_string(), "ns11".to_string()]).unwrap();
// Create namespace
let ns = catalog
.create_namespace(
&namespace_id,
HashMap::from([("key1".to_string(), "value1".to_string())]),
)
.await
.unwrap();
println!("Namespace created: {:?}", ns);
}
Table
After creating Catalog
, we can manipulate tables through Catalog
.
You can use following code to create a table:
// 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.
use std::collections::HashMap;
use iceberg::spec::{NestedField, PrimitiveType, Schema, Type};
use iceberg::{Catalog, TableCreation, TableIdent};
use iceberg_catalog_rest::{RestCatalog, RestCatalogConfig};
/// This is a simple example that demonstrates how to create a table in a REST catalog and get it back.
/// It requires a running instance of the iceberg-rest catalog for the port 8080.
/// You can find how to run the iceberg-rest catalog in the official documentation.
///
/// [Quickstart](https://iceberg.apache.org/spark-quickstart/)
#[tokio::main]
async fn main() {
// Create catalog
let config = RestCatalogConfig::builder()
.uri("http://localhost:8181".to_string())
.build();
let catalog = RestCatalog::new(config);
let table_id = TableIdent::from_strs(["default", "t1"]).unwrap();
let table_schema = Schema::builder()
.with_fields(vec![
NestedField::optional(1, "foo", Type::Primitive(PrimitiveType::String)).into(),
NestedField::required(2, "bar", Type::Primitive(PrimitiveType::Int)).into(),
NestedField::optional(3, "baz", Type::Primitive(PrimitiveType::Boolean)).into(),
])
.with_schema_id(1)
.with_identifier_field_ids(vec![2])
.build()
.unwrap();
// Create table
let table_creation = TableCreation::builder()
.name(table_id.name.clone())
.schema(table_schema.clone())
.properties(HashMap::from([("owner".to_string(), "testx".to_string())]))
.build();
let table = catalog
.create_table(&table_id.namespace, table_creation)
.await
.unwrap();
println!("Table created: {:?}", table.metadata());
let table_created = catalog
.load_table(&TableIdent::from_strs(["default", "t1"]).unwrap())
.await
.unwrap();
println!("{:?}", table_created.metadata());
}
Also, you can load a table directly:
// 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.
use std::collections::HashMap;
use iceberg::spec::{NestedField, PrimitiveType, Schema, Type};
use iceberg::{Catalog, TableCreation, TableIdent};
use iceberg_catalog_rest::{RestCatalog, RestCatalogConfig};
/// This is a simple example that demonstrates how to create a table in a REST catalog and get it back.
/// It requires a running instance of the iceberg-rest catalog for the port 8080.
/// You can find how to run the iceberg-rest catalog in the official documentation.
///
/// [Quickstart](https://iceberg.apache.org/spark-quickstart/)
#[tokio::main]
async fn main() {
// Create catalog
let config = RestCatalogConfig::builder()
.uri("http://localhost:8181".to_string())
.build();
let catalog = RestCatalog::new(config);
let table_id = TableIdent::from_strs(["default", "t1"]).unwrap();
let table_schema = Schema::builder()
.with_fields(vec![
NestedField::optional(1, "foo", Type::Primitive(PrimitiveType::String)).into(),
NestedField::required(2, "bar", Type::Primitive(PrimitiveType::Int)).into(),
NestedField::optional(3, "baz", Type::Primitive(PrimitiveType::Boolean)).into(),
])
.with_schema_id(1)
.with_identifier_field_ids(vec![2])
.build()
.unwrap();
// Create table
let table_creation = TableCreation::builder()
.name(table_id.name.clone())
.schema(table_schema.clone())
.properties(HashMap::from([("owner".to_string(), "testx".to_string())]))
.build();
let table = catalog
.create_table(&table_id.namespace, table_creation)
.await
.unwrap();
println!("Table created: {:?}", table.metadata());
let table_created = catalog
.load_table(&TableIdent::from_strs(["default", "t1"]).unwrap())
.await
.unwrap();
println!("{:?}", table_created.metadata());
}