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
|
#!/usr/bin/env tarantool
test = require("sqltester")
test:plan(4)
--!./tcltestrunner.lua
-- 2008 October 06
--
-- 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.
--
-------------------------------------------------------------------------
--
--
-- $Id: tkt3424.test,v 1.2 2009/06/05 17:09:12 drh Exp $
-- ["set","testdir",[["file","dirname",["argv0"]]]]
-- ["source",[["testdir"],"\/tester.tcl"]]
test:do_execsql_test(
"tkt3424-1.1",
[[
CREATE TABLE names(id INTEGER primary key, data TEXT, code TEXT);
INSERT INTO names VALUES(1,'E1','AAA');
INSERT INTO names VALUES(2,NULL,'BBB');
CREATE TABLE orig(id INT primary key, code TEXT, data TEXT);
INSERT INTO orig VALUES(1, 'AAA','E1');
INSERT INTO orig VALUES(2, 'AAA','E2');
INSERT INTO orig VALUES(3, 'AAA','E3');
INSERT INTO orig VALUES(4, 'AAA','E4');
INSERT INTO orig VALUES(5, 'AAA','E5');
]], {
-- <tkt3424-1.1>
-- </tkt3424-1.1>
})
test:do_execsql_test(
"tkt3424-1.2",
[[
SELECT names.id,names.data,names.code,orig.code,orig.data FROM
names LEFT OUTER JOIN orig
ON names.data = orig.data AND names.code = orig.code;
]], {
-- <tkt3424-1.2>
1, "E1", "AAA", "AAA", "E1", 2, "", "BBB", "", ""
-- </tkt3424-1.2>
})
test:do_execsql_test(
"tkt3424-1.3",
[[
CREATE INDEX udx_orig_code_data ON orig(code, data)
]], {
-- <tkt3424-1.3>
-- </tkt3424-1.3>
})
test:do_execsql_test(
"tkt3424-1.4",
[[
SELECT names.id,names.data,names.code,orig.code,orig.data FROM
names LEFT OUTER JOIN orig
ON names.data = orig.data AND names.code = orig.code;
]], {
-- <tkt3424-1.4>
1, "E1", "AAA", "AAA", "E1", 2, "", "BBB", "", ""
-- </tkt3424-1.4>
})
test:finish_test()
|