File: index_check6.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 (81 lines) | stat: -rw-r--r-- 3,603 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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81

t = db.index_check6;
t.drop();

t.ensureIndex( { age : 1 , rating : 1 } );

for ( var age=10; age<50; age++ ){
    for ( var rating=0; rating<10; rating++ ){
        t.save( { age : age , rating : rating } );
    }
}

assert.eq( 10 , t.find( { age : 30 } ).explain().nscanned , "A" );
assert.eq( 20 , t.find( { age : { $gte : 29 , $lte : 30 } } ).explain().nscanned , "B" );
assert.eq( 18 , t.find( { age : { $gte : 25 , $lte : 30 }, rating: {$in: [0,9] } } ).hint( {age:1,rating:1} ).explain().nscanned , "C1" );
assert.eq( 23 , t.find( { age : { $gte : 25 , $lte : 30 }, rating: {$in: [0,8] } } ).hint( {age:1,rating:1} ).explain().nscanned , "C2" );
assert.eq( 28 , t.find( { age : { $gte : 25 , $lte : 30 }, rating: {$in: [1,8] } } ).hint( {age:1,rating:1} ).explain().nscanned , "C3" );

assert.eq( 4 , t.find( { age : { $gte : 29 , $lte : 30 } , rating : 5 } ).hint( {age:1,rating:1} ).explain().nscanned , "C" ); // SERVER-371
assert.eq( 6 , t.find( { age : { $gte : 29 , $lte : 30 } , rating : { $gte : 4 , $lte : 5 } } ).hint( {age:1,rating:1} ).explain().nscanned , "D" ); // SERVER-371

assert.eq.automsg( "2", "t.find( { age:30, rating:{ $gte:4, $lte:5} } ).explain().nscanned" );

t.drop();

for ( var a=1; a<10; a++ ){
    for ( var b=0; b<10; b++ ){
        for ( var c=0; c<10; c++ ) {
            t.save( { a:a, b:b, c:c } );
        }
    }
}

function doQuery( count, query, sort, index ) {
    assert.eq( count, t.find( query ).hint( index ).sort( sort ).explain().nscanned );
}

function doTest( sort, index ) {
    doQuery( 1, { a:5, b:5, c:5 }, sort, index );
    doQuery( 2, { a:5, b:5, c:{$gte:5,$lte:6} }, sort, index );
    doQuery( 1, { a:5, b:5, c:{$gte:5.5,$lte:6} }, sort, index );
    doQuery( 1, { a:5, b:5, c:{$gte:5,$lte:5.5} }, sort, index );
    doQuery( 3, { a:5, b:5, c:{$gte:5,$lte:7} }, sort, index );
    doQuery( 4, { a:5, b:{$gte:5,$lte:6}, c:5 }, sort, index );
    if ( sort.b > 0 ) {
        doQuery( 2, { a:5, b:{$gte:5.5,$lte:6}, c:5 }, sort, index );
        doQuery( 2, { a:5, b:{$gte:5,$lte:5.5}, c:5 }, sort, index );
    } else {
        doQuery( 2, { a:5, b:{$gte:5.5,$lte:6}, c:5 }, sort, index );
        doQuery( 2, { a:5, b:{$gte:5,$lte:5.5}, c:5 }, sort, index );
    }
    doQuery( 7, { a:5, b:{$gte:5,$lte:7}, c:5 }, sort, index );
    doQuery( 4, { a:{$gte:5,$lte:6}, b:5, c:5 }, sort, index );    
    if ( sort.a > 0 ) {
        doQuery( 2, { a:{$gte:5.5,$lte:6}, b:5, c:5 }, sort, index );
        doQuery( 2, { a:{$gte:5,$lte:5.5}, b:5, c:5 }, sort, index );    
        doQuery( 3, { a:{$gte:5.5,$lte:6}, b:5, c:{$gte:5,$lte:6} }, sort, index );    
    } else {
        doQuery( 2, { a:{$gte:5.5,$lte:6}, b:5, c:5 }, sort, index );
        doQuery( 2, { a:{$gte:5,$lte:5.5}, b:5, c:5 }, sort, index );    
        doQuery( 3, { a:{$gte:5.5,$lte:6}, b:5, c:{$gte:5,$lte:6} }, sort, index );    
    }
    doQuery( 7, { a:{$gte:5,$lte:7}, b:5, c:5 }, sort, index );
    doQuery( 6, { a:{$gte:5,$lte:6}, b:5, c:{$gte:5,$lte:6} }, sort, index );    
    doQuery( 6, { a:5, b:{$gte:5,$lte:6}, c:{$gte:5,$lte:6} }, sort, index );    
    doQuery( 10, { a:{$gte:5,$lte:6}, b:{$gte:5,$lte:6}, c:5 }, sort, index );    
    doQuery( 14, { a:{$gte:5,$lte:6}, b:{$gte:5,$lte:6}, c:{$gte:5,$lte:6} }, sort, index );    
}

for ( var a = -1; a <= 1; a += 2 ) {
    for( var b = -1; b <= 1; b += 2 ) {
        for( var c = -1; c <= 1; c += 2 ) {
            t.dropIndexes();
            var spec = {a:a,b:b,c:c};
            t.ensureIndex( spec );
            doTest( spec, spec );
            doTest( {a:-a,b:-b,c:-c}, spec );
        }
    }
}