]> git.ipfire.org Git - thirdparty/sqlite.git/commitdiff
Add test for LEFT JOIN in UPDATE...FROM statement.
authordan <dan@noemail.net>
Mon, 13 Jul 2020 20:43:13 +0000 (20:43 +0000)
committerdan <dan@noemail.net>
Mon, 13 Jul 2020 20:43:13 +0000 (20:43 +0000)
FossilOrigin-Name: 4f3dff045ab90e80479960fed64cf36f23dd0e13144edbde15043913ad3faac5

manifest
manifest.uuid
test/upfrom1.tcl
test/upfrom1.test

index d70a238ea57782e356add94c86dada9ed82c1294..57ea2124579e56c79dcc0b5665614035d2688cb5 100644 (file)
--- a/manifest
+++ b/manifest
@@ -1,11 +1,13 @@
 B 5ee3c27e20d12a126fb773b428bb864102b949a5b26a8d5c523753dcedf4be10
-C Add\stest\scases\sand\sfixes\sfor\sUPDATE...FROM\sstatements\sthat\smodify\sprimary\skey\scolumns.
-D 2020-07-13T20:10:29.676
+C Add\stest\sfor\sLEFT\sJOIN\sin\sUPDATE...FROM\sstatement.
+D 2020-07-13T20:43:13.733
 F src/resolve.c 04f4710d3ab0070073b60b5b963158dadfbd049db55d10742d9fbd3f28a3f4b8
 F src/update.c ab137d08171e2bb18a4c6af815bbd6dbe8bfb483ddd7a2b97dfbfb4d95906ee0
 F test/fts4upfrom.test 8df5acb6e10ad73f393d1add082b042ab1db72567888847d098152121e507b34
+F test/upfrom1.tcl df984cb88010af1555812af55e9db44c4df50677395b45d1f30b69b1b6c07b73
+F test/upfrom1.test 2ba1ed45b4a2161fc79f234b9ce4300b0d3deba545e3f23b938fb3ebdbf8758d
 F test/upfrom3.test 8f107ed4dc863e75694867fa38c4f3fccd77a35939f65137ead8a55b6ee45152
-P 5ee3c27e20d12a126fb773b428bb864102b949a5b26a8d5c523753dcedf4be10
-R 2d0f465cbbb27a9a22406ae4b2f12478
+P 47c87af3e52bce10fbcc2cbe832d659b0c204bfb3368d9314fa1b01120129254
+R 65a8d9c8ed218ad0d5909deb2fd7a990
 U dan
-Z cd52a3446e6f9caf8f163180b9da21b7
+Z 74476aad6c58b82c53e5aec1a3d47ff5
index c939672a21b968f1f5a2de03138ff91989c1d829..9e5ac42c4718048b8e6d80113463365fd9c3d7f2 100644 (file)
@@ -1 +1 @@
-47c87af3e52bce10fbcc2cbe832d659b0c204bfb3368d9314fa1b01120129254
\ No newline at end of file
+4f3dff045ab90e80479960fed64cf36f23dd0e13144edbde15043913ad3faac5
\ No newline at end of file
index 5edbb94fe5b207cfb46dc3195114761b8327fd5e..e8d3bf21b97de42d031f025f485145769637091d 100644 (file)
@@ -76,5 +76,33 @@ execsql_test 1.%TN%.6 {
 }
 }]}
 
+execsql_test 2.1 {
+  DROP TABLE IF EXISTS t5;
+  DROP TABLE IF EXISTS m1;
+  DROP TABLE IF EXISTS m2;
+  CREATE TABLE t5(a INTEGER PRIMARY KEY, b TEXT, c TEXT);
+  CREATE TABLE m1(x INTEGER PRIMARY KEY, y TEXT);
+  CREATE TABLE m2(u INTEGER PRIMARY KEY, v TEXT);
+
+  INSERT INTO t5 VALUES(1, 'one', 'ONE');
+  INSERT INTO t5 VALUES(2, 'two', 'TWO');
+  INSERT INTO t5 VALUES(3, 'three', 'THREE');
+  INSERT INTO t5 VALUES(4, 'four', 'FOUR');
+
+  INSERT INTO m1 VALUES(1, 'i');
+  INSERT INTO m1 VALUES(2, 'ii');
+  INSERT INTO m1 VALUES(3, 'iii');
+
+  INSERT INTO m2 VALUES(1, 'I');
+  INSERT INTO m2 VALUES(3, 'II');
+  INSERT INTO m2 VALUES(4, 'III');
+}
+
+execsql_test 2.2 {
+  UPDATE t5 SET b=y, c=v FROM m1 LEFT JOIN m2 ON (x=u) WHERE x=a;
+  SELECT * FROM t5 ORDER BY a;
+}
+
+
 finish_test
 
index da873f16b4ceac166ff4caad3b4a859e4c3bb7e1..6dbb5a2b27297a1b76687cae2104c2fcd6bbff1c 100644 (file)
@@ -127,4 +127,31 @@ do_execsql_test 1.2.6 {
   SELECT * FROM t3 ORDER BY a;
 } {1 1 five   2 2 five   3 3 five}
 
+do_execsql_test 2.1 {
+  DROP TABLE IF EXISTS t5;
+  DROP TABLE IF EXISTS m1;
+  DROP TABLE IF EXISTS m2;
+  CREATE TABLE t5(a INTEGER PRIMARY KEY, b TEXT, c TEXT);
+  CREATE TABLE m1(x INTEGER PRIMARY KEY, y TEXT);
+  CREATE TABLE m2(u INTEGER PRIMARY KEY, v TEXT);
+
+  INSERT INTO t5 VALUES(1, 'one', 'ONE');
+  INSERT INTO t5 VALUES(2, 'two', 'TWO');
+  INSERT INTO t5 VALUES(3, 'three', 'THREE');
+  INSERT INTO t5 VALUES(4, 'four', 'FOUR');
+
+  INSERT INTO m1 VALUES(1, 'i');
+  INSERT INTO m1 VALUES(2, 'ii');
+  INSERT INTO m1 VALUES(3, 'iii');
+
+  INSERT INTO m2 VALUES(1, 'I');
+  INSERT INTO m2 VALUES(3, 'II');
+  INSERT INTO m2 VALUES(4, 'III');
+} {}
+
+do_execsql_test 2.2 {
+  UPDATE t5 SET b=y, c=v FROM m1 LEFT JOIN m2 ON (x=u) WHERE x=a;
+  SELECT * FROM t5 ORDER BY a;
+} {1 i I   2 ii {}   3 iii II   4 four FOUR}
+
 finish_test