Skip to content

Latest commit

 

History

History
597 lines (409 loc) · 29.1 KB

nql.md

File metadata and controls

597 lines (409 loc) · 29.1 KB

NQL: Narrative SQL Interface

Abstract

The Narrative SQL Interface ("NQL") provides a syntax for querying one or more datasets, access rules, views, and the Rosetta Stone set of normalized data Attributes via a Narrative-specific implementation of Structured Query Language. NQL acts on one or more Datasets. NQL is interpreted by a query engine whose purpose is to parse the query and validate syntax, validate the permissions ([Access Rules]) associated to the actor submitting the query, execute the query in a supported query engine and, when appropriate, write the output as a Dataset. The goal of NQL is to facilitate data querying, cross-company collaboration and interactions with Narrative's technology for normalizing disparate datasets, Rosetta Stone.

1. Introduction

Narrative SQL (NQL) commands are statements that execute queries on the Narrative Data Collaboration Platform. NQL input consists of a sequence of commands. A command is composed of a sequence of tokens, terminated by a semicolon (";"). The end of the input stream also terminates a command. Which tokens are valid depends on the syntax of the particular command.

1.1 Requirements Language

The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in [RFC2119]{.underline}.

1.2 Definitions

  • Commands: A command is composed of a sequence of tokens, terminated by a semicolon (";"). The end of the input stream also terminates a command. Which tokens are valid depends on the syntax of the particular command.

  • Tokens: A token can be a key word, an identifier, a quoted identifier, a literal (or constant), or a special character symbol. Tokens are normally separated by whitespace (space, tab, newline)

  • Keywords: The set of words that NQL is aware of and knows how to parse.

  • Identifiers: Names of tables, columns, or other database objects, depending on the command they are used in.

  • Operators: Keywords that reveal a relationship between two expressions and result in a true or false value.

  • Value expressions: Used in a variety of contexts, such as in the target list of the SELECT command, or in search conditions in a number of commands. The result of a value expression is sometimes called a scalar, to distinguish it from the result of a table expression (which is a table). Value expressions are therefore also called scalar expressions (or even simply expressions). The expression syntax allows the calculation of values from primitive parts using arithmetic, logical, set, and other operations.

    A value expression is one of the following:

    • A constant or literal value
    • A column reference

2. Scope

NQL is differentiated from other SQL engines due to its native integration with the Narrative platform. Specifically, NQL interoperates with the following components of the Narrative platform.

2.1 Datasets

A dataset is a system of record for any row of data that is ingressed, egressed, or registered on a supported storage engine in the Narrative platform. Datasets are identifiable by their unique identifiers and a unique name or "slug" that is unique within the Company's namespace. Datasets define the schema of the underlying data contained within the dataset. Schemas are immutable.

  • NQL SHALL allow querying of data that resides in a Dataset, via an Access Rule.

2.2 Rosetta Stone Attribute Catalog

The Narrative Data Collaboration Platform provides a standardized global attribute catalog known as the "Rosetta Stone" for NQL-based queries. This catalog comprises Rosetta Stone Attributes—data points normalized and aggregated from multiple sources across participating companies. Queries against these attributes are permissible only if the dataset containing them is governed by an appropriate Access Rule (also see Knowledge Base Article for more details).

Users MAY utilize Rosetta Stone Attributes to query datasets within their own company account or any other account that has granted access permissions. Rosetta Stone Attributes can be accessed through different namespaces:

  1. Embedded Namespace: Users can access Rosetta Stone Attributes on Datasets and Access Rules by querying dataset_name._rosetta_stone.attribute_name or access_rule_name._rosetta_stone.attribute_name.
  2. Company Namespace: Users can query all Rosetta Stone Attributes within their own company or within another company (where an Access Rule exists) by querying company_name.rosetta_stone.
  3. Narrative Namespace: A special namespace, narrative.rosetta_stone, allows users to query Rosetta Stone Attributes for all companies outside of their own which have shared an Access Rule with them.

Attributes SHALL be of the following types: string, long, double, timestamptz, or object. Object types MUST contain nested properties. To reference nested properties within an object attribute, dot-notation SHALL be used.

2.2. Permissions (Access Rules)

Permissions within the NQL environment are regulated through Access Rules. Each Access Rule MUST delineate:

  • The specific dataset it applies to.
  • The authorized principals, which MAY be companies or individual users.
  • The fields within the dataset that are eligible for querying.
  • Any applicable pricing model for executing a query.
  • Additional constraints for query analysis, if any.

By default, users SHALL be able to execute queries on all tables for which they possess the requisite permissions, given that the query adheres to established rules and syntax.

3. Supported Keywords

NQL SHALL support the following keywords.

Note: This is an incomplete list. For a complete list, refer to the Calcite documentation on supported keywords. Assume these keywords are supported UNLESS OTHERWISE NOTED.

  • SELECT: Executes a command with a "select list," which is a comma-separated list of value expressions.

  • FROM: Utilizes a comma-separated table reference list to derive a table.

  • WHERE: Adheres to the syntax WHERE <search_condition>, where <search_condition> is a boolean value expression.

  • LIMIT: Specifies a budget constraint in the format LIMIT <amount> <unit>, e.g., LIMIT 100 USD. This keyword restricts the number of rows returned, without exceeding the given limit. LIMIT 0 USD PER CALENDAR_MONTH implies purchasing only data with zero cost. If LIMIT is not included, a limit of 0 is assumed. To specify no budget constraint, NO LIMIT can be explicitly set.

  • USD: Denotes that the LIMIT is set in US Dollars. This is the only supported unit for LIMIT currently.

  • PER: Indicates the period over which the LIMIT applies.

  • CALENDAR_MONTH: Represents a calendar month as the time period for LIMIT.

  • CALENDAR_DAY: Represents a calendar day as the time period for LIMIT.

  • AS: Renames a column temporarily using an alias, effective only for the duration of the query.

4. Supported Operators

Logical Operators (AND, OR, NOT): Logical negation, conjugation, and negation.

Comparison Operators (<, >, <=, >=, =, <>, !=): These comparison operators are available for all built-in data types that have a natural ordering, including numeric, string, and date/time types. In addition, arrays, composite types, and ranges can be compared if their component data types are comparable.

Null Aware Operators (IS, IS NOT): Ordinary comparison operators yield null (signifying "unknown"), not true or false, when either input is null. For example, 7 = NULL yields null, as does 7 <> NULL. When this behavior is not suitable, use the IS [ NOT ] predicates

5. Identifiers

5.1 Reserved Fields

5.1.1 _price_cpm_usd

  • Definition: Specifies the maximum cost-per-mille (CPM) in US Dollars that the querier is willing to pay for 1000 rows of data.
  • Data Type: Numeric
  • Usage: Can be used in the WHERE clause as a filtering criterion and in the SELECT clause as an output column.
  • Constraints: Value must be a positive numeric value, up to two decimal places, or the value 0.
    • Setting a price (CPM) to 0 SHALL explicitly filter out access rules with a price, thereby only querying data that is freely available.
    • Omitting a CPM filter SHALL apply no filter, allowing targeting of data at any price. This is particularly useful for EXPLAIN statements to understand available data, but not recommended for CREATE MATERIALIZED VIEW statements due to potential high costs.

5.1.2 _access_rule_id (NOT YET IMPLEMENTED)

  • Definition: Identifier for the Access Rule that governs the query's permissions.
  • Data Type: String or Numeric ID
  • Usage: Typically used in the WHERE clause to specify which Access Rule to apply for the query. Can also appear in the SELECT clause for debugging or auditing.
  • Constraints: Must match an existing Access Rule ID.

5.1.3 _source_company_id (NOT YET IMPLEMENTED)

  • Definition: Identifier for the company or entity providing the Access Rule.
  • Data Type: String or Numeric ID
  • Usage: Used in the WHERE clause to specify data shared by a particular provider. Can also be used in the SELECT clause for output.
  • Constraints: Must match an existing provider ID.

5.2 Identifier Quoting and Referencing

  • Quoting Rule: Identifiers not starting with a lowercase letter [a-z] MUST be enclosed in double quotation marks (").

  • Strict Mode: NQL operates in "strict mode," meaning most identifiers MUST be fully qualified. NQL SHALL NOT attempt to infer identifiers based on command context.

6. SELECT COMMAND

  • A select list MUST NOT use * notation (all fields must be explicitly selected)

  • A FROM clause MUST contain the table name. Throws error if the table name is missing or if the buyer does not have access to the table (dataset or access rule).

  • select_list MUST only contain columns available in the underlying dataset, or via Rosetta Stone. Throws an error if a column is requested that does not exist in the dataset.

7. FROM CLAUSE

  • The FROM clause MUST contain both the schema name as well as the table name. Throws an error if wrong format.

  • The FROM clause schema MUST be one of the following:

    • The user's own company slug (or the equivalent, 'company_data')
    • Another company's slug
    • 'narrative' Error if not one of these valid values.
  • The user that is running the query MUST have access to the dataset being referenced in dataset_source. If the user does not have a valid access rule for the dataset a Unknown table or insufficient table permissions error should be thrown.

8. Search Conditions

  • search_conditions MUST contain database and columns in reference

  • search_conditions MUST only contain references to columns that are present in the underlying dataset OR Narrative reserved filter fields. If not, error is thrown with missing column or reserved field

  • search_conditions MUST contain at least one filter related to price for each table referenced in the query. Currently only _price_cpm_usd is supported. Value must be >=0 and only the <= expression is supported. If not throw error with easy to understand error message

  • LIMIT (Dollar Limit) expression MUST be present. Error if no LIMIT is present. To express no budget the proper syntax is *LIMIT ALL*

9. Query Output

  • Successful SELECT statements MUST return a message that the query has been accepted along with the dataset id that has been created and will be populated by the query

10. Query Features and Constraints

10.1 Cost Control in Queries

Queries in NQL can implement cost controls through two primary mechanisms: filtering based on the unit price per row and setting an overall budget for the query.

SELECT <select_list> FROM <dataset_source> WHERE <search_condition> [LIMIT <amount> <unit> PER <period>]
SELECT [...table.column] | [table.*] FROM [schema.table] WHERE [...table.column <filter_expression>] [_price_cpm_usd <= <price>] [LIMIT 100.50 USD PER CALENDAR_MONTH]
  1. Unit Price Filtering (_price_cpm_usd):

    • This filter allows users to specify the maximum cost-per-mille (CPM) in US Dollars that they are willing to pay for 1000 rows of data.
    • Setting _price_cpm_usd to a specific value filters out data that costs more than the specified price, thereby querying data at or below the set price.
    • Setting _price_cpm_usd to 0 explicitly filters out any data that has a cost, thus only querying free data.
    • Omitting the _price_cpm_usd filter means there is no price filter applied, allowing the query to target data at any price.
  2. Budget Constraint (LIMIT):

    • The LIMIT clause in a query sets a budget constraint, specified as LIMIT <amount> <unit>, for example, LIMIT 100 USD.
    • Using LIMIT 0 USD PER CALENDAR_MONTH indicates that only data with zero cost is to be purchased.
    • If the LIMIT clause is not included in a query, a default limit of 0 is assumed, implying no budget for purchasing data.
    • To specify that there is no budget constraint, the NO LIMIT clause can be used, allowing the purchase of data at any price.

These cost control mechanisms ensure that users can manage their data querying expenses effectively while accessing the necessary data.

10.2 Data and Cost Forecasting

Using EXPLAIN <query>, a forecast can be generated. This forecast estimates both the number of rows returned by the query and the associated cost to purchase the data, if any, according to the access rules that grant access.

10.3 CREATING MATERIALIZED VIEWS

10.3.1 Materialized Views

In databases that support them, a materialized view is a database object that stores the result of a query physically. It provides a way to cache expensive query results and improve query performance by reading from this pre-computed result set, which can be refreshed periodically or on-demand. Similarly, in NQL, creating a materialized view creates a new, unique dataset within the Narrative Data Collaboration Platform that can be further queried or actioned on downstream.

Creating a materialized view effectively creates a new dataset with a unique name. Such datasets cannot ingest data from other sources. Data purchase costs may or may not be incurred when executing a query that materializes data as a new dataset, depending on the underlying query's access rules.

10.3.2 Materialized View Syntax

CREATE MATERIALIZED VIEW "<view_name>"
[ DISPLAY_NAME = '<display_name>' ] 	
[ DESCRIPTION = '<description_text>' ] 	
[ EXPIRE = { <ISO 8601 PERIOD> } // Supported syntax: "expire_when > P60", default retains all data. ]
[ STATUS = { 'active' | 'updating' | 'draft' } ] 
[ TAGS = ( '_nio_materialized_view', '<tag1>', ... ) ]
[ WRITE_MODE = { 'append' | 'overwrite' } ] 
[ EXTENDED_STATS = { 'all' | 'none' } ] 
[ PARTITIONED_BY <field> <transform>, <field2> <transform> ]
[ REFRESH_SCHEDULE = { '@hourly' | '@daily' | '@weekly' | '@monthly' | '@once' | cron expression} ]
AS SELECT <column_names> FROM <table_name>

Note: Materialized view names must be slugified and unique within a company's dataset space, using only alphanumeric and underscore characters. Typically, these names should be enclosed in double quotation marks.

10.3.3 Materialized View Parameters

The following parameters apply to the dataset that is generated by the CREATE MATERIALIZE VIEW command:

  • DISPLAY_NAME: Human-readable name, usually describing the business context of the dataset.

    • Type: string
    • Default: Empty or generated by RosettaAI.
  • DESCRIPTION: Human-readable description providing business context.

    • Type: string
    • Default: Empty or generated by RosettaAI.
  • EXPIRE: Setting for the retention policy.

    • Allowed Values:
      • expireWhen > ISO PERIOD
      • retain_everything
      • expire_everything
    • Type: enum
    • Default: retain_everything
  • STATUS: Status of the materialized view.

    • Allowed Values:
      • active
      • draft (not yet implemented)
      • updating
    • Type: enum
    • Default: active
  • TAGS: Default tag _nio_materialized_view is added. Users can add more.

    • Type: array
    • Default: Empty or generated by RosettaAI.
  • WRITE_MODE: Write mode of the resulting dataset.

    • Allowed Values:
      • append
      • overwrite
    • Type: enum
    • Default: append
  • EXTENDED_STATS: Advanced dataset statistics.

    • Allowed Values:
      • all
      • none
    • Type: enum
    • Default: all
  • PARTITIONED_BY: Output dataset partitions defined by sets of field + transformation.

    • Type: expression
    • Default: Narrative sample partition is always present; users can add additional partitions.
  • REFRESH_SCHEDULE: Defines the frequency of updates for the materialized view.

    • Allowed Values:
      • '@hourly'
      • '@daily'
      • '@weekly'
      • '@monthly'
      • '@once'
      • cron expressions
    • Type: enum | cron
    • Default: '@once'

10.4 Cost Control in Queries

Queries in NQL can implement cost controls through two primary mechanisms: filtering based on the unit price per row and setting an overall budget for the query. These cost controls are necessary when querying data via access rules (either directly or via narrative.rosetta_stone), as this data may come at a cost to the user executing the query.

SELECT <select_list> FROM <dataset_source> WHERE <search_condition> [LIMIT <amount> <unit> PER <period>]
SELECT [...table.column] | [table.*] FROM [schema.table] WHERE [...table.column <filter_expression>] [_price_cpm_usd <= <price>] [LIMIT 100.50 USD PER CALENDAR_MONTH]
  1. Unit Price Filtering (_price_cpm_usd):

    • This filter allows users to specify the maximum cost-per-mille (CPM) in US Dollars that they are willing to pay for 1000 rows of data.
    • Setting _price_cpm_usd to a specific value filters out data that costs more than the specified price, thereby querying data at or below the set price.
    • Setting _price_cpm_usd to 0 explicitly filters out any data that has a cost, thus only querying free data.
    • Omitting the _price_cpm_usd filter means there is no price filter applied, allowing the query to target data at any price.
  2. Budget Constraint (LIMIT):

    • The LIMIT clause in a query sets a budget constraint, specified as LIMIT <amount> <unit>, for example, LIMIT 100 USD.
    • Using LIMIT 0 USD PER CALENDAR_MONTH indicates that only data with zero cost is to be purchased.
    • If the LIMIT clause is not included in a query, a default limit of 0 is assumed, implying no budget for purchasing data.
    • To specify that there is no budget constraint, the NO LIMIT clause can be used, allowing the purchase of data at any price.

These cost control mechanisms ensure that users can manage their data querying expenses effectively while accessing the necessary data.

10.5 Specialized Functions in NQL

NQL also supports a variety of specialized functions or User-Defined Functions (UDFs) to cater to specific use-cases.

10.5.1 ADDRESS_HASHES()

The ADDRESS_HASHES() function generates libpostal address hashes from an unstructured address string. This is especially useful for conducting fuzzy address comparisons where exact string matching isn't sufficient. By hashing the addresses and then joining two input lists based on these hashes, users can find approximate address matches with high efficiency.

Example:
CREATE MATERIALIZED VIEW "address_hashes_sample_v2" AS
SELECT
  address_hashes(
    concat_ws(
      ' ',
      lower(UnitDesignator),
      lower(UnitDesignatorNumber),
      HouseNumber,
      lower(PrimaryAddress),
      lower(PreDirection),
      lower(StreetName),
      lower(StreetSuffix),
      lower(PostDirection),
      ZIPCode,
      ZIP4,
      lower(CityName),
      StateAbbreviation
    )
  ) as address_hashes,
...

10.5.2 country_code_3_to_2()

The country_code_3_to_2('column') function takes in a single column of ISO 3166-1 alpha-3 country code(s) and converts it to ISO 3166-1 alpha-2 country code(s). The function is useful for matching the standard output of the iso_3166_1_country Rosetta Stone attribute, expressed as ISO 3166-1 alpha-2 country codes.

Example:
CREATE MATERIALIZED VIEW "country_code_sample" AS
SELECT
  country_code_3_to_2(my_dataset.country_code) as two_letter_codes
FROM 
  company_data.my_dataset
...

10.6 Querying an Access Rule Directly

An access rule has two identifiers: an access_rule_name and an access_rule_id. Access rule names are human readable and must be created explicitly, while access rule ids are created automatically during the initial set up for each access rule. NQL supports querying access rules directly through access_rule_name and not access_rule_id.

NQL supports querying internal access rules (access rules on datasets in the same company seat) or external access rules (access rules on datasets in a different company seat) directly. Querying an access rule is the third method of querying datasets in NQL, in addition to the Rosetta Stone attribute catalog and dataset ids.

10.6.1 Querying Internal Access Rules

An access rule name is added after the company identifier. When querying data in your own company seat, an access rule name always follows company_data.

Example
SELECT pd.hashed_emails
FROM company_data.access_rule_for_private_deal pd

10.6.2 Querying External Access Rules

An access rule name is added after the company identifier. When querying data in your own company seat, an access rule name always follows company_slug.

Example
SELECT teams.baseball_teams
FROM company_slug.access_rule_unique_name_1 teams

10.7 Namespaces in NQL

NQL operates in "strict mode" - identifiers must be fully qualified in the FROM statement to indicate the namespace they are pulled from. The following namespaces are supported in NQL:

10.7.1 Company Namespaces

  • Every Company (organization using the Narrative platform) has their own namespace, identified by a "slug". The slug identifies the company's namespace.
  • Datasets can only be queried directly by the company that owns the dataset, e.g., company_slug.dataset_name.
  • Users in one company can query data owned by another company using Access Rules, and must refer to that company's company_slug.access_rule_name in the query.
  • Users can also query their own data via access rules.

10.7.2 Rosetta Stone Embedded Namespace

  • Users can access fields and nested object fields in Datasets (and access rules that target those datasets).
  • Users can also access Rosetta Stone Attributes on Datasets and Access Rules by querying dataset_name._rosetta_stone.attribute_name or access_rule_name._rosetta_stone.attribute_name.

10.7.3 Rosetta Stone Company Namespace

  • Users can query all Rosetta Stone Attributes within their own company or within another company (only where an Access Rule exists) by querying company_name.rosetta_stone.

10.7.4 Narrative Rosetta Stone Namespace

  • There is a special namespace, narrative.rosetta_stone, which allows users to query Rosetta Stone Attributes for all companies outside of their own which have shared an Access Rule with them.
Basic Usage
```sql
SELECT ds_identifier._rosetta_stone."attribute_name" AS alias_name
FROM dataset_source
```

- **`ds_identifier`**: Alias or identifier for the dataset. A dataset can be referenced by its `id` or `unique_name`. 
- **`attribute_name`**: The name of the Rosetta Stone attribute that is being selected.
- **`alias_name`**: An optional alias for the selected attribute.
Example with Single Dataset
```sql
SELECT ds_123._rosetta_stone."event_timestamp" AS event_time
FROM company_data.ds_123 AS ds_123
```
Example Joining Multiple Datasets
```sql
SELECT
    ds_123._rosetta_stone."attribute_1" AS attribute_from_a,
    ds_456._rosetta_stone."attribute_2" AS attribute_from_b,
    ds_123.email,
    ds_456.username
FROM
    company_data.ds_123 AS ds_123
JOIN
    company_data.ds_456 AS ds_456
ON
    ds_123.user_id = ds_456.user_id
```

In this example:

- The first Rosetta Stone attribute (**`attribute_1`**) is being pulled from dataset **`ds_123`**.
- The second Rosetta Stone attribute (**`attribute_2`**) is being pulled from dataset **`ds_456`**.
Example of Nested Properties

For nested properties, the same dot notation is used within the _rosetta_stone namespace.

```sql
SELECT
    ds_123._rosetta_stone."nested"."attribute" AS nested_attribute
FROM
    company_data.ds_123 AS ds_123
```
Example of Filtering with Rosetta Attributes
```sql
SELECT
    ds_123._rosetta_stone."unique_id"."value" AS id
FROM
    company_data.ds_123 AS ds_123
WHERE
    ds_123.id = 123
```

Here, the **`WHERE`** clause uses the Rosetta attribute **`unique_id.value`** from dataset **`ds_123`** for filtering.

12. Example Queries

Querying Rosetta Stone Attributes:

EXPLAIN
SELECT
  rs."unique_id"."value",
  rs."hl7_gender"."gender"  
FROM
  narrative.rosetta_stone rs
WHERE 
  rs."hl7_gender"."gender" = 'female'
  AND rs."event_timestamp" > '2023-10-01' 
  AND rs._price_cpm_usd <= 2.0

Single Dataset:

CREATE MATERIALIZED VIEW "running_times" AS

SELECT 
  ds."Workout_Timestamp",
  ds."Total_Output" AS output
FROM 
  company_data."20" ds
WHERE
  ds."Total_Output" > 200 
  AND ds."Fitness_Discipline" = 'Running'
  AND ds._price_cpm_usd <= 1.00
  LIMIT
  50 USD PER CALENDAR_MONTH

Joining datasets:

EXPLAIN
SELECT 
  rs."unique_id"."value",
  rs."hl7_gender"."gender",
  cd."Sha_256_Client_Email"
FROM
  "narrative"."rosetta_stone" AS rs
JOIN 
  "company_data"."833" AS cd
ON 
  rs."unique_id"."value" = cd."Sha_256_Client_Email"
WHERE 
  rs."hl7_gender"."gender" = 'female'
  AND rs."event_timestamp" > '2023-10-01'
  AND rs._price_cpm_usd <= 2.0

APPENDIX

CHANGE LOG

Update 2024-10-19

Section 1 - INTRODUCTION

  • Expanded the definition of NQL to include its ability to query Access Rules, Views, and Rosetta Stone Attributes.

Section 2.2 - ROSETTA STONE ATTRIBUTE CATALOG

  • Added information about different namespaces available for querying Rosetta Stone Attributes.

Section 7 - FROM CLAUSE

  • Updated the allowed schema names to now include company_slug, ensuring that queries can target schemas by company-specific identifiers.

Section 10.5 - COST CONTROL IN QUERIES

  • Clarified the conditions where cost controls are necessary, providing additional guidance on when and how to apply them to queries for optimized resource management.

Section 10.7 - NAMESPACES IN NQL

  • Introduced a new section explaining the different types of namespaces within NQL and how they can be queried, providing a more comprehensive framework for namespace usage in queries.

Update 2023-12-26

Section 10 - CREATING MATERIALIZED VIEWS

  • Create Materialized View syntax was updated to include REFRESH_SCHEDULE, which defines the frequency of updates for the materialized view.
  • The UDF section includes a new function: country_code_3_to_2().
  • NQL supports targeting access rules directly.
    • Internal access rules are targeted using access_rule_name and the company_data identifier.
    • External access rules are targeted using company_slug and access_rule_name.
  • Introduction of the Rosetta Embedded Namespace as a way to query attributes from specific access rules or datasets. The Rosetta Embedded Namespace is facilitated by _rosetta_stone.

Update 2023-11-05

Section 2 - Scope

  • Revised to highlight NQL's integration with the Narrative platform.
  • Expanded the definition of Datasets to include their role as a system of record for data managed within the Narrative platform, emphasizing their unique identifiers, immutable schemas, and namespace uniqueness.

Section 3 - Supported Keywords

  • Updated the LIMIT keyword description to clarify its role in budget constraints and the implications of using LIMIT 0 USD PER CALENDAR_MONTH and NO LIMIT.

Section 5.1.1 - _price_cpm_usd

  • Enhanced the definition to specify the behavior when setting the price (CPM) to 0, emphasizing its role in filtering out priced access rules and querying only free data.
  • Clarified the implications of omitting a CPM filter, noting its utility in EXPLAIN statements and caution in CREATE MATERIALIZED VIEW statements due to potential cost implications.

OUT OF SCOPE FOR THIS VERSION:

DATA MANIPULATION

  1. UPDATE

  2. DELETE

POSSIBLE FUTURE SCOPE:

EXPORT DATA / CONNECTORS

EXPORT DATA OPTIONS (export_option_list) FROM <table_name>

TABLE / DATASET STATISTICS

  1. Show Table Schema

    DESCRIBE SCHEMA <table_name>

  2. Show Table Statistics

    DESCRIBE STATS <table_name> ANALYZE <table_name>;

DATASET DELETION

DROP TABLE <table_name>;