- C Add\stest\scase\sthat\sshould\shave\sbeen\spart\sof\sprevious\scommit.
- D 2022-12-05T14:20:54.124
-C Update\scomments\sin\ssqlite.h.in\sto\saccount\sfor\ssqlite3_stmt_scanstatus_v2().
-D 2022-12-05T18:52:12.491
++C Enhance\sthe\ssqlite3_stmt_scanstatus()\sAPI\sand\sadd\ssqlite3_stmt_scanstatus_v2().\sFor\screation\sof\senhanced\squery\sperformance\sreports.
++D 2022-12-05T19:16:23.509
F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1
F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea
F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724
F test/savepoint6.test f41279c5e137139fa5c21485773332c7adb98cd7
F test/savepoint7.test cde525ea3075283eb950cdcdefe23ead4f700daa
F test/savepointfault.test f044eac64b59f09746c7020ee261734de82bf9b2
- F test/scanstatus.test 9a0ed37ab6d57b50567282788fffdf832d9b16739ecc41bff9d77a8d767cf317
+ F test/scanstatus.test 7dbcfd6adc6a8df6abc59f83d6da5a27e1bce0b2f6fa55147c8176d7c44e0450
-F test/scanstatus2.test 503c8529111fbac777b225b846f3a31a020e80950d40763b65953fae46e9ceb9
++F test/scanstatus2.test cc0be2f645c32ede50affa7d4ecfaffd2b4572a4fd7f723082397c65a910a2b5
F test/schema.test 5dd11c96ba64744de955315d2e4f8992e447533690153b93377dffb2a5ef5431
F test/schema2.test 906408621ea881fdb496d878b1822572a34e32c5
F test/schema3.test 8ed4ae66e082cdd8b1b1f22d8549e1e7a0db4527a8e6ee8b6193053ee1e5c9ce
F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
- P 15f0be8a640e7bfa4130edd4650a745337bd96083b119a1553f9abf9ff066806
- R 0d5d7f5190e8e855ad343ae2d8e33bd7
-P 1a72777b1279f74f212fb2f675a4594a238e5d28f048879d7f5ad5287673c3c4
-R 8c721203ec6b199973a0c855b39497c4
++P dc7dd2d3e50e7cc474b22f1b5b219da32bcd7aa1ba56864d1dbcf0d3a6fa06f2 009462f2344b1f468cf9440343a47fec68d783a2bfb4fa6168bb227ec910b918
++R 6f58eb8b4613cbdc0da9cabf0de9170c
U dan
- Z 56bab95316a0c053d879db2cb26ee05d
-Z 6aa6d3a2a8294beaab19425ddd9ee52d
++Z dd8e28132ec997579f72120c72f627ae
# Remove this line to create a well-formed Fossil manifest.
--- /dev/null
-# 2014 November 1
++# 2022 December 5
+ #
+ # The author disclaims copyright to this source code. In place of
+ # a legal notice, here is a blessing:
+ #
+ # May you do good and not evil.
+ # May you find forgiveness for yourself and forgive others.
+ # May you share freely, never taking more than you give.
+ #
+ #***********************************************************************
+ #
+
+ set testdir [file dirname $argv0]
+ source $testdir/tester.tcl
+ set testprefix scanstatus2
+
+ ifcapable !scanstatus {
+ finish_test
+ return
+ }
+
+ do_execsql_test 1.0 {
+ CREATE TABLE t1(a, b);
+ CREATE TABLE t2(x, y);
+ INSERT INTO t1 VALUES(1, 2);
+ INSERT INTO t1 VALUES(3, 4);
+ INSERT INTO t2 VALUES('a', 'b');
+ INSERT INTO t2 VALUES('c', 'd');
+ INSERT INTO t2 VALUES('e', 'f');
+ }
+
+ proc do_zexplain_test {v2 tn sql res} {
+ db eval $sql
+ set stmt [db version -last-stmt-ptr]
+ set idx 0
+ set ret [list]
+
+ set cmd sqlite3_stmt_scanstatus
+ set f [list]
+ if {$v2} { lappend f complex }
+
+ while {1} {
+ set r [sqlite3_stmt_scanstatus -flags $f $stmt $idx]
+ if {[llength $r]==0} break
+ lappend ret [dict get $r zExplain]
+ incr idx
+ }
+ uplevel [list do_test $tn [list set {} $ret] [list {*}$res]]
+ }
+
+ proc get_cycles {stmt} {
+ set r [sqlite3_stmt_scanstatus $stmt -1]
+ dict get $r nCycle
+ }
+
+ proc foreach_scan {varname stmt body} {
+ upvar $varname var
+
+ for {set ii 0} {1} {incr ii} {
+ set r [sqlite3_stmt_scanstatus -flags complex $stmt $ii]
+ if {[llength $r]==0} break
+ array set var $r
+ uplevel $body
+ }
+ }
+
+ proc get_eqp_graph {stmt iPar nIndent} {
+ set res ""
+ foreach_scan A $stmt {
+ if {$A(iParentId)==$iPar} {
+ set txt $A(zExplain)
+ if {$A(nCycle)>=0} {
+ append txt " (nCycle=$A(nCycle))"
+ }
+ append res "[string repeat - $nIndent]$txt\n"
+ append res [get_eqp_graph $stmt $A(iSelectId) [expr $nIndent+2]]
+ }
+ }
+ set res
+ }
+
+ proc get_graph {stmt} {
+ set nCycle [get_cycles $stmt]
+ set res "QUERY (nCycle=$nCycle)\n"
+ append res [get_eqp_graph $stmt 0 2]
+ }
+
+ proc do_graph_test {tn sql res} {
+ db eval $sql
+ set stmt [db version -last-stmt-ptr]
+
+ set graph [string trim [get_graph $stmt]]
+ set graph [regsub -all {nCycle=[0-9]+} $graph nCycle=nnn]
+ uplevel [list do_test $tn [list set {} $graph] [string trim $res]]
+ }
+
+ proc puts_graph {sql} {
+ db eval $sql
+ set stmt [db version -last-stmt-ptr]
+ puts [string trim [get_graph $stmt]]
+ }
+
+
+ do_zexplain_test 0 1.1 {
+ SELECT (SELECT a FROM t1 WHERE b=x) FROM t2 WHERE y=2
+ } {
+ {SCAN t2}
+ {SCAN t1}
+ }
+ do_zexplain_test 1 1.2 {
+ SELECT (SELECT a FROM t1 WHERE b=x) FROM t2 WHERE y=2
+ } {
+ {SCAN t2}
+ {CORRELATED SCALAR SUBQUERY 1}
+ {SCAN t1}
+ }
+
+ do_graph_test 1.3 {
+ SELECT (SELECT a FROM t1 WHERE b=x) FROM t2 WHERE y=2
+ } {
+ QUERY (nCycle=nnn)
+ --SCAN t2
+ --CORRELATED SCALAR SUBQUERY 1 (nCycle=nnn)
+ ----SCAN t1
+ }
+
+ do_graph_test 1.4 {
+ WITH v2(x,y) AS MATERIALIZED (
+ SELECT x,y FROM t2
+ )
+ SELECT * FROM t1, v2 ORDER BY y;
+ } {
+ QUERY (nCycle=nnn)
+ --MATERIALIZE v2 (nCycle=nnn)
+ ----SCAN t2
+ --SCAN v2
+ --SCAN t1
+ --USE TEMP B-TREE FOR ORDER BY (nCycle=nnn)
+ }
+
+ #-------------------------------------------------------------------------
+ reset_db
+ do_execsql_test 2.0 {
+ CREATE VIRTUAL TABLE ft USING fts5(a);
+ INSERT INTO ft VALUES('abc');
+ INSERT INTO ft VALUES('def');
+ INSERT INTO ft VALUES('ghi');
+ }
+
+ do_graph_test 2.1 {
+ SELECT * FROM ft('def')
+ } {
+ QUERY (nCycle=nnn)
+ --SCAN ft VIRTUAL TABLE INDEX 0:M1 (nCycle=nnn)
+ }
+
+ finish_test
+
+