repeat

Loop until a condition is met.

Synopsis

repeat(traversal)

Description

The repeat() step is a branch step and is used for looping over a traversal to some given break predicate. Three step modulators can be used with the repeat() step, emit(), times(), or until().

Examples

Repeatedly gets the outgoing vertex, three times, and prints the results:

g.V().hasLabel('fridgeSensor').repeat(out()).times(3).valueMap()

A more complex example that repeats through all the outgoing knows adjacent vertices of John Doe:

g.V().hasLabel('person','name','John Doe').
  repeat(out('knows').dedup().
         aggregate('x').
           by(project('person','level').
                by('name').
                by(loops())
           )
    ).
    until(__.not(out('knows').simplePath())).
  cap('x').next()

Was this helpful?

Give Feedback

How can we improve the documentation?

© 2025 DataStax | Privacy policy | Terms of use

Apache, Apache Cassandra, Cassandra, Apache Tomcat, Tomcat, Apache Lucene, Apache Solr, Apache Hadoop, Hadoop, Apache Pulsar, Pulsar, Apache Spark, Spark, Apache TinkerPop, TinkerPop, Apache Kafka and Kafka are either registered trademarks or trademarks of the Apache Software Foundation or its subsidiaries in Canada, the United States and/or other countries. Kubernetes is the registered trademark of the Linux Foundation.

General Inquiries: +1 (650) 389-6000, info@datastax.com