diff options
author | dan <Dan Kennedy> | 2022-12-03 21:24:26 +0000 |
---|---|---|
committer | dan <Dan Kennedy> | 2022-12-03 21:24:26 +0000 |
commit | ad23a47acdc3258e988c91eac48eb8ce7a79fd53 (patch) | |
tree | 95da521aa81425b70f1234266e449a0351243b17 /src/vdbeapi.c | |
parent | f6f01f15dd9ff495ac59f5abc3bbe15f4d8e88c8 (diff) | |
download | sqlite-ad23a47acdc3258e988c91eac48eb8ce7a79fd53.tar.gz sqlite-ad23a47acdc3258e988c91eac48eb8ce7a79fd53.zip |
Enhance SQLITE_SCANSTAT_NCYCLE so that it reports on virtual tables.
FossilOrigin-Name: 622d8eb3724bee617b55d6fb71f1a2d683db6858065adced6bf3ce9525bcd6b5
Diffstat (limited to 'src/vdbeapi.c')
-rw-r--r-- | src/vdbeapi.c | 28 |
1 files changed, 22 insertions, 6 deletions
diff --git a/src/vdbeapi.c b/src/vdbeapi.c index c00980d6b..2b9b1087f 100644 --- a/src/vdbeapi.c +++ b/src/vdbeapi.c @@ -2206,17 +2206,33 @@ int sqlite3_stmt_scanstatus_v2( break; } case SQLITE_SCANSTAT_NCYCLE: { - i64 res = -1; - if( pScan->aAddrRange[0] ){ + i64 res = 0; + if( pScan->aAddrRange[0]==0 ){ + res = -1; + }else{ int ii; - res = 0; for(ii=0; ii<ArraySize(pScan->aAddrRange); ii+=2){ int iIns = pScan->aAddrRange[ii]; int iEnd = pScan->aAddrRange[ii+1]; if( iIns==0 ) break; - while( iIns<=iEnd ){ - res += p->anCycle[iIns]; - iIns++; + if( iIns>0 ){ + while( iIns<=iEnd ){ + res += p->anCycle[iIns]; + iIns++; + } + }else{ + int iOp; + for(iOp=0; iOp<p->nOp; iOp++){ + Op *pOp = &p->aOp[iOp]; + if( pOp->p1!=iEnd ) continue; + if( pOp->opcode!=OP_VFilter && pOp->opcode!=OP_VColumn + && pOp->opcode!=OP_Rowid && pOp->opcode!=OP_VOpen + && pOp->opcode!=OP_VNext + ){ + continue; + } + res += p->anCycle[iOp]; + } } } } |