github.com/cockroachdb/pebble@v1.1.1-0.20240513155919-3622ade60459/testdata/iter_histories/range_key_masking (about) 1 reset 2 ---- 3 4 batch commit 5 range-key-set a d @8 boop 6 set a@2 a@2 7 set a@3 a@3 8 set a@9 a@9 9 set a@10 a@10 10 set b b 11 ---- 12 committed 6 keys 13 14 combined-iter 15 seek-prefix-ge a 16 next 17 next 18 next 19 next 20 next 21 ---- 22 a: (., [a-"a\x00") @8=boop UPDATED) 23 a@10: (a@10, [a-"a\x00") @8=boop) 24 a@9: (a@9, [a-"a\x00") @8=boop) 25 a@3: (a@3, [a-"a\x00") @8=boop) 26 a@2: (a@2, [a-"a\x00") @8=boop) 27 . 28 29 # Perform the above iteration with range-key masking enabled at a suffix equal 30 # to the range key's. The [a,d)@8 range key should serve as a masking, obscuring 31 # the points a@3 and a@2. 32 33 combined-iter mask-suffix=@8 34 seek-prefix-ge a 35 next 36 next 37 next 38 ---- 39 a: (., [a-"a\x00") @8=boop UPDATED) 40 a@10: (a@10, [a-"a\x00") @8=boop) 41 a@9: (a@9, [a-"a\x00") @8=boop) 42 . 43 44 # Perform the same thing but with a mask suffix below the range key's. All the 45 # points should be visible again. 46 # 47 # Then use SetOptions to raise the mask. The masked points should disappear. 48 49 combined-iter mask-suffix=@7 50 seek-prefix-ge a 51 next 52 next 53 next 54 next 55 next 56 set-options key-types=both mask-suffix=@8 57 seek-prefix-ge a 58 next 59 next 60 next 61 ---- 62 a: (., [a-"a\x00") @8=boop UPDATED) 63 a@10: (a@10, [a-"a\x00") @8=boop) 64 a@9: (a@9, [a-"a\x00") @8=boop) 65 a@3: (a@3, [a-"a\x00") @8=boop) 66 a@2: (a@2, [a-"a\x00") @8=boop) 67 . 68 . 69 a: (., [a-"a\x00") @8=boop UPDATED) 70 a@10: (a@10, [a-"a\x00") @8=boop) 71 a@9: (a@9, [a-"a\x00") @8=boop) 72 . 73 74 # Test that switching out of prefix iteration correctly expands the bounds 75 # beyond the scope of the previous prefix. 76 77 combined-iter 78 seek-prefix-ge a 79 next 80 seek-ge a@3 81 ---- 82 a: (., [a-"a\x00") @8=boop UPDATED) 83 a@10: (a@10, [a-"a\x00") @8=boop) 84 a@3: (a@3, [a-d) @8=boop UPDATED) 85 86 # Test a range key masking case where the range key is not immediately 87 # masking point keys, but masks point keys once positioned beneath it. 88 89 reset 90 ---- 91 92 batch commit 93 range-key-set d e @5 boop 94 set a@1 a1 95 set b@3 b3 96 set d@3 d3 97 ---- 98 committed 4 keys 99 100 combined-iter mask-suffix=@9 101 first 102 next 103 next 104 next 105 ---- 106 a@1: (a1, .) 107 b@3: (b3, .) 108 d: (., [d-e) @5=boop UPDATED) 109 . 110 111 # Test a broad range key that masks all the point keys. 112 113 reset block-size=20 114 ---- 115 116 batch commit 117 range-key-set a z @5 boop 118 set a@1 foo 119 set b@3 foo 120 set c@3 foo 121 set d@1 foo 122 set e@3 foo 123 set f@3 foo 124 set g@2 foo 125 set h@2 foo 126 set i@2 foo 127 set j@2 foo 128 set k@0 foo 129 set l@2 foo 130 set m@1 foo 131 set n@3 foo 132 set o@4 foo 133 set p@2 foo 134 set q@2 foo 135 set r@1 foo 136 set s@2 foo 137 set t@3 foo 138 set u@2 foo 139 set v@0 foo 140 set w@0 foo 141 set x@2 foo 142 set y@4 foo 143 ---- 144 committed 26 keys 145 146 flush 147 ---- 148 149 combined-iter mask-suffix=@9 150 first 151 next 152 stats 153 ---- 154 a: (., [a-z) @5=boop UPDATED) 155 . 156 stats: (interface (dir, seek, step): (fwd, 1, 1), (rev, 0, 0)), (internal (dir, seek, step): (fwd, 1, 1), (rev, 0, 0)), 157 (internal-stats: (block-bytes: (total 1.1KB, cached 0B, read-time 0s)), (points: (count 25, key-bytes 75B, value-bytes 75B, tombstoned 0))), 158 (range-key-stats: (count 1), (contained points: (count 25, skipped 25))) 159 160 # Repeat the above test, but with an iterator that uses a block-property filter 161 # mask. The internal stats should reflect fewer bytes read and fewer points 162 # visited by the internal iterators. 163 164 combined-iter mask-suffix=@9 mask-filter 165 first 166 next 167 stats 168 ---- 169 a: (., [a-z) @5=boop UPDATED) 170 . 171 stats: (interface (dir, seek, step): (fwd, 1, 1), (rev, 0, 0)), (internal (dir, seek, step): (fwd, 1, 1), (rev, 0, 0)), 172 (internal-stats: (block-bytes: (total 514B, cached 514B, read-time 0s)), (points: (count 2, key-bytes 6B, value-bytes 6B, tombstoned 0))), 173 (range-key-stats: (count 1), (contained points: (count 2, skipped 2))) 174 175 # Perform a similar comparison in reverse. 176 177 combined-iter mask-suffix=@9 178 last 179 prev 180 stats 181 ---- 182 a: (., [a-z) @5=boop UPDATED) 183 . 184 stats: (interface (dir, seek, step): (fwd, 0, 0), (rev, 1, 1)), (internal (dir, seek, step): (fwd, 0, 0), (rev, 1, 1)), 185 (internal-stats: (block-bytes: (total 1.1KB, cached 1.1KB, read-time 0s)), (points: (count 25, key-bytes 75B, value-bytes 75B, tombstoned 0))), 186 (range-key-stats: (count 1), (contained points: (count 25, skipped 25))) 187 188 combined-iter mask-suffix=@9 mask-filter 189 last 190 prev 191 stats 192 ---- 193 a: (., [a-z) @5=boop UPDATED) 194 . 195 stats: (interface (dir, seek, step): (fwd, 0, 0), (rev, 1, 1)), (internal (dir, seek, step): (fwd, 0, 0), (rev, 1, 1)), 196 (internal-stats: (block-bytes: (total 514B, cached 514B, read-time 0s)), (points: (count 2, key-bytes 6B, value-bytes 6B, tombstoned 0))), 197 (range-key-stats: (count 1), (contained points: (count 2, skipped 2))) 198 199 # Perform similar comparisons with seeks. 200 201 combined-iter mask-suffix=@9 202 seek-ge m 203 next 204 stats 205 ---- 206 m: (., [a-z) @5=boop UPDATED) 207 . 208 stats: (interface (dir, seek, step): (fwd, 1, 1), (rev, 0, 0)), (internal (dir, seek, step): (fwd, 1, 1), (rev, 0, 0)), 209 (internal-stats: (block-bytes: (total 789B, cached 789B, read-time 0s)), (points: (count 13, key-bytes 39B, value-bytes 39B, tombstoned 0))), 210 (range-key-stats: (count 1), (contained points: (count 13, skipped 13))) 211 212 combined-iter mask-suffix=@9 mask-filter 213 seek-ge m 214 next 215 stats 216 ---- 217 m: (., [a-z) @5=boop UPDATED) 218 . 219 stats: (interface (dir, seek, step): (fwd, 1, 1), (rev, 0, 0)), (internal (dir, seek, step): (fwd, 1, 1), (rev, 0, 0)), 220 (internal-stats: (block-bytes: (total 514B, cached 514B, read-time 0s)), (points: (count 2, key-bytes 6B, value-bytes 6B, tombstoned 0))), 221 (range-key-stats: (count 1), (contained points: (count 2, skipped 2))) 222 223 combined-iter mask-suffix=@9 224 seek-lt m 225 prev 226 stats 227 ---- 228 a: (., [a-z) @5=boop UPDATED) 229 . 230 stats: (interface (dir, seek, step): (fwd, 0, 0), (rev, 1, 1)), (internal (dir, seek, step): (fwd, 0, 0), (rev, 1, 1)), 231 (internal-stats: (block-bytes: (total 789B, cached 789B, read-time 0s)), (points: (count 12, key-bytes 36B, value-bytes 36B, tombstoned 0))), 232 (range-key-stats: (count 1), (contained points: (count 12, skipped 12))) 233 234 combined-iter mask-suffix=@9 mask-filter 235 seek-lt m 236 prev 237 stats 238 ---- 239 a: (., [a-z) @5=boop UPDATED) 240 . 241 stats: (interface (dir, seek, step): (fwd, 0, 0), (rev, 1, 1)), (internal (dir, seek, step): (fwd, 0, 0), (rev, 1, 1)), 242 (internal-stats: (block-bytes: (total 539B, cached 539B, read-time 0s)), (points: (count 2, key-bytes 6B, value-bytes 6B, tombstoned 0))), 243 (range-key-stats: (count 1), (contained points: (count 2, skipped 2)))