From 1769d63d889f83bc7acb90d7f4dd0add34be7b6a Mon Sep 17 00:00:00 2001 From: Jordan Smith <45415425+jordan-smith721@users.noreply.github.com> Date: Thu, 28 Sep 2023 10:52:47 -0700 Subject: [PATCH] DOCSP-31907 Split Event (#457) --- .../crud/read-operations/change-streams.txt | 49 ++++++++++++++++++- 1 file changed, 48 insertions(+), 1 deletion(-) diff --git a/source/fundamentals/crud/read-operations/change-streams.txt b/source/fundamentals/crud/read-operations/change-streams.txt index 8c714419d..7f455de99 100644 --- a/source/fundamentals/crud/read-operations/change-streams.txt +++ b/source/fundamentals/crud/read-operations/change-streams.txt @@ -137,6 +137,53 @@ An update operation on the collection produces the following output: ... } +Split Large Change Stream Events +-------------------------------- + +Starting in MongoDB 7.0, you can use the ``$changeStreamSplitLargeEvent`` +aggregation stage to split events that exceed 16 MB into smaller fragments. +The $changeStreamSplitLargeEvent stage returns the fragments sequentially. You can +access the fragments by using a change stream cursor. Each fragment +includes a ``SplitEvent`` object containing the following fields: + +.. list-table:: + :header-rows: 1 + :widths: 35 65 + + * - Field + - Description + + * - ``fragment`` + - The index of the fragment, starting at ``1`` + + * - ``of`` + - The total number of fragments that compose the split event + +The following example modifies your change stream by using the +``$changeStreamSplitLargeEvent`` aggregation stage to split large events: + +.. code-block:: java + + ChangeStreamIterable changeStream = collection.watch( + Arrays.asList(Document.parse("{ $changeStreamSplitLargeEvent: {} }"))); + +.. note:: + + You can have only one ``$changeStreamSplitLargeEvent`` stage in your + aggregation pipeline, and it must be the last stage in the pipeline. + +You can call the ``getSplitEvent()`` method on your change stream cursor to access +the ``SplitEvent`` as shown in the following example: + +.. code-block:: java + + MongoChangeStreamCursor> cursor = changeStream.cursor(); + SplitEvent event = cursor.tryNext().getSplitEvent(); + +For more information on the ``$changeStreamSplitLargeEvent`` aggregation stage, +see the :manual:`$changeStreamSplitLargeEvent +` server documentation. + .. _java-change-stream-configure-pre-post: Include Pre-images and Post-images @@ -287,4 +334,4 @@ output: } For a list of options, see the `FullDocument <{+api+}/apidocs/mongodb-driver-core/com/mongodb/client/model/changestream/FullDocument.html>`__ -API documentation. +API documentation. \ No newline at end of file