ReQL command: run
Command syntax
query.run(conn[, optArgs, fetchMode, typeRef]) → Result query.runAsync(conn[, optArgs, fetchMode, typeRef]) → CompletableFuture<Result>
Description
Run a query on a connection either synchronosuly or asynchronously, returning either a result or a CompletableFuture which will complete with the result.
You can pass the following options using optArg. Note that unlike other Java ReQL commands, you must create an OptArg object and pass it as an optional second argument to run
:
import com.rethinkdb.model.OptArgs;
r.table("table").run(conn, OptArgs.of("read_mode", "outdated"));
// for two or more optArgs, use "with"
r.table("table").run(conn,
OptArgs.of("read_mode", "outdated").with("db", "database"));
-
read_mode
: One of three possible values affecting the consistency guarantee for the query (default:'single'
).-
'single'
(the default) returns values that are in memory (but not necessarily written to disk) on the primary replica. -
'majority'
will only return values that are safely committed on disk on a majority of replicas. This requires sending a message to every replica on each read, so it is the slowest but most consistent. -
'outdated'
will return values that are in memory on an arbitrarily-selected replica. This is the fastest but least consistent.
-
-
time_format
: what format to return times in (default:native
). Set this toraw
if you want times returned as JSON objects for exporting. -
profile
: whether or not to return a profile of the query’s execution (default:false
). -
durability
: possible values arehard
andsoft
. In soft durability mode RethinkDB will acknowledge the write immediately after receiving it, but before the write has been committed to disk. -
group_format
: what format to returngrouped_data
andgrouped_streams
in (default:native
). Set this toraw
if you want the raw pseudotype. -
db
: the database to run this query against as a string. The default is the database specified in thedb
connection method (which defaults totest
). The database may also be specified with the db command. -
array_limit
: the maximum numbers of array elements that can be returned by a query (default: 100,000). This affects all ReQL commands that return arrays. Note that it has no effect on the size of arrays being written to the database; those always have an upper limit of 100,000 elements. -
binary_format
: what format to return binary data in (default:native
). Set this toraw
if you want the raw pseudotype. -
min_batch_rows
: minimum number of rows to wait for before batching a result set (default: 8). This is an integer. -
max_batch_rows
: maximum number of rows to wait for before batching a result set (default: unlimited). This is an integer. -
max_batch_bytes
: maximum number of bytes to wait for before batching a result set (default: 1MB). This is an integer. -
max_batch_seconds
: maximum number of seconds to wait before batching a result set (default: 0.5). This is a float (not an integer) and may be specified to the microsecond. -
first_batch_scaledown_factor
: factor to scale the other parameters down by on the first batch (default: 4). For example, with this set to 8 andmax_batch_rows
set to 80, on the first batchmax_batch_rows
will be adjusted to 10 (80 / 8). This allows the first batch to return faster.
Example: If you are OK with potentially out of date data from all the tables involved in this query and want potentially faster reads, pass a flag allowing out of date data in an options object. Settings for individual tables will supercede this global setting for all tables in the query.
import com.rethinkdb.model.OptArgs;
r.table("marvel").run(conn, OptArgs.of("read_mode", "outdated"));
Example: If you want to specify whether to wait for a write to be written to disk (overriding the table’s default settings), you can set durability
to hard
or soft
in the options.
r.table("marvel").insert(r.hashMap("superhero", "Iron Man")
.with("superpower", "Arc Reactor"))
.run(conn, OptArgs.of("durability", "soft"));
Example: If you do not want a time object to be converted to a native date object, you can pass a time_format
flag to prevent it (valid flags are “raw” and “native”). This query returns an object with two fields (epoch_time
and $reql_type$
) instead of a Java 8 ZonedDateTime object.
r.now().run(conn, OptArgs.of("time_format", "raw"));
Example: Specify the database to use for the query.
for (Object doc : r.table("marvel").run(conn, OptArgs.of("db", "heroes")) {
System.out.println(doc);
}
This is equivalent to using the db
command to specify the database:
r.db("heroes").table("marvel").run(conn);
Example: Change the batching parameters for this query.
r.table("marvel").run(conn, OptArgs.of("max_batch_rows", 16).with("max_batch_bytes", 2048));
If you want to send a write and forget about it—that is, not wait for a reply—use the runNoReply command. (Unlike other official RethinkDB drivers, Java does not support a
noreply
option torun
but instead implements a separate term.)
© RethinkDB contributors
Licensed under the Creative Commons Attribution-ShareAlike 3.0 Unported License.
https://rethinkdb.com/api/java/run/