Fix some identifier name de-quoting issues in the foreign key and trigger logic.
FossilOrigin-Name: 59e92bd9521f1e8315a9a7e7fd3d63b0c75eaf0e
This commit is contained in:
parent
60f4e0918d
commit
b6b676ea7c
16
manifest
16
manifest
@ -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
|
||||||
|
@ -1 +1 @@
|
|||||||
a526f58bc96c0fdead51b6bd9aafea7b48bf398e
|
59e92bd9521f1e8315a9a7e7fd3d63b0c75eaf0e
|
18
src/fkey.c
18
src/fkey.c
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user