occams-record 1.1.5 → 1.1.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/lib/occams-record/batches.rb +23 -12
- data/lib/occams-record/raw_query.rb +1 -1
- data/lib/occams-record/version.rb +1 -1
- metadata +2 -2
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: 466aabbac2317ba6b65e5d02c4f244f317640bbbea08a2949c4b4ebe59be5bfb
|
|
4
|
+
data.tar.gz: cd50c8465764d9f811acccd1d833357ced98e2ba5812e3c5d12a3f2534495fb1
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: d5935484d5a729eb82fa12eb6402b48d7a54f54d9d8fe2986694eada3af26296c88536c78bbf2a05239483d66deb2c0a7bd6f70097b51547d95d5ded77bbec11
|
|
7
|
+
data.tar.gz: b0162c9054e18a8c1c265de9e47b5cd2bb00dcc53bd7406a166d67b3c4a390389a0e06f80e345fff8ed89fc2b7edb2b87a9e30a4fc165c6a4f9be2541bbebd71
|
|
@@ -13,12 +13,13 @@ module OccamsRecord
|
|
|
13
13
|
#
|
|
14
14
|
# @param batch_size [Integer]
|
|
15
15
|
# @param use_transaction [Boolean] Ensure it runs inside of a database transaction
|
|
16
|
+
# @param append_order_by [String] Append this column to ORDER BY to ensure consistent results. Defaults to the primary key. Pass false to disable.
|
|
16
17
|
# @yield [OccamsRecord::Results::Row]
|
|
17
18
|
# @return [Enumerator] will yield each record
|
|
18
19
|
#
|
|
19
|
-
def find_each(batch_size: 1000, use_transaction: true)
|
|
20
|
+
def find_each(batch_size: 1000, use_transaction: true, append_order_by: nil)
|
|
20
21
|
enum = Enumerator.new { |y|
|
|
21
|
-
batches(of: batch_size, use_transaction: use_transaction).each { |batch|
|
|
22
|
+
batches(of: batch_size, use_transaction: use_transaction, append_order_by: append_order_by).each { |batch|
|
|
22
23
|
batch.each { |record| y.yield record }
|
|
23
24
|
}
|
|
24
25
|
}
|
|
@@ -39,11 +40,12 @@ module OccamsRecord
|
|
|
39
40
|
#
|
|
40
41
|
# @param batch_size [Integer]
|
|
41
42
|
# @param use_transaction [Boolean] Ensure it runs inside of a database transaction
|
|
43
|
+
# @param append_order_by [String] Append this column to ORDER BY to ensure consistent results. Defaults to the primary key. Pass false to disable.
|
|
42
44
|
# @yield [OccamsRecord::Results::Row]
|
|
43
45
|
# @return [Enumerator] will yield each batch
|
|
44
46
|
#
|
|
45
|
-
def find_in_batches(batch_size: 1000, use_transaction: true)
|
|
46
|
-
enum = batches(of: batch_size, use_transaction: use_transaction)
|
|
47
|
+
def find_in_batches(batch_size: 1000, use_transaction: true, append_order_by: nil)
|
|
48
|
+
enum = batches(of: batch_size, use_transaction: use_transaction, append_order_by: append_order_by)
|
|
47
49
|
if block_given?
|
|
48
50
|
enum.each { |batch| yield batch }
|
|
49
51
|
else
|
|
@@ -61,34 +63,43 @@ module OccamsRecord
|
|
|
61
63
|
#
|
|
62
64
|
# @param of [Integer] batch size
|
|
63
65
|
# @param use_transaction [Boolean] Ensure it runs inside of a database transaction
|
|
66
|
+
# @param append_order_by [String] Append this column to ORDER BY to ensure consistent results. Defaults to the primary key. Pass false to disable.
|
|
64
67
|
# @return [Enumerator] yields batches
|
|
65
68
|
#
|
|
66
|
-
def batches(of:, use_transaction: true)
|
|
69
|
+
def batches(of:, use_transaction: true, append_order_by: nil)
|
|
70
|
+
append_order =
|
|
71
|
+
case append_order_by
|
|
72
|
+
when false then nil
|
|
73
|
+
when nil then model.primary_key
|
|
74
|
+
else append_order_by
|
|
75
|
+
end
|
|
76
|
+
|
|
67
77
|
Enumerator.new do |y|
|
|
68
78
|
if use_transaction and model.connection.open_transactions == 0
|
|
69
79
|
model.connection.transaction {
|
|
70
|
-
run_batches y, of
|
|
80
|
+
run_batches y, of, append_order
|
|
71
81
|
}
|
|
72
82
|
else
|
|
73
|
-
run_batches y, of
|
|
83
|
+
run_batches y, of, append_order
|
|
74
84
|
end
|
|
75
85
|
end
|
|
76
86
|
end
|
|
77
87
|
|
|
78
|
-
def run_batches(y, of)
|
|
88
|
+
def run_batches(y, of, append_order_by = nil)
|
|
79
89
|
limit = scope.limit_value
|
|
80
90
|
batch_size = limit && limit < of ? limit : of
|
|
81
91
|
|
|
82
92
|
offset = scope.offset_value || 0
|
|
83
93
|
out_of_records, count = false, 0
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
94
|
+
order_by =
|
|
95
|
+
if append_order_by
|
|
96
|
+
append_order_by.to_s == model.primary_key.to_s ? append_order_by.to_sym : append_order_by
|
|
97
|
+
end
|
|
87
98
|
|
|
88
99
|
until out_of_records
|
|
89
100
|
l = limit && batch_size > limit - count ? limit - count : batch_size
|
|
90
101
|
q = scope
|
|
91
|
-
q = q.order(
|
|
102
|
+
q = q.order(order_by) if order_by
|
|
92
103
|
q = q.offset(offset).limit(l)
|
|
93
104
|
results = Query.new(q, use: @use, query_logger: @query_logger, eager_loaders: @eager_loaders).run
|
|
94
105
|
|
|
@@ -156,7 +156,7 @@ module OccamsRecord
|
|
|
156
156
|
# @param use_transaction [Boolean] Ensure it runs inside of a database transaction
|
|
157
157
|
# @return [Enumerator] yields batches
|
|
158
158
|
#
|
|
159
|
-
def batches(of:, use_transaction: true)
|
|
159
|
+
def batches(of:, use_transaction: true, append_order_by: nil)
|
|
160
160
|
unless @sql =~ /LIMIT\s+%\{batch_limit\}/i and @sql =~ /OFFSET\s+%\{batch_offset\}/i
|
|
161
161
|
raise ArgumentError, "When using find_each/find_in_batches you must specify 'LIMIT %{batch_limit} OFFSET %{batch_offset}'. SQL statement: #{@sql}"
|
|
162
162
|
end
|
metadata
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
|
2
2
|
name: occams-record
|
|
3
3
|
version: !ruby/object:Gem::Version
|
|
4
|
-
version: 1.1.
|
|
4
|
+
version: 1.1.6
|
|
5
5
|
platform: ruby
|
|
6
6
|
authors:
|
|
7
7
|
- Jordan Hollinger
|
|
8
8
|
autorequire:
|
|
9
9
|
bindir: bin
|
|
10
10
|
cert_chain: []
|
|
11
|
-
date: 2020-05-
|
|
11
|
+
date: 2020-05-14 00:00:00.000000000 Z
|
|
12
12
|
dependencies:
|
|
13
13
|
- !ruby/object:Gem::Dependency
|
|
14
14
|
name: activerecord
|