Class: Believer::Query
Instance Attribute Summary collapse
#wheres
Instance Method Summary
collapse
#where
Methods inherited from Command
#clone, #connection, #execute
Constructor Details
#initialize(attrs) ⇒ Query
8
9
10
|
# File 'lib/believer/query.rb', line 8
def initialize(attrs)
super
end
|
Instance Attribute Details
#limit_to ⇒ Object
Returns the value of attribute limit_to.
4
5
6
|
# File 'lib/believer/query.rb', line 4
def limit_to
@limit_to
end
|
#order_by ⇒ Object
Returns the value of attribute order_by.
4
5
6
|
# File 'lib/believer/query.rb', line 4
def order_by
@order_by
end
|
#record_class ⇒ Object
Returns the value of attribute record_class.
4
5
6
|
# File 'lib/believer/query.rb', line 4
def record_class
@record_class
end
|
#selects ⇒ Object
Returns the value of attribute selects.
4
5
6
|
# File 'lib/believer/query.rb', line 4
def selects
@selects
end
|
Instance Method Details
#[](index) ⇒ Object
122
123
124
|
# File 'lib/believer/query.rb', line 122
def [](index)
to_a[index]
end
|
#count ⇒ Object
104
105
106
107
108
109
110
111
112
113
114
|
# File 'lib/believer/query.rb', line 104
def count
count_q = clone
count_q.selects = ['COUNT(*)']
result = count_q.execute
cnt = -1
result.each do |row|
cnt = row['count']
end
cnt
end
|
#delete_all(options = {}) ⇒ Object
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
|
# File 'lib/believer/query.rb', line 70
def delete_all(options = {})
cnt = count
chunk_size = options[:delete_batch_chunk_size] || (self.limit_to.nil? ? nil : self.limit_to.size) || cnt
key_cols = self.record_class.primary_key_columns
deleted_count = 0
while deleted_count < cnt
batch = Batch.new(:record_class => @record_class)
rows_to_delete = clone.select(key_cols).limit(chunk_size).execute
rows_to_delete.each do |row_to_delete|
batch << Delete.new(:record_class => self.record_class).where(row_to_delete)
end
batch.execute
deleted_count += batch.commands.size
end
deleted_count
end
|
#destroy_all ⇒ Object
62
63
64
65
66
67
68
|
# File 'lib/believer/query.rb', line 62
def destroy_all
objects = to_a
objects.each do |obj|
obj.destroy
end
objects.size
end
|
#each ⇒ Object
116
117
118
119
120
|
# File 'lib/believer/query.rb', line 116
def each
to_a.each do |r|
yield r
end
end
|
#first ⇒ Object
126
127
128
129
|
# File 'lib/believer/query.rb', line 126
def first
return @result_rows.first unless @result_rows.nil?
clone.limit(1)[0]
end
|
#last ⇒ Object
131
132
133
134
135
136
137
|
# File 'lib/believer/query.rb', line 131
def last
return @result_rows.last unless @result_rows.nil?
raise "Cannot retrieve last of no order column is set" if @order_by.nil?
lq = clone.limit(1)
lq.order_by = @order_by.inverse
lq[0]
end
|
#limit(l) ⇒ Object
32
33
34
35
36
|
# File 'lib/believer/query.rb', line 32
def limit(l)
q = clone
q.limit_to = Limit.new(l)
q
end
|
#order(field, order = :asc) ⇒ Object
26
27
28
29
30
|
# File 'lib/believer/query.rb', line 26
def order(field, order = :asc)
q = clone
q.order_by = OrderBy.new(field, order)
q
end
|
#query_attributes ⇒ Object
12
13
14
15
|
# File 'lib/believer/query.rb', line 12
def query_attributes
attrs = super
attrs.merge(:order_by => @order_by, :selects => @selects, :limit_to => @limit_to)
end
|
#select(*fields) ⇒ Object
17
18
19
20
21
22
23
24
|
# File 'lib/believer/query.rb', line 17
def select(*fields)
q = clone
q.selects ||= []
q.selects += fields
q.selects.flatten!
q
end
|
#size ⇒ Object
100
101
102
|
# File 'lib/believer/query.rb', line 100
def size
to_a.size
end
|
#to_a ⇒ Object
87
88
89
90
91
92
93
94
95
96
97
98
|
# File 'lib/believer/query.rb', line 87
def to_a
unless @result_rows
result = execute
@result_rows = []
start = Time.now
result.each do |row|
@result_rows << @record_class.instantiate_from_result_rows(row)
end
puts "Took #{sprintf "%.3f", (Time.now - start)*1000.0} ms to deserialize #{@result_rows.size} object(s)"
end
@result_rows
end
|
#to_cql ⇒ Object
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
# File 'lib/believer/query.rb', line 46
def to_cql
cql = "SELECT "
if @selects && @selects.any?
cql << "#{@selects.join(', ')}"
else
cql << @record_class.columns.keys.join(',')
end
cql << " FROM #{@record_class.table_name}"
cql << " WHERE #{@wheres.map { |wc| "#{wc.to_cql}" }.join(' AND ')}" if @wheres && @wheres.any?
cql << " #{@order_by.to_cql}" unless @order_by.nil?
cql << " #{@limit_to.to_cql}" unless @limit_to.nil?
cql
end
|