]>
git.ipfire.org Git - thirdparty/sqlite.git/log
drh [Tue, 8 May 2018 13:03:31 +0000 (13:03 +0000)]
Fix a harmless compiler warning in fuzzcheck. Add new OSSFuzz test cases
to the test case library.
FossilOrigin-Name:
d2619746cb233f4be127a77988548dd1d90eebddf0d0ac9107913b240553e5d0
drh [Tue, 8 May 2018 12:49:53 +0000 (12:49 +0000)]
drh [Mon, 7 May 2018 18:41:19 +0000 (18:41 +0000)]
Activate the cell-overwrite optimization for index b-trees.
FossilOrigin-Name:
a68697d10ef17d452c8279181186faad7bc54e3a35858a336552f717449065ea
drh [Mon, 7 May 2018 17:27:04 +0000 (17:27 +0000)]
Improved comments on the cell-overwrite optimization code.
FossilOrigin-Name:
a4fe966da2fc479b18bf521ff596000410af3a611f7d8723d126795e595ccf22
drh [Mon, 7 May 2018 11:48:22 +0000 (11:48 +0000)]
On an UPDATE, try to overwrite an existing btree cell with the modified
content, if the old and new cell are the same size. Use memcmp() first
to avoid dirtying pages that are unchanged.
FossilOrigin-Name:
5887d8beb502ad62689d31b850f46ab50831a1e9db36adf20d55ad45619d207e
drh [Mon, 7 May 2018 11:37:34 +0000 (11:37 +0000)]
Fix harmless compiler warnings associated with the new EXPLAIN QUERY PLAN logic.
FossilOrigin-Name:
374d8e264487b0437a8d995ced1bc026a92d495a2d0568f65f033e9ebe11d0e2
drh [Mon, 7 May 2018 11:29:59 +0000 (11:29 +0000)]
Fix harmless compiler warnings in the cell-overwrite logic.
FossilOrigin-Name:
3e11dc3183bc3e8ec49af244a8e8b3e07d12f7a2e59028b2bf64ce0ab589a91f
drh [Mon, 7 May 2018 02:50:38 +0000 (02:50 +0000)]
Backout change [
05fee1a21ea398f1e4d6f1cf3 ] because it does not take into
account the LD_LIBRARY_PATH environment variable used by dl_open().
FossilOrigin-Name:
b348d1193a7a3ed4d3e656b6cc95a41f87eae29222e0723850a5eb5ffabffd00
drh [Sat, 5 May 2018 16:50:35 +0000 (16:50 +0000)]
In an ORDER BY LIMIT, make sure the ORDER BY expression evaluator does not
try to reuse values from the result set if the result set has not yet
be computed. This fixes a bug in the recent deferred-row loading
optimization, check-in [
c381f0ea57002a264fd958b28e ].
OSSFuzz discovered the problem.
FossilOrigin-Name:
5d61e75f32de09c81dbe844443209f063cccb005d60b846900de5b023643fc3b
drh [Sat, 5 May 2018 01:23:28 +0000 (01:23 +0000)]
Fix a slightly incorrect corruption detection branch in the btree logic.
FossilOrigin-Name:
9191ff670cb7f36e0b2dac4a22888679b639845687aef8edcc3c05e35ba71eda
drh [Fri, 4 May 2018 19:18:27 +0000 (19:18 +0000)]
drh [Fri, 4 May 2018 18:32:11 +0000 (18:32 +0000)]
drh [Fri, 4 May 2018 04:49:55 +0000 (04:49 +0000)]
For the amalgamation-tarball, enable FTS5 and JSON1 by default and
provide a new --enable-debug option that actives debugging facilities.
FossilOrigin-Name:
03edecaf9dcfc927aa60c2a17590a432b17de1647d480d277b4aafc8018c2d20
drh [Fri, 4 May 2018 00:39:43 +0000 (00:39 +0000)]
Make a separate limb in the EXPLAIN QUERY PLAN output for the various lines
associated with the OR-optimization.
FossilOrigin-Name:
75ac7b4e4fd0811ca80c719badacff207e0bbd00ac64dde3b3d4ec676fad472d
drh [Thu, 3 May 2018 23:20:06 +0000 (23:20 +0000)]
In ORDER BY LIMIT queries, try to evaluate the ORDER BY terms first, and it
it becomes clear that the row will not come in under the LIMIT, then skip
evaluation of the other columns.
FossilOrigin-Name:
c381f0ea57002a264fd958b28e4921cb9c9e73a10fb592f6bb64e6bc9bd16d39
drh [Thu, 3 May 2018 22:52:56 +0000 (22:52 +0000)]
Fix a branch that has become unreachable due to recent enhancements.
FossilOrigin-Name:
81ab5e0d106fb9f2de80d17c8167d8542c6721b8d7ec69c43e1571c2dcadeddd
drh [Thu, 3 May 2018 21:51:30 +0000 (21:51 +0000)]
Improved security for VACUUM. This check-in combines the fixes
of [
ab0d99d0b5ede ] and [
27754b74ddf646 ] in a way that is less likely to
to be broken by future changes.
FossilOrigin-Name:
260fc696538b195e8decabaab46771f664fb829b539efa86fb0b8170db01fa0a
drh [Thu, 3 May 2018 19:56:50 +0000 (19:56 +0000)]
Overhaul of EXPLAIN QUERY PLAN. The output is now in the form of a tree.
More details of the query plan are shown, and what is shown is truer to what
actually happens.
FossilOrigin-Name:
ff01bbdabc4b9db3db8b928979442c91b32d72082158e4f5fe62ae51a73649d2
drh [Thu, 3 May 2018 19:47:14 +0000 (19:47 +0000)]
drh [Thu, 3 May 2018 16:56:06 +0000 (16:56 +0000)]
Fix various error handling conditions on the cell overwrite optimization.
Fix a test case so that it works with the new optimization.
FossilOrigin-Name:
f89b54f41405ed7e28132f66b8a0c690a087c2412c8f55790c2beabb0b521645
drh [Thu, 3 May 2018 14:07:18 +0000 (14:07 +0000)]
The BtCursor.info fields are only valid if info.nSize!=0.
FossilOrigin-Name:
54c537eead5b08104cfaf0d5b1e2706e53d6f74be2ca02e06229024fd889fc94
drh [Thu, 3 May 2018 13:56:23 +0000 (13:56 +0000)]
Add more corruption checking to the cell overwrite logic.
FossilOrigin-Name:
58d14afe1e1288d114ea213458b3121e0a95670887861928858b7f143c76f789
drh [Thu, 3 May 2018 12:57:48 +0000 (12:57 +0000)]
drh [Thu, 3 May 2018 03:59:02 +0000 (03:59 +0000)]
The sqlite3BtreeInsert() routine tries to overwrite an existing cell with
modified content if the new content is the same size. Pages are only dirtied
if they change. This prototype works some, but still has issues.
FossilOrigin-Name:
489451b378819621537231c1c8a07704437e11c1f5384fd53b09f3977d2213a4
drh [Thu, 3 May 2018 01:37:13 +0000 (01:37 +0000)]
Enhance EXPLAIN QUERY PLAN to report the generation of constant rows using
VALUES or just a SELECT without FROM.
FossilOrigin-Name:
c75eee69fa8a9b56ee58a4cc539e80cc982f43390dc3a357344d58479dd89a41
drh [Wed, 2 May 2018 19:42:33 +0000 (19:42 +0000)]
More test case updates. Tests are all running now.
FossilOrigin-Name:
dab5e5294813891469660cceb211ac1a1e526715bb57dcdbb1ab90321e6a4dad
drh [Wed, 2 May 2018 18:00:17 +0000 (18:00 +0000)]
Fix test cases so that they work with the new EXPLAIN QUERY PLAN output
format. Only some of the cases have been fixed. This is an incremental
check-in.
FossilOrigin-Name:
5f0e803e33aa557865d5fc830d9202d628de9a94c9757058ca48f1a560702cd3
drh [Wed, 2 May 2018 16:13:48 +0000 (16:13 +0000)]
Improved EQP output for recursive CTEs and multi-value VALUES clauses.
FossilOrigin-Name:
f2f525548c65f89f55cbe91da8a21512dedc6f7b68b58b7906d653e800a2963a
drh [Wed, 2 May 2018 15:00:26 +0000 (15:00 +0000)]
Prevent VACUUM from running any commands in sqlite_master.sql other than
CREATE statements. That is all that should be there anyhow. This fixes
a problem discovered by OSSFuzz. Test cases in TH3.
FossilOrigin-Name:
ab0d99d0b5edece4c639baa47ce1ca2c02774cb2515e5b7f36d9bd312ccd3310
drh [Wed, 2 May 2018 14:24:34 +0000 (14:24 +0000)]
Fix a dangling-else problem that was causing recursive CTEs to malfunction.
Begin fixing test cases to work with the new EQP output.
FossilOrigin-Name:
82ca44b82fed6814c84440ba8bfaa019488ab956e84ac165180e2fcece6facb2
dan [Wed, 2 May 2018 08:12:22 +0000 (08:12 +0000)]
Fix a problem in the xBestIndex method of the closure extension causing it to
allocate non-contiguous argvIndex values in some cases (an "xBestIndex
malfunction" error).
FossilOrigin-Name:
0c67150749cb3d067e14b2dcac9c3489e0f14bd18c0387f1d9bc93d21fc96fe5
mistachkin [Wed, 2 May 2018 03:01:50 +0000 (03:01 +0000)]
Add sqlite3_win32_set_directory8() and sqlite3_win32_set_directory16() functions.
FossilOrigin-Name:
22089ea2bbea93eb1da7f08344789a5455077169443e40025f053d2a117f1c08
drh [Wed, 2 May 2018 02:22:22 +0000 (02:22 +0000)]
Improvements to the EQP display for compound select statements.
FossilOrigin-Name:
699a77e479010a331b0423f157a2fbfc373688e3d0d04ae5e64376c00cb3d488
drh [Wed, 2 May 2018 00:33:43 +0000 (00:33 +0000)]
Begin reengineering the EXPLAIN QUERY PLAN function to provide more
intuitive output.
FossilOrigin-Name:
70b48a7972dfbb44af3ccd8ccd830e984bec88d80a78b3566a5de86a16e7fc14
drh [Tue, 1 May 2018 18:39:31 +0000 (18:39 +0000)]
The SQLITE_ALLOW_SQLITE_MASTER_INDEX compile-time option allows a CREATE INDEX
statement against the sqlite_master table. Once created, the index works, and
is usable by legacy instances of SQLite.
FossilOrigin-Name:
853f3163597b9946c0cbeb808ea6fd33a0cf48ae6b8f4459c4165db377f33a9e
drh [Mon, 30 Apr 2018 19:32:49 +0000 (19:32 +0000)]
Defer loading result column values into registers on an ORDER BY LIMIT until
we know that the LIMIT does not exclude the current row.
FossilOrigin-Name:
ce4ef46058f4aaea6623a41255a2e4b69bb24f16a287391df48f6bacdb4c4989
drh [Sat, 28 Apr 2018 19:08:02 +0000 (19:08 +0000)]
Test cases added for SQLITE_DBCONFIG_RESET_DATABASE.
FossilOrigin-Name:
08665a9e2e50a0a1e62529884cf65f8090debe89a306a3904b53268729ab5ad5
dan [Sat, 28 Apr 2018 18:20:01 +0000 (18:20 +0000)]
Fix an RBU problem causing spurious SQLITE_CONSTRAINT errors when restarting
an RBU update in which more than one source table writes to a single target
database table.
FossilOrigin-Name:
564ae8297d417ba4b7978e430d41f125007177673163f6ed9adc3a3974f73d24
drh [Sat, 28 Apr 2018 13:21:00 +0000 (13:21 +0000)]
Add the SQLITE_DBCONFIG_RESET_DATABASE control for resetting a corrupt
database file without closing any database connections. Added the
".dbconfig" command to the CLI.
FossilOrigin-Name:
a200a49edeaca5a787a3036070f7ced3cb6e9495f8afe7b74d5cde02c79b20dc
drh [Sat, 28 Apr 2018 12:43:16 +0000 (12:43 +0000)]
Add the SQLITE_DBCONFIG_RESET_DATABASE control as a replacement for
the reset_database pragma. Resetting the database should be hard enough
to do that it cannot be done by accident.
FossilOrigin-Name:
ff836cb8b0377c5970ecb2b797702e2b5d208eda443ecbd55f4c238a3094b28a
drh [Sat, 28 Apr 2018 11:22:53 +0000 (11:22 +0000)]
drh [Sat, 28 Apr 2018 04:16:43 +0000 (04:16 +0000)]
Prevent deep recursions on nested COLLATE operators.
FossilOrigin-Name:
6e098ee415f1a530e17a942c9ba51d67c25a3ebff6b97377b7858d0b10bcec92
drh [Sat, 28 Apr 2018 04:10:55 +0000 (04:10 +0000)]
mistachkin [Sat, 28 Apr 2018 01:46:22 +0000 (01:46 +0000)]
Document and expose sqlite3_win32_set_directory() function for use on Win32.
FossilOrigin-Name:
7626b593405ca720e371b9f698b72b499b7c829bfe00f758140bc542cf970689
mistachkin [Sat, 28 Apr 2018 01:44:27 +0000 (01:44 +0000)]
Add comments about the intended use of the sqlite3_data_directory variable as it pertains to the sqlite3_win32_set_directory function.
FossilOrigin-Name:
d11c419756ce28fcc1f58df6bbe59a3d8d19d0441970aa7bfa216ba915ceddf5
drh [Sat, 28 Apr 2018 01:27:09 +0000 (01:27 +0000)]
Add the "PRAGMA reset_database=ON|OFF" command. When on, it causes the
database to appear to be empty, causing the next transaction to reset it to
an empty database.
FossilOrigin-Name:
02e1a13c1f04bb72599b98f51240c78d0d050de264fef5808fd97db3f4c16dac
mistachkin [Fri, 27 Apr 2018 22:42:37 +0000 (22:42 +0000)]
Document and expose sqlite3_win32_set_directory() function for use on Win32.
FossilOrigin-Name:
cbce7180ee664367ee8fc1f8af703eb7845bb58ade6870cc3b7608dcbe5952b3
dan [Fri, 27 Apr 2018 18:05:01 +0000 (18:05 +0000)]
Update test script fts3expr4.test so that it always creates fts3 tokenizers in
the "en_US" locality.
FossilOrigin-Name:
576a8f69ae25883f752e58953624e9f7126db998bebaa1f07f7c2ec47aaecabe
dan [Fri, 27 Apr 2018 16:35:44 +0000 (16:35 +0000)]
Fix a test script error causing tests to fail in soak.test.
FossilOrigin-Name:
462b52b121c1882e0eca819bc30c0f6e94d7fdd60047d2c32adeff3a1eb70546
drh [Fri, 27 Apr 2018 15:17:08 +0000 (15:17 +0000)]
Enhance the comments in the templatevtab.c implementation.
FossilOrigin-Name:
05f6278a02e5cde89f76ced5af7d508e26576d7291dad7ee9e06b1a3be516cb0
drh [Thu, 26 Apr 2018 18:34:26 +0000 (18:34 +0000)]
The previous fix for ticket [
d85fffd6ffe856092ed8da ] in check-in
[
0a514e62ad1ebe5c12da8dae ] did not completely address the
probably in that it only worked for cases where the OP_SCopy that loaded
the register was the last instruction in the sequence for the expression, which
is not necessarily the case for expressions like CASE...END. This revision
prevents the registered that will be recomputed from being cached in the first
place.
FossilOrigin-Name:
9fd0faf517993587d2f54212638545fc85fbbc84a031bcfae8c1e5894825d83b
dan [Thu, 26 Apr 2018 17:43:35 +0000 (17:43 +0000)]
When processing an "ORDER BY ... LIMIT" that does not use an index, check
whether or not a record may appear in the final result set before adding it to
the temp b-tree used for sorting.
FossilOrigin-Name:
0fcfc36ceb820fc70136b799a0405fe92e50646e697be2872bbe9a53a05ed5a9
dan [Thu, 26 Apr 2018 16:13:47 +0000 (16:13 +0000)]
When processing an "ORDER BY ... LIMIT" that does not use an index, check
whether or not a record may appear in the final result set before adding it to
the sorter.
FossilOrigin-Name:
71bf91c218334381b1b4bdba6a093e623b62e17f3e8550e154a11f0cb0b404f3
drh [Thu, 26 Apr 2018 15:50:10 +0000 (15:50 +0000)]
Ensure that new.* values of an UPDATE do not get clobbered after the
BEFORE triggers run when unmodified columns of the row being updated are
reloaded. Fix for ticket [
d85fffd6ffe856092ed8da ]
FossilOrigin-Name:
0a514e62ad1ebe5c12da8daed429ae2f9d9910471d3c5cef3b6870bdadfefca1
drh [Thu, 26 Apr 2018 15:04:18 +0000 (15:04 +0000)]
Clarification of the behavior of a BEFORE UPDATE trigger when the trigger
changes the values of some of the columns used to compute new columns in
the UPDATE.
FossilOrigin-Name:
7bb23c2a3d37f0d5e5515b917860818906819d54a0066e1ba8e9792a82f7d279
drh [Thu, 26 Apr 2018 12:27:03 +0000 (12:27 +0000)]
Improved VDBE comment on the OP_Param opcode. No substantial changes.
FossilOrigin-Name:
368c14da868a843767344f6cc17c499fddd83244c0510337ed9a918e64ee2413
dan [Thu, 26 Apr 2018 08:56:40 +0000 (08:56 +0000)]
Update the "fuzz_malloc.test" script to print SQL statements in which OOM
handling problems are found to stdout.
FossilOrigin-Name:
a956363cf6881be590120c7718976b54b12c4bd0d9228d8142b45e0fe1826f7e
drh [Wed, 25 Apr 2018 19:02:48 +0000 (19:02 +0000)]
Add new interfaces for accessing the list of SQL keywords:
sqlite3_keyword_count(), sqlite3_keyword_name(), sqlite3_keyword_check().
FossilOrigin-Name:
7dd34e3776fed90a49344d54a1b68bb59f7957b5a8a1a367087b7cafb63111c1
drh [Wed, 25 Apr 2018 17:10:30 +0000 (17:10 +0000)]
Add the new DO and NOTHING keywords to the keyword lists maintained
by various extensions and auxiliary programs.
FossilOrigin-Name:
77a98a0781cd8450e2100111e70526db6a51d7e58e3c505ea87f685388099e82
drh [Wed, 25 Apr 2018 13:27:07 +0000 (13:27 +0000)]
Add the new SQLITE_SHELL_INIT_PROC compile-time entry point to the CLI. This
is needed to work around the tighter sqlite3_config() constraints now in the
CLI.
FossilOrigin-Name:
3bcdbccf530e2a5aab7b91f4b9e5535cced91f242c49ff69b05a75d643b8b4a3
drh [Wed, 25 Apr 2018 12:01:45 +0000 (12:01 +0000)]
Avoid many unnecessary calls to sqlite3ReadSchema() and sqlite3Init() when
the schema is known to be valid already.
FossilOrigin-Name:
58cf812fd81329e82b3fdd61b7ad2040c9b90d2d80f592b9231e0e1902c8d577
drh [Wed, 25 Apr 2018 10:30:46 +0000 (10:30 +0000)]
Add an assert() to ensure that schema mutexes are held prior to accessing
the DB_SchemaLoaded flag inside of sqlite3Init().
FossilOrigin-Name:
d8b46290bb75c695dac523cf9a50d1b43e773802e3b95fd722feca16162ab7c5
dan [Tue, 24 Apr 2018 18:59:18 +0000 (18:59 +0000)]
Remove a recently added NEVER() macro from a branch that can be taken in
obscure circumstances.
FossilOrigin-Name:
2aa210030ae414782adab9291cc43a149a780f39bd3d306dc2892a8c20422a51
dan [Tue, 24 Apr 2018 18:53:24 +0000 (18:53 +0000)]
Fix a problem with processing "LEFT JOIN tbl ON tbl.a = ? AND (tbl.b=? OR
tbl.c=?)" in cases where there are indexes on both tbl(a, b) and tbl(a, c).
FossilOrigin-Name:
ce35e39c5cc2b00dd6b4a9ffaa9d5eb7d9b862759e87d5f053729de7643eee9c
drh [Tue, 24 Apr 2018 17:34:03 +0000 (17:34 +0000)]
Do not attempt to use terms from the WHERE clause to drive indexes on the
right table of a LEFT JOIN. Fix for ticket [
4ba5abf65c5b0f9a96a7a40cd18b ]
FossilOrigin-Name:
aeb694e3f787f1f8b55650c17f90c197eee3f7f9b890a88f458c33e43009a082
drh [Tue, 24 Apr 2018 16:51:38 +0000 (16:51 +0000)]
Update the expert extension test cases to account for the fact that
EXPLAIN QUERY PLAN now shows the start of each trigger in its output.
FossilOrigin-Name:
8acb42f48929d908fe67a8536e240ca252a9ab780dce79eaa85b8fba35d52250
drh [Tue, 24 Apr 2018 16:41:37 +0000 (16:41 +0000)]
All the OR optimization to proceed even if the OR is also converted into
an IN operator.
FossilOrigin-Name:
e252c6540db266b93beeb47a8f7dbf3b275f8c782cd2d36ba4c00648c382f63f
drh [Tue, 24 Apr 2018 14:18:49 +0000 (14:18 +0000)]
Add a hyperlink to the ticket on the code comment for the fix to
ticket [
7fa8049685b50b5aeb0c2 ].
FossilOrigin-Name:
45247c7f291bc0cc42600a4aa4ff7cdcd0a703fdfadcb0e12174c5250e70d503
dan [Tue, 24 Apr 2018 14:05:14 +0000 (14:05 +0000)]
Do not attempt to read values from indexes-on-expressions if the index is on
the RHS of a LEFT JOIN. This won't work if the index cursor points at a
null-row. Fix for [
7fa80496 ].
FossilOrigin-Name:
b8ef967ab1bebf2846c06c4f7200d6fa1c60e52e55711ea171c25ef1331f8a24
drh [Tue, 24 Apr 2018 13:07:40 +0000 (13:07 +0000)]
Enhance the CLI to render EXPLAIN QUERY PLAN using an ASCII-art graph.
This works with ".eqp" modes and when the query begins with exactly
"EXPLAIN QUERY PLAN". To see the original output format, add extra space
characters in between words of the initial "EXPLAIN QUERY PLAN".
FossilOrigin-Name:
f53716ee2ab5a6d47a5551529aae526bb39058f4a8e11e6243b32c1ddc25a19e
drh [Tue, 24 Apr 2018 10:57:10 +0000 (10:57 +0000)]
Fix a memory leak following failure to open an external CSV file in the
csv.c extension.
FossilOrigin-Name:
526ee07d19dbc8fd1af3a02a8da12b337020a4be40e045da9a19d0a7c2b6ab54
drh [Tue, 24 Apr 2018 01:10:12 +0000 (01:10 +0000)]
In EXPLAIN QUERY PLAN output, do not show an EXECUTE LIST SUBQUERY line for
IN operators where the RHS is a list and not a subquery, since in that case
there is no SUBQUERY to execute.
FossilOrigin-Name:
8bc0207abdeeb3ffac003703e78826759f07994698f6cdf40c89c3443ba22a47
drh [Tue, 24 Apr 2018 00:08:09 +0000 (00:08 +0000)]
Fix to check-in [
ca34c2dd20ee071e ] - avoid a NULL pointer dereference
following an OOM.
FossilOrigin-Name:
c7e6e848fa91f61bc980a031a17d4cd4784f93a1c9ffee35665efa1a59f2982a
drh [Mon, 23 Apr 2018 20:38:40 +0000 (20:38 +0000)]
Fix a problem in sqlite3ExprCompare() associated with UPSERT.
FossilOrigin-Name:
67d0b2c15299dd20bca7254ecb33e71b5eee6024e2709bfdc36f877bf2a5679f
drh [Mon, 23 Apr 2018 20:04:38 +0000 (20:04 +0000)]
Fix a formatting issue in the TreeView output for bare expression lists.
FossilOrigin-Name:
a6356817815fe986c4d89475194e0537ebd46582d6df1034482bf08521182bdf
drh [Mon, 23 Apr 2018 18:38:48 +0000 (18:38 +0000)]
Add the ".imposter off" variant of the ".imposter" dot-command in the CLI.
FossilOrigin-Name:
d3dad06ff1b163040c54dd215f30d6669cc2bc339001a362605f26f06eddf98c
drh [Mon, 23 Apr 2018 17:43:35 +0000 (17:43 +0000)]
The ".selecttrace 0x2000" command causes just the top-level parse tree to
be displayed, after all transformations, and showing the EQP iSelectId at
each level.
FossilOrigin-Name:
ca34c2dd20ee071e6f8d60f91dbf474515a688ba57949143483da1641246cb25
drh [Mon, 23 Apr 2018 17:18:03 +0000 (17:18 +0000)]
The ".selecttrace 4" command now shows only a single parse tree after
name resolution.
FossilOrigin-Name:
5682146e8a4ebb4edc1e1b53fbf3daf77f8cb9cd9bc2aa32acb34fa5824bd518
drh [Mon, 23 Apr 2018 17:09:58 +0000 (17:09 +0000)]
Do not restore the iSelectId value until after the last SELECTTRACE when
debugging Select processing.
FossilOrigin-Name:
8088d8cac317adb96e357a8f4a196d7c1e0115af9c2335f167b4d7e7154299b0
drh [Mon, 23 Apr 2018 17:02:14 +0000 (17:02 +0000)]
In the ".selecttrace" output, include the EXPLAIN QUERY PLAN iSelectId as
part of each Select identifier.
FossilOrigin-Name:
5c6339f955eaa550c7d112488d7830e67ceacba4fbba12e1c5ce2970980159e0
drh [Mon, 23 Apr 2018 13:28:55 +0000 (13:28 +0000)]
Ensure that there are no bind-parameters or incorrect schema references in
the UPSERT portions of an INSERT within a TRIGGER.
FossilOrigin-Name:
d47a6bdda0ce967a7b70bc6eb56278c8b79525622381ff4adcf04525eafc1461
drh [Mon, 23 Apr 2018 00:25:31 +0000 (00:25 +0000)]
Fix an unreachable branch associated with stack overflow in the
LEMON-generated parser.
FossilOrigin-Name:
e3064ba3b68ca2a1c54561756e8c898866a19ef6e785d315171cd47827a50c85
drh [Sat, 21 Apr 2018 22:40:08 +0000 (22:40 +0000)]
Performance improvements on the main loop of the LEMON-generated parser.
FossilOrigin-Name:
fec1ebadeb9d6b55b19a1c159c543fd7ae67b3307c4caee4d2541bd783630e23
drh [Sat, 21 Apr 2018 20:24:19 +0000 (20:24 +0000)]
Enhance LEMON to track which symbols actually carry semantic content.
Output the list of symbols that do not carry content at the end of the
report, but do not (yet) do anything else with the information.
FossilOrigin-Name:
dcf2bafc159179859b91ffea3a4ebd70b5ca6de9e1d515eaf9afde8cfff26c6c
dan [Sat, 21 Apr 2018 14:11:18 +0000 (14:11 +0000)]
drh [Sat, 21 Apr 2018 13:51:42 +0000 (13:51 +0000)]
Add the %extra_context directive to lemon, as an alternative to %extra_argument.
Use this to improve the performance of the parser.
FossilOrigin-Name:
be47a6f5262a43f477700579512fe7112a0872faedcbbe5c3383d13a08af6440
drh [Sat, 21 Apr 2018 03:06:29 +0000 (03:06 +0000)]
Fix UPSERT so that it plays nicely with AUTOINCREMENT.
FossilOrigin-Name:
359725ab36339b443b7745e84f6d27991038ceb063c653805dde17f3eb5a03c5
drh [Fri, 20 Apr 2018 20:47:49 +0000 (20:47 +0000)]
Add the -dDIRECTORY command-line option to LEMON.
FossilOrigin-Name:
9cd20475ff3b2ca1a58e441194c921780d25bdb9b9c744a6b4541b888194efb8
dan [Fri, 20 Apr 2018 20:37:25 +0000 (20:37 +0000)]
Enhance the "rbu" command line utility a bit.
FossilOrigin-Name:
61eb516f83d1a7fe44f72bebe2a2745ab904a02e06e38fb6d932348c49607976
drh [Fri, 20 Apr 2018 20:09:22 +0000 (20:09 +0000)]
drh [Fri, 20 Apr 2018 19:46:52 +0000 (19:46 +0000)]
Avoid the use of statement journals on DELETEs of a single row without
triggers or foreign keys.
FossilOrigin-Name:
20bf5800808ea02b2aa4bf01a380926784c0e7514a2c73ca303cac1f5c732ae0
drh [Fri, 20 Apr 2018 19:32:35 +0000 (19:32 +0000)]
Avoid opening a statement journal on single-row UPDATEs without triggers or
FK constraints.
FossilOrigin-Name:
2772404b8c570caf3c31d2b0530cf347a24f6f60e220e726c086537b38ebfa85
drh [Fri, 20 Apr 2018 18:01:31 +0000 (18:01 +0000)]
Fix a VDBE comment on upsert. Provide an error message when upsert detects
index corruption.
FossilOrigin-Name:
279c48f6061f766f5437edd6964c0dd1e10399314eb17b6e5ee34df925a776ed
dan [Fri, 20 Apr 2018 17:50:49 +0000 (17:50 +0000)]
Add tests for name resolution in ON CONFLICT clauses.
FossilOrigin-Name:
cf253584ecf7aed04406b4bae78b536818fadfb3fb96c05f2c99954b841db85f
drh [Fri, 20 Apr 2018 17:02:16 +0000 (17:02 +0000)]
Avoid unnecessary cursor seeking when performing an UPSERT.
FossilOrigin-Name:
693a3dcbdd8fb2d516c0f46fdbb478838cde675afc1026740e942705aac3c07f
drh [Fri, 20 Apr 2018 16:49:51 +0000 (16:49 +0000)]
drh [Fri, 20 Apr 2018 16:27:57 +0000 (16:27 +0000)]
Minor simplification of the previous checkin.
FossilOrigin-Name:
d1906689abdb685f78aa97bca4bf301204d12846016d27bc86dcc9ce2b024d24
drh [Fri, 20 Apr 2018 15:56:24 +0000 (15:56 +0000)]
Avoid unnecessary cursor seeks during upsert processing.
FossilOrigin-Name:
7c4b6d5475092a3e205f01a6972366e27a404568e8e7ba327f2feefac2ce2c7c
dan [Fri, 20 Apr 2018 15:34:08 +0000 (15:34 +0000)]
Add test cases for UPSERT. And a fix for a "REPLACE INTO ... ON CONFLICT"
statement where the new row conflicts with both the IPK and the ON CONFLICT
indexes.
FossilOrigin-Name:
d8eb9f8d9b61400c7e12f01ef5c233257b03532221f7c7a8386f7ac2db439626
drh [Fri, 20 Apr 2018 13:18:51 +0000 (13:18 +0000)]
Enhance UPSERT so that the UPDATE uses the same set of cursors as the INSERT.
FossilOrigin-Name:
c37f39d18d41ae5ba6c4561d87cbbf71f3b6896b86cc5cff9cdf046b02dc521a