Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

What is the difference between "started streaming" and "completed" in Neo4j queries?

In the Neo4j browser, when I profile a query, I get: "Started streaming 162063 records after 129 ms and completed after 13793 ms." Were the results all gathered after 129ms, but it took 13793ms to output them to the browser?

Also, when I run queries in the Cypher Shell, I get "162063 rows available after 9 ms, consumed after another 8673 ms". Does this mean all of the data was gathered after 9ms, but it took 8673ms to output it to the shell?

like image 277
Colby Cox Avatar asked Oct 15 '25 03:10

Colby Cox


1 Answers

When records (or rows) are streamed, the neo4j server sends each record as soon as it is available -- as opposed to waiting for all the records to be "gathered" and then sending them all at once.

So, for instance, "Started streaming 162063 records after 129 ms and completed after 13793 ms." means that the server streamed the first record after 129 ms and the last record after 13793 ms. (By the way, that is a rate of almost 12 records per ms.)

[EDITED]

The rate at which streamed data is consumed affects the rate at which data can be fed into the stream.

like image 103
cybersam Avatar answered Oct 19 '25 13:10

cybersam