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
1916 1917 1918 1919 1920 1921 1922 1923 1924 1925 1926 1927 1928 1929 1930 1931 1932 1933 1934 1935 1936 1937 1938 1939 1940 1941 1942 1943 1944 1945 1946 1947 1948 1949 1950 1951 1952 1953 1954 1955 1956 1957 1958 1959 1960 1961 |
# File 'lib/couchbase/options.rb', line 1916 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
1840 1841 1842 |
# File 'lib/couchbase/options.rb', line 1840 def adhoc @adhoc end |
#client_context_id ⇒ String
1841 1842 1843 |
# File 'lib/couchbase/options.rb', line 1841 def client_context_id @client_context_id end |
#flex_index ⇒ Boolean
1850 1851 1852 |
# File 'lib/couchbase/options.rb', line 1850 def flex_index @flex_index end |
#max_parallelism ⇒ Integer
1842 1843 1844 |
# File 'lib/couchbase/options.rb', line 1842 def max_parallelism @max_parallelism end |
#metrics ⇒ Boolean
1848 1849 1850 |
# File 'lib/couchbase/options.rb', line 1848 def metrics @metrics end |
#pipeline_batch ⇒ Integer
1846 1847 1848 |
# File 'lib/couchbase/options.rb', line 1846 def pipeline_batch @pipeline_batch end |
#pipeline_cap ⇒ Integer
1847 1848 1849 |
# File 'lib/couchbase/options.rb', line 1847 def pipeline_cap @pipeline_cap end |
#preserve_expiry ⇒ Boolean
1851 1852 1853 |
# File 'lib/couchbase/options.rb', line 1851 def preserve_expiry @preserve_expiry end |
#profile ⇒ Symbol
1849 1850 1851 |
# File 'lib/couchbase/options.rb', line 1849 def profile @profile end |
#readonly ⇒ Boolean
1843 1844 1845 |
# File 'lib/couchbase/options.rb', line 1843 def readonly @readonly end |
#scan_cap ⇒ Integer
1845 1846 1847 |
# File 'lib/couchbase/options.rb', line 1845 def scan_cap @scan_cap end |
#scan_wait ⇒ Integer, #in_milliseconds
1844 1845 1846 |
# File 'lib/couchbase/options.rb', line 1844 def scan_wait @scan_wait end |
#scope_qualifier ⇒ String
1852 1853 1854 |
# File 'lib/couchbase/options.rb', line 1852 def scope_qualifier @scope_qualifier end |
#transcoder ⇒ JsonTranscoder, #decode(String)
1853 1854 1855 |
# File 'lib/couchbase/options.rb', line 1853 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
1992 1993 1994 1995 |
# File 'lib/couchbase/options.rb', line 1992 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
2014 2015 2016 2017 |
# File 'lib/couchbase/options.rb', line 2014 def named_parameters(named) @named_parameters = named @positional_parameters = nil end |
#positional_parameters(positional) ⇒ Object
Sets positional parameters for the query
2000 2001 2002 2003 |
# File 'lib/couchbase/options.rb', line 2000 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
1967 1968 1969 |
# File 'lib/couchbase/options.rb', line 1967 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.
1982 1983 1984 1985 |
# File 'lib/couchbase/options.rb', line 1982 def scan_consistency=(level) @mutation_state = nil if @mutation_state @scan_consistency = level end |