Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
In this article, you learn about the Spark SQL syntax for activities related to materialized lake views in Microsoft Fabric.
Create a materialized lake view
You can define a materialized lake view from any table or from another materialized lake view within a lakehouse. The following code outlines the syntax for declaring a materialized lake view by using Spark SQL:
CREATE MATERIALIZED LAKE VIEW [IF NOT EXISTS][workspace.lakehouse.schema].MLV_Identifier 
[( 
    CONSTRAINT constraint_name1 CHECK (condition expression1)[ON MISMATCH DROP | FAIL],  
    CONSTRAINT constraint_name2 CHECK (condition expression2)[ON MISMATCH DROP | FAIL] 
)] 
[PARTITIONED BY (col1, col2, ... )] 
[COMMENT "description or comment"] 
[TBLPROPERTIES ("key1"="val1", "key2"="val2", ... )] 
AS select_statement 
Arguments
| Parameter | Description | 
|---|---|
| MLV_Identifier | Name of the materialized lake view. | 
| CONSTRAINT | Keyword to define a data quality constraint, followed by a user-defined name. The constraint applies at the level of the materialized lake view. | 
| CHECK | Parameter for enforcing a condition based on certain column values. Mandatory to use when you're defining constraint. | 
| ON MISMATCH | Parameter for specifying the action to take if the constraint is violated. Possible actions are DROPandFAIL. By default, without this clause, the action isFAIL. | 
| PARTITIONED BY | Parameter for creating partitions based on the specified column. | 
| TBLPROPERTIES | List of key/value pairs for tagging the definition of the materialized lake view. | 
| COMMENT | Statement to describe the materialized lake view. | 
| AS select_statement | Query to populate the data in the materialized lake view by using a SELECTstatement. | 
Examples
The following example illustrates the definition of a materialized lake view named customers_enriched by joining a customers table with an orders table:
CREATE MATERIALIZED LAKE VIEW IF NOT EXISTS silver.customers_enriched AS 
SELECT 
    c.customerID, 
    c.customerName, 
    c.contact, 
    CASE  
       WHEN COUNT(o.orderID) OVER (PARTITION BY c.customerID) > 0 THEN TRUE  
       ELSE FALSE  
       END AS has_orders 
FROM bronze.customers c LEFT JOIN bronze.orders o 
ON c.customerID = o.customerID; 
The following example defines a materialized lake view called customers_enriched, partitioned by the city column:
CREATE MATERIALIZED LAKE VIEW IF NOT EXISTS silver.customers_enriched 
COMMENT "This is a sample materialized lake view" 
PARTITIONED BY (city)
AS SELECT 
     c.customerID, 
     c.customerName, 
     c.contact, 
     CASE  
        WHEN COUNT(o.orderID) OVER (PARTITION BY c.customerID) > 0 THEN TRUE  
        ELSE FALSE  
        END AS has_orders 
FROM bronze.customers c LEFT JOIN bronze.orders o 
ON c.customerID = o.customerID; 
Get a list of materialized lake views
To obtain the list of all materialized lake views in a lakehouse, use the following command:
SHOW MATERIALIZED LAKE VIEWS <IN/FROM> Schema_Name;
Here's an example:
SHOW MATERIALIZED LAKE VIEWS IN silver;
Retrieve the statement that created a materialized lake view
To get the CREATE statement for a materialized lake view, use the following command:
SHOW CREATE MATERIALIZED LAKE VIEW MLV_Identifier;
Here's an example:
SHOW CREATE MATERIALIZED LAKE VIEW customers_enriched;
Update a materialized lake view
To update the definition of a materialized lake view, you must drop it and re-create it. The ALTER statement is supported only for renaming a materialized lake view.
ALTER MATERIALIZED LAKE VIEW MLV_Identifier RENAME TO MLV_Identifier_New;
Here's an example:
ALTER MATERIALIZED LAKE VIEW customers_enriched RENAME TO customers_enriched_new;
Drop a materialized lake view
You can drop a materialized lake view by using the Delete option in the lakehouse object explorer or by running the following command in the notebook:
DROP MATERIALIZED LAKE VIEW MLV_Identifier;
Here's an example:
DROP MATERIALIZED LAKE VIEW customers_enriched;
Note
Dropping or renaming a materialized lake view affects the lineage view and scheduled refresh. Be sure to update the reference in all dependent materialized lake views.
Current limitations
- Schema names with all capital letters aren't supported. You can continue to create materialized lake views without using all capital letters in the schema name.
- Spark properties set at the session level aren't applied during a scheduled lineage refresh.
- The creation of a materialized lake view with delta time travel isn't supported.
- Data Manipulation Language (DML) statements aren't supported with materialized lake views.
- User-defined functions in CREATE TABLE AS SELECT(CTAS) statements aren't supported.
- You can't use temporary views to define materialized lake views.