File: queryoptimizer4.js

package info (click to toggle)
mongodb 1%3A2.4.10-5
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 82,464 kB
  • sloc: cpp: 740,225; ansic: 152,098; sh: 13,820; python: 11,864; makefile: 1,012; perl: 922; pascal: 617; java: 452; lisp: 222; asm: 174
file content (44 lines) | stat: -rw-r--r-- 1,290 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
// Check that a new plan will be selected if a recorded plan performs poorly.

t = db.jstests_queryoptimizer4;

function reset( matches, filler ) {
    t.drop();
    
    t.ensureIndex({a:1});
    t.ensureIndex({b:1});
    
    // {a:1} index best for query {a:1,b:1}
    t.save({a:1,b:1});
    t.save({a:2,b:1});
    
    // {b:1} index best for query {a:100,b:100}
    for( i = 0; i < matches; ++i ) {
        t.save({a:100,b:100});        
    }
    for( i = 0; i < filler; ++i ) {
        t.save({a:100,b:5});
    }
}

function checkCursor( query, cursor ) {
    t.find(query).itcount();
    // Check that index on 'cursor' was chosen in the above query.
    var x = t.find(query).explain(true);
    assert.eq( 'BtreeCursor ' + cursor, x.oldPlan.cursor , tojson(x) );    
}

// Check {b:1} takes over when {a:1} is much worse for query {a:100,b:100}.
reset( 1, 50 );
checkCursor( {a:1,b:1}, 'a_1' );
checkCursor( {a:100,b:100}, 'b_1' );

// Check smallest filler for which {b:1} will take over.
reset( 2, 12 );
checkCursor( {a:1,b:1}, 'a_1' );
checkCursor( {a:100,b:100}, 'b_1' );

// Check largest filler for which {b:1} will not take over - demonstrating that new plans run alongside the old plan.
reset( 2, 11 );
checkCursor( {a:1,b:1}, 'a_1' );
checkCursor( {a:100,b:100}, 'a_1' );