Yandex Cloud
Search
Discuss with expertTry it for free
  • Customer Stories
  • Documentation
  • Blog
  • All Services
  • System Status
  • Marketplace
    • Featured
    • Infrastructure & Network
    • Data Platform
    • AI for business
    • Security
    • DevOps tools
    • Serverless
    • Monitoring & Resources
  • All Solutions
    • By industry
    • By use case
    • Economics and Pricing
    • Security
    • Technical Support
    • Start testing with double trial credits
    • Cloud credits to scale your IT product
    • Gateway to Russia
    • Cloud for Startups
    • Center for Technologies and Society
    • Yandex Cloud Partner program
    • Price calculator
    • Pricing plans
  • Customer Stories
  • Documentation
  • Blog
© 2026 Direct Cursus Technology L.L.C.
Yandex Query
    • Data formats and compression algorithms
      • Reading data via connections
      • Reading data via bindings
      • Writing data
    • Working with Managed Service for ClickHouse® databases
    • Working with Yandex MPP Analytics for PostgreSQL databases
    • Working with Managed Service for MySQL® databases
    • Working with Managed Service for PostgreSQL databases
    • Working with Managed Service for YDB databases
    • Reading Iceberg tables
  • Access management
  • Pricing policy
  • Integrations
  • Audit Trails events
  • FAQ

In this article:

  • Setting up a connection
  • Data model
  • Data reading example
  1. Data sources and sinks
  2. Working with Data Streams
  3. Reading data via connections

Reading data from Data Streams via Query connections

Written by
Yandex Cloud
Updated at July 1, 2026
View in Markdown
  • Setting up a connection
  • Data model
  • Data reading example

Using Yandex Data Streams connections is convenient for prototyping and initial data access configuration.

Yandex Data Streams enables you to transfer data streams to multiple applications for processing, with each handling the data independently of the others.

Query example for reading Json-formatted data from Yandex Data Streams:

SELECT
    JSON_VALUE(CAST(Data AS Json), "$.action") AS action
FROM yds.`input_stream`
WITH (
    format=raw,
    SCHEMA
    (
        Data String
    )
)
LIMIT 10;

Note

Data from a streaming source is delivered as an infinite stream. To prevent infinite streaming and get output in the console, the example uses the LIMIT clause that limits the number of result rows.

Setting up a connectionSetting up a connection

To read data from Yandex Data Streams:

  1. Navigate to the Connections section of the Yandex Query interface and click Create new.

  2. In the window that opens, specify the Yandex Data Streams connection name in the Name field.

  3. In the Type dropdown, select Data Streams.

  4. In the Cloud and Folder field, specify the data source location.

  5. In the Database dropdown, select the Yandex Managed Service for YDB database where you created the Yandex Data Streams stream.

  6. In the Service account field, select an existing service account or create a new one. Assign it the yds.editor permissions required to read data.

    To use a service account, the iam.serviceAccounts.user role is required.

  7. Click Create to create a connection.

Data modelData model

Data is transmitted via Yandex Data Streams in binary format and is read via SQL statements.

SELECT
    <expression>
FROM
    <connection>.<stream_name>
WITH
(
    format=raw,
    SCHEMA
    (
        Data String
    )
)
WHERE <filter>;

Where:

  • <connection>: Name of the Data Streams data stream connection created in the previous step.
  • <stream_name>: Data Streams data stream name.

Data reading exampleData reading example

Query example for reading data from Yandex Data Streams and writing the results to Yandex Data Streams

$data =
SELECT
    JSON_VALUE(Data, "$.host") AS host,
    JSON_VALUE(Data, "$.count") AS count,
    JSON_VALUE(Data, "$.tag") AS tag,
FROM
(
    SELECT
        CAST(Data AS Json) AS Data
    FROM yds.`input_stream`
    WITH
    (
        format=raw,
        SCHEMA
        (
            Data String
        )
    )
)
WHERE
    JSON_VALUE(Data, "$.tag") = "my_tag";

SELECT
    *
FROM
    $data
LIMIT 10;

Where:

Field Type Description
yds Yandex Data Streams connection name
input_stream Name of the source data stream in the SQL query
host String Query string parameter
raw String Data format. Support is currently limited to the raw format

Was the article helpful?

Previous
Writing data
Next
Reading data via bindings
© 2026 Direct Cursus Technology L.L.C.