2001-09-16 04:13:26 +04:00
|
|
|
# 2001 September 15
|
2001-07-23 18:33:02 +04:00
|
|
|
#
|
2001-09-16 04:13:26 +04:00
|
|
|
# The author disclaims copyright to this source code. In place of
|
|
|
|
# a legal notice, here is a blessing:
|
2001-07-23 18:33:02 +04:00
|
|
|
#
|
2001-09-16 04:13:26 +04:00
|
|
|
# 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.
|
2001-07-23 18:33:02 +04:00
|
|
|
#
|
|
|
|
#***********************************************************************
|
|
|
|
# This file implements regression tests for SQLite library. The
|
|
|
|
# focus of this file is the ability to specify table and column names
|
|
|
|
# as quoted strings.
|
|
|
|
#
|
2007-04-25 15:32:30 +04:00
|
|
|
# $Id: quote.test,v 1.7 2007/04/25 11:32:30 drh Exp $
|
2001-07-23 18:33:02 +04:00
|
|
|
|
|
|
|
set testdir [file dirname $argv0]
|
|
|
|
source $testdir/tester.tcl
|
2019-05-20 20:14:25 +03:00
|
|
|
set testprefix quote
|
2001-07-23 18:33:02 +04:00
|
|
|
|
|
|
|
# Create a table with a strange name and with strange column names.
|
|
|
|
#
|
|
|
|
do_test quote-1.0 {
|
2005-08-13 22:15:42 +04:00
|
|
|
catchsql {CREATE TABLE '@abc' ( '#xyz' int, '!pqr' text );}
|
2001-07-23 18:33:02 +04:00
|
|
|
} {0 {}}
|
|
|
|
|
|
|
|
# Insert, update and query the table.
|
|
|
|
#
|
|
|
|
do_test quote-1.1 {
|
2005-08-13 22:15:42 +04:00
|
|
|
catchsql {INSERT INTO '@abc' VALUES(5,'hello')}
|
2001-07-23 18:33:02 +04:00
|
|
|
} {0 {}}
|
2005-08-13 22:15:42 +04:00
|
|
|
do_test quote-1.2.1 {
|
|
|
|
catchsql {SELECT * FROM '@abc'}
|
|
|
|
} {0 {5 hello}}
|
|
|
|
do_test quote-1.2.2 {
|
|
|
|
catchsql {SELECT * FROM [@abc]} ;# SqlServer compatibility
|
|
|
|
} {0 {5 hello}}
|
|
|
|
do_test quote-1.2.3 {
|
|
|
|
catchsql {SELECT * FROM `@abc`} ;# MySQL compatibility
|
2001-07-23 18:33:02 +04:00
|
|
|
} {0 {5 hello}}
|
|
|
|
do_test quote-1.3 {
|
2005-08-13 22:15:42 +04:00
|
|
|
catchsql {
|
|
|
|
SELECT '@abc'.'!pqr', '@abc'.'#xyz'+5 FROM '@abc'
|
|
|
|
}
|
2001-07-23 18:33:02 +04:00
|
|
|
} {0 {hello 10}}
|
2002-05-21 17:43:04 +04:00
|
|
|
do_test quote-1.3.1 {
|
|
|
|
catchsql {
|
|
|
|
SELECT '!pqr', '#xyz'+5 FROM '@abc'
|
|
|
|
}
|
2005-11-01 18:48:24 +03:00
|
|
|
} {0 {!pqr 5}}
|
2002-05-21 17:43:04 +04:00
|
|
|
do_test quote-1.3.2 {
|
|
|
|
catchsql {
|
|
|
|
SELECT "!pqr", "#xyz"+5 FROM '@abc'
|
|
|
|
}
|
|
|
|
} {0 {hello 10}}
|
2005-08-13 22:15:42 +04:00
|
|
|
do_test quote-1.3.3 {
|
|
|
|
catchsql {
|
|
|
|
SELECT [!pqr], `#xyz`+5 FROM '@abc'
|
|
|
|
}
|
|
|
|
} {0 {hello 10}}
|
2007-04-25 15:32:30 +04:00
|
|
|
do_test quote-1.3.4 {
|
2002-05-21 17:43:04 +04:00
|
|
|
set r [catch {
|
|
|
|
execsql {SELECT '@abc'.'!pqr', '@abc'.'#xyz'+5 FROM '@abc'}
|
|
|
|
} msg ]
|
|
|
|
lappend r $msg
|
|
|
|
} {0 {hello 10}}
|
2001-07-23 18:33:02 +04:00
|
|
|
do_test quote-1.4 {
|
|
|
|
set r [catch {
|
|
|
|
execsql {UPDATE '@abc' SET '#xyz'=11}
|
|
|
|
} msg ]
|
|
|
|
lappend r $msg
|
|
|
|
} {0 {}}
|
|
|
|
do_test quote-1.5 {
|
|
|
|
set r [catch {
|
|
|
|
execsql {SELECT '@abc'.'!pqr', '@abc'.'#xyz'+5 FROM '@abc'}
|
|
|
|
} msg ]
|
|
|
|
lappend r $msg
|
|
|
|
} {0 {hello 16}}
|
|
|
|
|
|
|
|
# Drop the table with the strange name.
|
|
|
|
#
|
|
|
|
do_test quote-1.6 {
|
|
|
|
set r [catch {
|
|
|
|
execsql {DROP TABLE '@abc'}
|
|
|
|
} msg ]
|
|
|
|
lappend r $msg
|
|
|
|
} {0 {}}
|
2019-05-20 20:14:25 +03:00
|
|
|
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
# Check that it is not possible to use double-quotes for a string
|
|
|
|
# constant in a CHECK constraint or CREATE INDEX statement. However,
|
|
|
|
# SQLite can load such a schema from disk.
|
|
|
|
#
|
|
|
|
reset_db
|
2019-07-02 15:23:09 +03:00
|
|
|
sqlite3_db_config db SQLITE_DBCONFIG_DQS_DDL 0
|
|
|
|
sqlite3_db_config db SQLITE_DBCONFIG_DQS_DML 1
|
2019-05-20 20:14:25 +03:00
|
|
|
do_execsql_test 2.0 {
|
|
|
|
CREATE TABLE t1(x, y, z);
|
|
|
|
}
|
|
|
|
foreach {tn sql errname} {
|
|
|
|
1 { CREATE TABLE xyz(a, b, c CHECK (c!="null") ) } null
|
|
|
|
2 { CREATE INDEX i2 ON t1(x, y, z||"abc") } abc
|
|
|
|
3 { CREATE INDEX i3 ON t1("w") } w
|
|
|
|
4 { CREATE INDEX i4 ON t1(x) WHERE z="w" } w
|
|
|
|
} {
|
|
|
|
do_catchsql_test 2.1.$tn $sql [list 1 "no such column: $errname"]
|
|
|
|
}
|
|
|
|
|
|
|
|
do_execsql_test 2.2 {
|
|
|
|
PRAGMA writable_schema = 1;
|
|
|
|
CREATE TABLE xyz(a, b, c CHECK (c!="null") );
|
|
|
|
CREATE INDEX i2 ON t1(x, y, z||"abc");
|
2021-03-14 22:55:40 +03:00
|
|
|
CREATE INDEX i3 ON t1("w"||"");
|
2019-05-20 20:14:25 +03:00
|
|
|
CREATE INDEX i4 ON t1(x) WHERE z="w";
|
|
|
|
}
|
|
|
|
|
|
|
|
db close
|
|
|
|
sqlite3 db test.db
|
|
|
|
|
|
|
|
do_execsql_test 2.3.1 {
|
|
|
|
INSERT INTO xyz VALUES(1, 2, 3);
|
|
|
|
}
|
|
|
|
do_catchsql_test 2.3.2 {
|
|
|
|
INSERT INTO xyz VALUES(1, 2, 'null');
|
2020-08-27 21:36:30 +03:00
|
|
|
} {1 {CHECK constraint failed: c!="null"}}
|
2019-05-20 20:14:25 +03:00
|
|
|
|
|
|
|
do_execsql_test 2.4 {
|
|
|
|
INSERT INTO t1 VALUES(1, 2, 3);
|
|
|
|
INSERT INTO t1 VALUES(4, 5, 'w');
|
|
|
|
SELECT * FROM t1 WHERE z='w';
|
|
|
|
} {4 5 w}
|
|
|
|
do_execsql_test 2.5 {
|
|
|
|
SELECT sql FROM sqlite_master;
|
|
|
|
} {
|
|
|
|
{CREATE TABLE t1(x, y, z)}
|
|
|
|
{CREATE TABLE xyz(a, b, c CHECK (c!="null") )}
|
|
|
|
{CREATE INDEX i2 ON t1(x, y, z||"abc")}
|
2021-03-14 22:55:40 +03:00
|
|
|
{CREATE INDEX i3 ON t1("w"||"")}
|
2019-05-20 20:14:25 +03:00
|
|
|
{CREATE INDEX i4 ON t1(x) WHERE z="w"}
|
|
|
|
}
|
|
|
|
|
2021-03-14 22:55:40 +03:00
|
|
|
# 2021-03-13
|
|
|
|
# ticket 1c24a659e6d7f3a1
|
2021-10-01 23:39:50 +03:00
|
|
|
ifcapable altertable {
|
|
|
|
reset_db
|
|
|
|
do_catchsql_test 3.0 {
|
|
|
|
CREATE TABLE t1(a,b);
|
|
|
|
CREATE INDEX x1 on t1("b");
|
|
|
|
ALTER TABLE t1 DROP COLUMN b;
|
|
|
|
} {1 {error in index x1 after drop column: no such column: b}}
|
|
|
|
do_catchsql_test 3.1 {
|
|
|
|
DROP TABLE t1;
|
|
|
|
CREATE TABLE t1(a,"b");
|
|
|
|
CREATE INDEX x1 on t1("b");
|
|
|
|
ALTER TABLE t1 DROP COLUMN b;
|
|
|
|
} {1 {error in index x1 after drop column: no such column: b}}
|
|
|
|
do_catchsql_test 3.2 {
|
|
|
|
DROP TABLE t1;
|
|
|
|
CREATE TABLE t1(a,'b');
|
|
|
|
CREATE INDEX x1 on t1("b");
|
|
|
|
ALTER TABLE t1 DROP COLUMN b;
|
|
|
|
} {1 {error in index x1 after drop column: no such column: b}}
|
|
|
|
do_catchsql_test 3.3 {
|
|
|
|
DROP TABLE t1;
|
|
|
|
CREATE TABLE t1(a,"b");
|
|
|
|
CREATE INDEX x1 on t1('b');
|
|
|
|
ALTER TABLE t1 DROP COLUMN b;
|
|
|
|
} {1 {error in index x1 after drop column: no such column: b}}
|
|
|
|
do_catchsql_test 3.4 {
|
|
|
|
DROP TABLE t1;
|
|
|
|
CREATE TABLE t1(a, b, c);
|
|
|
|
CREATE INDEX x1 ON t1("a"||"b");
|
|
|
|
INSERT INTO t1 VALUES(1,2,3),(1,4,5);
|
|
|
|
ALTER TABLE t1 DROP COLUMN b;
|
|
|
|
} {1 {error in index x1 after drop column: no such column: b}}
|
2022-01-16 22:11:13 +03:00
|
|
|
sqlite3_db_config db SQLITE_DBCONFIG_DQS_DDL 1
|
2021-10-01 23:39:50 +03:00
|
|
|
do_catchsql_test 3.5 {
|
|
|
|
DROP TABLE t1;
|
|
|
|
CREATE TABLE t1(a, b, c);
|
|
|
|
CREATE INDEX x1 ON t1("a"||"x");
|
|
|
|
INSERT INTO t1 VALUES(1,2,3),(1,4,5);
|
|
|
|
ALTER TABLE t1 DROP COLUMN b;
|
|
|
|
} {0 {}}
|
|
|
|
}
|
2001-07-23 18:33:02 +04:00
|
|
|
|
|
|
|
finish_test
|