Fix some identifier name de-quoting issues in the foreign key and trigger logic.

FossilOrigin-Name: 59e92bd9521f1e8315a9a7e7fd3d63b0c75eaf0e
This commit is contained in:
drh 2015-04-21 03:13:47 +00:00
parent 60f4e0918d
commit b6b676ea7c
5 changed files with 51 additions and 19 deletions

View File

@ -1,5 +1,5 @@
C Test\scase\sfor\sthe\sprevious\scheck-in. C Fix\ssome\sidentifier\sname\sde-quoting\sissues\sin\sthe\sforeign\skey\sand\strigger\slogic.
D 2015-04-21T02:17:30.839 D 2015-04-21T03:13:47.283
F Makefile.arm-wince-mingw32ce-gcc d6df77f1f48d690bd73162294bbba7f59507c72f F Makefile.arm-wince-mingw32ce-gcc d6df77f1f48d690bd73162294bbba7f59507c72f
F Makefile.in faaf75b89840659d74501bea269c7e33414761c1 F Makefile.in faaf75b89840659d74501bea269c7e33414761c1
F Makefile.linux-gcc 91d710bdc4998cb015f39edf3cb314ec4f4d7e23 F Makefile.linux-gcc 91d710bdc4998cb015f39edf3cb314ec4f4d7e23
@ -184,7 +184,7 @@ F src/date.c e4d50b3283696836ec1036b695ead9a19e37a5ac
F src/delete.c 37964e6c1d73ff49cbea9ff690c9605fb15f600e F src/delete.c 37964e6c1d73ff49cbea9ff690c9605fb15f600e
F src/expr.c 5555f768c05d7d4a7840c6c2e72ad7aecbe0fe54 F src/expr.c 5555f768c05d7d4a7840c6c2e72ad7aecbe0fe54
F src/fault.c 160a0c015b6c2629d3899ed2daf63d75754a32bb F src/fault.c 160a0c015b6c2629d3899ed2daf63d75754a32bb
F src/fkey.c 3343d551a8d810782257244fb33f2ce191493c39 F src/fkey.c 6040cf888922273171f30b8d6e0726aeae4ec82d
F src/func.c 1414c24c873c48796ad45942257a179a423ba42f F src/func.c 1414c24c873c48796ad45942257a179a423ba42f
F src/global.c 4f77cadbc5427d00139ba43d0f3979804cbb700e F src/global.c 4f77cadbc5427d00139ba43d0f3979804cbb700e
F src/hash.c 4263fbc955f26c2e8cdc0cf214bc42435aa4e4f5 F src/hash.c 4263fbc955f26c2e8cdc0cf214bc42435aa4e4f5
@ -288,7 +288,7 @@ F src/test_vfstrace.c bab9594adc976cbe696ff3970728830b4c5ed698
F src/test_wsd.c 41cadfd9d97fe8e3e4e44f61a4a8ccd6f7ca8fe9 F src/test_wsd.c 41cadfd9d97fe8e3e4e44f61a4a8ccd6f7ca8fe9
F src/threads.c 6bbcc9fe50c917864d48287b4792d46d6e873481 F src/threads.c 6bbcc9fe50c917864d48287b4792d46d6e873481
F src/tokenize.c b7fb584c2be5ec39b6fdf04b185e7c6f33f8dc15 F src/tokenize.c b7fb584c2be5ec39b6fdf04b185e7c6f33f8dc15
F src/trigger.c bc647c712454c9b209fac082bb82870b5fd6fa54 F src/trigger.c 45db6f59c6a945e1fe1acbdc77263c5c414d4c65
F src/update.c 3c4ecc282accf12d39edb8d524cf089645e55a13 F src/update.c 3c4ecc282accf12d39edb8d524cf089645e55a13
F src/utf.c fc6b889ba0779b7722634cdeaa25f1930d93820c F src/utf.c fc6b889ba0779b7722634cdeaa25f1930d93820c
F src/util.c a6431c92803b975b7322724a7b433e538d243539 F src/util.c a6431c92803b975b7322724a7b433e538d243539
@ -504,7 +504,7 @@ F test/extension01.test 00d13cec817f331a687a243e0e5a2d87b0e358c9
F test/fallocate.test 3e979af17dfa7e5e9dda5eba1a696c04fa9d47f7 F test/fallocate.test 3e979af17dfa7e5e9dda5eba1a696c04fa9d47f7
F test/filectrl.test 14fa712e42c4cb791e09dfd58a6a03efb47ef13a F test/filectrl.test 14fa712e42c4cb791e09dfd58a6a03efb47ef13a
F test/filefmt.test cb34663f126cbc2d358af552dcaf5c72769b0146 F test/filefmt.test cb34663f126cbc2d358af552dcaf5c72769b0146
F test/fkey1.test e1d1fa84cde579185ea01358436839703e415a5b F test/fkey1.test de5b287f6a480b36bd51e8debcf48168e26e4ed2
F test/fkey2.test f3d27ecba480a348c328965d154214719bb158a9 F test/fkey2.test f3d27ecba480a348c328965d154214719bb158a9
F test/fkey3.test 76d475c80b84ee7a5d062e56ccb6ea68882e2b49 F test/fkey3.test 76d475c80b84ee7a5d062e56ccb6ea68882e2b49
F test/fkey4.test 86446017011273aad8f9a99c1a65019e7bd9ca9d F test/fkey4.test 86446017011273aad8f9a99c1a65019e7bd9ca9d
@ -1251,7 +1251,7 @@ F tool/vdbe_profile.tcl 67746953071a9f8f2f668b73fe899074e2c6d8c1
F tool/warnings-clang.sh f6aa929dc20ef1f856af04a730772f59283631d4 F tool/warnings-clang.sh f6aa929dc20ef1f856af04a730772f59283631d4
F tool/warnings.sh 0abfd78ceb09b7f7c27c688c8e3fe93268a13b32 F tool/warnings.sh 0abfd78ceb09b7f7c27c688c8e3fe93268a13b32
F tool/win/sqlite.vsix deb315d026cc8400325c5863eef847784a219a2f F tool/win/sqlite.vsix deb315d026cc8400325c5863eef847784a219a2f
P 588db14ffb4b0e8e76d511b7b1541db3ec78836a P a526f58bc96c0fdead51b6bd9aafea7b48bf398e
R 0379e03a168715422bfe2697c2af7c68 R 6263ca10bc3a41fc51b68112322cb0ff
U drh U drh
Z ee4991a8fe0a3ae557d83e10280b0c68 Z 0f5648b8f58dd956d25b7cd57819a2e5

View File

@ -1 +1 @@
a526f58bc96c0fdead51b6bd9aafea7b48bf398e 59e92bd9521f1e8315a9a7e7fd3d63b0c75eaf0e

View File

@ -1197,10 +1197,10 @@ static Trigger *fkActionTrigger(
** parent table are used for the comparison. */ ** parent table are used for the comparison. */
pEq = sqlite3PExpr(pParse, TK_EQ, pEq = sqlite3PExpr(pParse, TK_EQ,
sqlite3PExpr(pParse, TK_DOT, sqlite3PExpr(pParse, TK_DOT,
sqlite3PExpr(pParse, TK_ID, 0, 0, &tOld), sqlite3ExprAlloc(db, TK_ID, &tOld, 0),
sqlite3PExpr(pParse, TK_ID, 0, 0, &tToCol) sqlite3ExprAlloc(db, TK_ID, &tToCol, 0)
, 0), , 0),
sqlite3PExpr(pParse, TK_ID, 0, 0, &tFromCol) sqlite3ExprAlloc(db, TK_ID, &tFromCol, 0)
, 0); , 0);
pWhere = sqlite3ExprAnd(db, pWhere, pEq); pWhere = sqlite3ExprAnd(db, pWhere, pEq);
@ -1212,12 +1212,12 @@ static Trigger *fkActionTrigger(
if( pChanges ){ if( pChanges ){
pEq = sqlite3PExpr(pParse, TK_IS, pEq = sqlite3PExpr(pParse, TK_IS,
sqlite3PExpr(pParse, TK_DOT, sqlite3PExpr(pParse, TK_DOT,
sqlite3PExpr(pParse, TK_ID, 0, 0, &tOld), sqlite3ExprAlloc(db, TK_ID, &tOld, 0),
sqlite3PExpr(pParse, TK_ID, 0, 0, &tToCol), sqlite3ExprAlloc(db, TK_ID, &tToCol, 0),
0), 0),
sqlite3PExpr(pParse, TK_DOT, sqlite3PExpr(pParse, TK_DOT,
sqlite3PExpr(pParse, TK_ID, 0, 0, &tNew), sqlite3ExprAlloc(db, TK_ID, &tNew, 0),
sqlite3PExpr(pParse, TK_ID, 0, 0, &tToCol), sqlite3ExprAlloc(db, TK_ID, &tToCol, 0),
0), 0),
0); 0);
pWhen = sqlite3ExprAnd(db, pWhen, pEq); pWhen = sqlite3ExprAnd(db, pWhen, pEq);
@ -1227,8 +1227,8 @@ static Trigger *fkActionTrigger(
Expr *pNew; Expr *pNew;
if( action==OE_Cascade ){ if( action==OE_Cascade ){
pNew = sqlite3PExpr(pParse, TK_DOT, pNew = sqlite3PExpr(pParse, TK_DOT,
sqlite3PExpr(pParse, TK_ID, 0, 0, &tNew), sqlite3ExprAlloc(db, TK_ID, &tNew, 0),
sqlite3PExpr(pParse, TK_ID, 0, 0, &tToCol) sqlite3ExprAlloc(db, TK_ID, &tToCol, 0)
, 0); , 0);
}else if( action==OE_SetDflt ){ }else if( action==OE_SetDflt ){
Expr *pDflt = pFKey->pFrom->aCol[iFromCol].pDflt; Expr *pDflt = pFKey->pFrom->aCol[iFromCol].pDflt;

View File

@ -676,9 +676,11 @@ static SrcList *targetSrcList(
int iDb; /* Index of the database to use */ int iDb; /* Index of the database to use */
SrcList *pSrc; /* SrcList to be returned */ SrcList *pSrc; /* SrcList to be returned */
pSrc = sqlite3SrcListAppend(pParse->db, 0, &pStep->target, 0); pSrc = sqlite3SrcListAppend(pParse->db, 0, 0, 0);
if( pSrc ){ if( pSrc ){
assert( pSrc->nSrc>0 ); assert( pSrc->nSrc>0 );
pSrc->a[pSrc->nSrc-1].zName =
sqlite3DbStrNDup(pParse->db, pStep->target.z, pStep->target.n);
iDb = sqlite3SchemaToIndex(pParse->db, pStep->pTrig->pSchema); iDb = sqlite3SchemaToIndex(pParse->db, pStep->pTrig->pSchema);
if( iDb==0 || iDb>=2 ){ if( iDb==0 || iDb>=2 ){
sqlite3 *db = pParse->db; sqlite3 *db = pParse->db;

View File

@ -121,4 +121,34 @@ do_test fkey1-3.5 {
sqlite3_db_status db DBSTATUS_DEFERRED_FKS 0 sqlite3_db_status db DBSTATUS_DEFERRED_FKS 0
} {0 0 0} } {0 0 0}
# Stress the dequoting logic. The first test is not so bad.
do_execsql_test fkey1-4.0 {
PRAGMA foreign_keys=ON;
CREATE TABLE "xx1"("xx2" TEXT PRIMARY KEY, "xx3" TEXT);
INSERT INTO "xx1"("xx2","xx3") VALUES('abc','def');
CREATE TABLE "xx4"("xx5" TEXT REFERENCES "xx1" ON DELETE CASCADE);
INSERT INTO "xx4"("xx5") VALUES('abc');
INSERT INTO "xx1"("xx2","xx3") VALUES('uvw','xyz');
SELECT 1, "xx5" FROM "xx4";
DELETE FROM "xx1";
SELECT 2, "xx5" FROM "xx4";
} {1 abc}
# This case is identical to the previous except the "xx" in each name
# is changed to a single escaped double-quote character.
do_execsql_test fkey1-4.1 {
PRAGMA foreign_keys=ON;
CREATE TABLE """1"("""2" TEXT PRIMARY KEY, """3" TEXT);
INSERT INTO """1"("""2","""3") VALUES('abc','def');
CREATE TABLE """4"("""5" TEXT REFERENCES """1" ON DELETE CASCADE);
INSERT INTO """4"("""5") VALUES('abc');
INSERT INTO """1"("""2","""3") VALUES('uvw','xyz');
SELECT 1, """5" FROM """4";
DELETE FROM """1";
SELECT 2, """5" FROM """4";
} {1 abc}
do_execsql_test fkey1-4.2 {
PRAGMA table_info="""1";
} {0 {"2} TEXT 0 {} 1 1 {"3} TEXT 0 {} 0}
finish_test finish_test