Class: Couchbase::Options::Query
- Defined in:
- lib/couchbase/options.rb,
/Users/sergey.auseyau/code/couchbase-ruby-client/lib/couchbase/options.rb more...
Overview
Options for Cluster#query
Instance Attribute Summary collapse
- #adhoc ⇒ Boolean
- #client_context_id ⇒ String
- #flex_index ⇒ Boolean
- #max_parallelism ⇒ Integer
- #metrics ⇒ Boolean
- #pipeline_batch ⇒ Integer
- #pipeline_cap ⇒ Integer
- #preserve_expiry ⇒ Boolean
- #profile ⇒ Symbol
- #readonly ⇒ Boolean
- #scan_cap ⇒ Integer
- #scan_wait ⇒ Integer, #in_milliseconds
- #scope_qualifier ⇒ String
- #transcoder ⇒ JsonTranscoder, #decode(String)
Attributes inherited from Base
#client_context, #parent_span, #retry_strategy, #timeout
Instance Method Summary collapse
-
#consistent_with(mutation_state) ⇒ Object
Sets the mutation tokens this query should be consistent with.
-
#initialize(adhoc: true, client_context_id: nil, max_parallelism: nil, readonly: false, scan_wait: nil, scan_cap: nil, pipeline_cap: nil, pipeline_batch: nil, metrics: nil, profile: :off, flex_index: nil, preserve_expiry: nil, scope_qualifier: nil, scan_consistency: :not_bounded, mutation_state: nil, transcoder: JsonTranscoder.new, positional_parameters: nil, named_parameters: nil, timeout: nil, retry_strategy: nil, client_context: nil, parent_span: nil) {|self| ... } ⇒ Query
constructor
Creates new instance of options for Cluster#query.
-
#named_parameters(named) ⇒ Object
Sets named parameters for the query.
-
#positional_parameters(positional) ⇒ Object
Sets positional parameters for the query.
-
#raw(key, value) ⇒ Object
Allows providing custom JSON key/value pairs for advanced usage.
-
#scan_consistency=(level) ⇒ Object
Customizes the consistency guarantees for this query.
Constructor Details
#initialize(adhoc: true, client_context_id: nil, max_parallelism: nil, readonly: false, scan_wait: nil, scan_cap: nil, pipeline_cap: nil, pipeline_batch: nil, metrics: nil, profile: :off, flex_index: nil, preserve_expiry: nil, scope_qualifier: nil, scan_consistency: :not_bounded, mutation_state: nil, transcoder: JsonTranscoder.new, positional_parameters: nil, named_parameters: nil, timeout: nil, retry_strategy: nil, client_context: nil, parent_span: nil) {|self| ... } ⇒ Query
Either positional_parameters
or named_parameters
may be specified.
Creates new instance of options for Cluster#query
1484 1485 1486 1487 1488 1489 1490 1491 1492 1493 1494 1495 1496 1497 1498 1499 1500 1501 1502 1503 1504 1505 1506 1507 1508 1509 1510 1511 1512 1513 1514 1515 1516 1517 1518 1519 1520 1521 1522 1523 1524 1525 1526 1527 1528 1529 |
# File 'lib/couchbase/options.rb', line 1484 def initialize(adhoc: true, client_context_id: nil, max_parallelism: nil, readonly: false, scan_wait: nil, scan_cap: nil, pipeline_cap: nil, pipeline_batch: nil, metrics: nil, profile: :off, flex_index: nil, preserve_expiry: nil, scope_qualifier: nil, scan_consistency: :not_bounded, mutation_state: nil, transcoder: JsonTranscoder.new, positional_parameters: nil, named_parameters: nil, timeout: nil, retry_strategy: nil, client_context: nil, parent_span: nil) raise ArgumentError, "Cannot pass positional and named parameters at the same time" if positional_parameters && named_parameters super(timeout: timeout, retry_strategy: retry_strategy, client_context: client_context, parent_span: parent_span) @adhoc = adhoc @client_context_id = client_context_id @max_parallelism = max_parallelism @readonly = readonly @scan_wait = scan_wait @scan_cap = scan_cap @pipeline_cap = pipeline_cap @pipeline_batch = pipeline_batch @metrics = metrics @profile = profile @flex_index = flex_index @preserve_expiry = preserve_expiry @scope_qualifier = scope_qualifier @scan_consistency = scan_consistency @mutation_state = mutation_state @transcoder = transcoder @positional_parameters = positional_parameters @named_parameters = named_parameters @raw_parameters = {} yield self if block_given? end |
Instance Attribute Details
#adhoc ⇒ Boolean
1408 1409 1410 |
# File 'lib/couchbase/options.rb', line 1408 def adhoc @adhoc end |
#client_context_id ⇒ String
1409 1410 1411 |
# File 'lib/couchbase/options.rb', line 1409 def client_context_id @client_context_id end |
#flex_index ⇒ Boolean
1418 1419 1420 |
# File 'lib/couchbase/options.rb', line 1418 def flex_index @flex_index end |
#max_parallelism ⇒ Integer
1410 1411 1412 |
# File 'lib/couchbase/options.rb', line 1410 def max_parallelism @max_parallelism end |
#metrics ⇒ Boolean
1416 1417 1418 |
# File 'lib/couchbase/options.rb', line 1416 def metrics @metrics end |
#pipeline_batch ⇒ Integer
1414 1415 1416 |
# File 'lib/couchbase/options.rb', line 1414 def pipeline_batch @pipeline_batch end |
#pipeline_cap ⇒ Integer
1415 1416 1417 |
# File 'lib/couchbase/options.rb', line 1415 def pipeline_cap @pipeline_cap end |
#preserve_expiry ⇒ Boolean
1419 1420 1421 |
# File 'lib/couchbase/options.rb', line 1419 def preserve_expiry @preserve_expiry end |
#profile ⇒ Symbol
1417 1418 1419 |
# File 'lib/couchbase/options.rb', line 1417 def profile @profile end |
#readonly ⇒ Boolean
1411 1412 1413 |
# File 'lib/couchbase/options.rb', line 1411 def readonly @readonly end |
#scan_cap ⇒ Integer
1413 1414 1415 |
# File 'lib/couchbase/options.rb', line 1413 def scan_cap @scan_cap end |
#scan_wait ⇒ Integer, #in_milliseconds
1412 1413 1414 |
# File 'lib/couchbase/options.rb', line 1412 def scan_wait @scan_wait end |
#scope_qualifier ⇒ String
1420 1421 1422 |
# File 'lib/couchbase/options.rb', line 1420 def scope_qualifier @scope_qualifier end |
#transcoder ⇒ JsonTranscoder, #decode(String)
1421 1422 1423 |
# File 'lib/couchbase/options.rb', line 1421 def transcoder @transcoder end |
Instance Method Details
#consistent_with(mutation_state) ⇒ Object
overrides consistency level set by #scan_consistency=
Sets the mutation tokens this query should be consistent with
1560 1561 1562 1563 |
# File 'lib/couchbase/options.rb', line 1560 def consistent_with(mutation_state) @scan_consistency = nil if @scan_consistency @mutation_state = mutation_state end |
#named_parameters(named) ⇒ Object
Sets named parameters for the query
1582 1583 1584 1585 |
# File 'lib/couchbase/options.rb', line 1582 def named_parameters(named) @named_parameters = named @positional_parameters = nil end |
#positional_parameters(positional) ⇒ Object
Sets positional parameters for the query
1568 1569 1570 1571 |
# File 'lib/couchbase/options.rb', line 1568 def positional_parameters(positional) @positional_parameters = positional @named_parameters = nil end |
#raw(key, value) ⇒ Object
Allows providing custom JSON key/value pairs for advanced usage
1535 1536 1537 |
# File 'lib/couchbase/options.rb', line 1535 def raw(key, value) @raw_parameters[key] = JSON.generate(value) end |
#scan_consistency=(level) ⇒ Object
overrides consistency level set by #consistent_with
Customizes the consistency guarantees for this query
:not_bounded
-
The indexer will return whatever state it has to the query engine at the time of query. This is the default (for
single-statement requests).
:request_plus
-
The indexer will wait until all mutations have been processed at the time of request before returning to the query
engine.
1550 1551 1552 1553 |
# File 'lib/couchbase/options.rb', line 1550 def scan_consistency=(level) @mutation_state = nil if @mutation_state @scan_consistency = level end |