/ Hex Artifact Content
Login

Artifact 48921db21c10b7857efe8a9f4dd9dbe7fe931df3eaea0913629e8512924fc8ef:


0000: 2f 2a 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75 74  /*.**.** The aut
0010: 68 6f 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f  hor disclaims co
0020: 70 79 72 69 67 68 74 20 74 6f 20 74 68 69 73 20  pyright to this 
0030: 73 6f 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e  source code.  In
0040: 20 70 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20 6c   place of.** a l
0050: 65 67 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72  egal notice, her
0060: 65 20 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a  e is a blessing:
0070: 0a 2a 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79 6f  .**.**    May yo
0080: 75 20 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f  u do good and no
0090: 74 20 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d 61  t evil..**    Ma
00a0: 79 20 79 6f 75 20 66 69 6e 64 20 66 6f 72 67 69  y you find forgi
00b0: 76 65 6e 65 73 73 20 66 6f 72 20 79 6f 75 72 73  veness for yours
00c0: 65 6c 66 20 61 6e 64 20 66 6f 72 67 69 76 65 20  elf and forgive 
00d0: 6f 74 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d 61  others..**    Ma
00e0: 79 20 79 6f 75 20 73 68 61 72 65 20 66 72 65 65  y you share free
00f0: 6c 79 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e 67  ly, never taking
0100: 20 6d 6f 72 65 20 74 68 61 6e 20 79 6f 75 20 67   more than you g
0110: 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a  ive..**.********
0120: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 0a 2a 2a 20 54 68 69 73 20 66 69 6c 65 20 63  *.** This file c
0170: 6f 6e 74 61 69 6e 73 20 63 6f 64 65 20 75 73 65  ontains code use
0180: 64 20 62 79 20 74 68 65 20 63 6f 6d 70 69 6c 65  d by the compile
0190: 72 20 74 6f 20 61 64 64 20 66 6f 72 65 69 67 6e  r to add foreign
01a0: 20 6b 65 79 0a 2a 2a 20 73 75 70 70 6f 72 74 20   key.** support 
01b0: 74 6f 20 63 6f 6d 70 69 6c 65 64 20 53 51 4c 20  to compiled SQL 
01c0: 73 74 61 74 65 6d 65 6e 74 73 2e 0a 2a 2f 0a 23  statements..*/.#
01d0: 69 6e 63 6c 75 64 65 20 22 73 71 6c 69 74 65 49  include "sqliteI
01e0: 6e 74 2e 68 22 0a 23 69 6e 63 6c 75 64 65 20 22  nt.h".#include "
01f0: 6c 6f 6f 6b 61 73 69 64 65 2e 68 22 0a 0a 23 69  lookaside.h"..#i
0200: 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49  fndef SQLITE_OMI
0210: 54 5f 46 4f 52 45 49 47 4e 5f 4b 45 59 0a 23 69  T_FOREIGN_KEY.#i
0220: 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49  fndef SQLITE_OMI
0230: 54 5f 54 52 49 47 47 45 52 0a 0a 2f 2a 0a 2a 2a  T_TRIGGER../*.**
0240: 20 44 65 66 65 72 72 65 64 20 61 6e 64 20 49 6d   Deferred and Im
0250: 6d 65 64 69 61 74 65 20 46 4b 73 0a 2a 2a 20 2d  mediate FKs.** -
0260: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0270: 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 2a 2a 0a 2a 2a 20  ---------.**.** 
0280: 46 6f 72 65 69 67 6e 20 6b 65 79 73 20 69 6e 20  Foreign keys in 
0290: 53 51 4c 69 74 65 20 63 6f 6d 65 20 69 6e 20 74  SQLite come in t
02a0: 77 6f 20 66 6c 61 76 6f 75 72 73 3a 20 64 65 66  wo flavours: def
02b0: 65 72 72 65 64 20 61 6e 64 20 69 6d 6d 65 64 69  erred and immedi
02c0: 61 74 65 2e 0a 2a 2a 20 49 66 20 61 6e 20 69 6d  ate..** If an im
02d0: 6d 65 64 69 61 74 65 20 66 6f 72 65 69 67 6e 20  mediate foreign 
02e0: 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e 74 20 69  key constraint i
02f0: 73 20 76 69 6f 6c 61 74 65 64 2c 0a 2a 2a 20 53  s violated,.** S
0300: 51 4c 49 54 45 5f 43 4f 4e 53 54 52 41 49 4e 54  QLITE_CONSTRAINT
0310: 5f 46 4f 52 45 49 47 4e 4b 45 59 20 69 73 20 72  _FOREIGNKEY is r
0320: 65 74 75 72 6e 65 64 20 61 6e 64 20 74 68 65 20  eturned and the 
0330: 63 75 72 72 65 6e 74 0a 2a 2a 20 73 74 61 74 65  current.** state
0340: 6d 65 6e 74 20 74 72 61 6e 73 61 63 74 69 6f 6e  ment transaction
0350: 20 72 6f 6c 6c 65 64 20 62 61 63 6b 2e 20 49 66   rolled back. If
0360: 20 61 20 0a 2a 2a 20 64 65 66 65 72 72 65 64 20   a .** deferred 
0370: 66 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73  foreign key cons
0380: 74 72 61 69 6e 74 20 69 73 20 76 69 6f 6c 61 74  traint is violat
0390: 65 64 2c 20 6e 6f 20 61 63 74 69 6f 6e 20 69 73  ed, no action is
03a0: 20 74 61 6b 65 6e 20 0a 2a 2a 20 69 6d 6d 65 64   taken .** immed
03b0: 69 61 74 65 6c 79 2e 20 48 6f 77 65 76 65 72 20  iately. However 
03c0: 69 66 20 74 68 65 20 61 70 70 6c 69 63 61 74 69  if the applicati
03d0: 6f 6e 20 61 74 74 65 6d 70 74 73 20 74 6f 20 63  on attempts to c
03e0: 6f 6d 6d 69 74 20 74 68 65 20 0a 2a 2a 20 74 72  ommit the .** tr
03f0: 61 6e 73 61 63 74 69 6f 6e 20 62 65 66 6f 72 65  ansaction before
0400: 20 66 69 78 69 6e 67 20 74 68 65 20 63 6f 6e 73   fixing the cons
0410: 74 72 61 69 6e 74 20 76 69 6f 6c 61 74 69 6f 6e  traint violation
0420: 2c 20 74 68 65 20 61 74 74 65 6d 70 74 20 66 61  , the attempt fa
0430: 69 6c 73 2e 0a 2a 2a 0a 2a 2a 20 44 65 66 65 72  ils..**.** Defer
0440: 72 65 64 20 63 6f 6e 73 74 72 61 69 6e 74 73 20  red constraints 
0450: 61 72 65 20 69 6d 70 6c 65 6d 65 6e 74 65 64 20  are implemented 
0460: 75 73 69 6e 67 20 61 20 73 69 6d 70 6c 65 20 63  using a simple c
0470: 6f 75 6e 74 65 72 20 61 73 73 6f 63 69 61 74 65  ounter associate
0480: 64 0a 2a 2a 20 77 69 74 68 20 74 68 65 20 64 61  d.** with the da
0490: 74 61 62 61 73 65 20 68 61 6e 64 6c 65 2e 20 54  tabase handle. T
04a0: 68 65 20 63 6f 75 6e 74 65 72 20 69 73 20 73 65  he counter is se
04b0: 74 20 74 6f 20 7a 65 72 6f 20 65 61 63 68 20 74  t to zero each t
04c0: 69 6d 65 20 61 20 0a 2a 2a 20 64 61 74 61 62 61  ime a .** databa
04d0: 73 65 20 74 72 61 6e 73 61 63 74 69 6f 6e 20 69  se transaction i
04e0: 73 20 6f 70 65 6e 65 64 2e 20 45 61 63 68 20 74  s opened. Each t
04f0: 69 6d 65 20 61 20 73 74 61 74 65 6d 65 6e 74 20  ime a statement 
0500: 69 73 20 65 78 65 63 75 74 65 64 20 0a 2a 2a 20  is executed .** 
0510: 74 68 61 74 20 63 61 75 73 65 73 20 61 20 66 6f  that causes a fo
0520: 72 65 69 67 6e 20 6b 65 79 20 76 69 6f 6c 61 74  reign key violat
0530: 69 6f 6e 2c 20 74 68 65 20 63 6f 75 6e 74 65 72  ion, the counter
0540: 20 69 73 20 69 6e 63 72 65 6d 65 6e 74 65 64 2e   is incremented.
0550: 20 45 61 63 68 0a 2a 2a 20 74 69 6d 65 20 61 20   Each.** time a 
0560: 73 74 61 74 65 6d 65 6e 74 20 69 73 20 65 78 65  statement is exe
0570: 63 75 74 65 64 20 74 68 61 74 20 72 65 6d 6f 76  cuted that remov
0580: 65 73 20 61 6e 20 65 78 69 73 74 69 6e 67 20 76  es an existing v
0590: 69 6f 6c 61 74 69 6f 6e 20 66 72 6f 6d 0a 2a 2a  iolation from.**
05a0: 20 74 68 65 20 64 61 74 61 62 61 73 65 2c 20 74   the database, t
05b0: 68 65 20 63 6f 75 6e 74 65 72 20 69 73 20 64 65  he counter is de
05c0: 63 72 65 6d 65 6e 74 65 64 2e 20 57 68 65 6e 20  cremented. When 
05d0: 74 68 65 20 74 72 61 6e 73 61 63 74 69 6f 6e 20  the transaction 
05e0: 69 73 0a 2a 2a 20 63 6f 6d 6d 69 74 74 65 64 2c  is.** committed,
05f0: 20 74 68 65 20 63 6f 6d 6d 69 74 20 66 61 69 6c   the commit fail
0600: 73 20 69 66 20 74 68 65 20 63 75 72 72 65 6e 74  s if the current
0610: 20 76 61 6c 75 65 20 6f 66 20 74 68 65 20 63 6f   value of the co
0620: 75 6e 74 65 72 20 69 73 0a 2a 2a 20 67 72 65 61  unter is.** grea
0630: 74 65 72 20 74 68 61 6e 20 7a 65 72 6f 2e 20 54  ter than zero. T
0640: 68 69 73 20 73 63 68 65 6d 65 20 68 61 73 20 74  his scheme has t
0650: 77 6f 20 62 69 67 20 64 72 61 77 62 61 63 6b 73  wo big drawbacks
0660: 3a 0a 2a 2a 0a 2a 2a 20 20 20 2a 20 57 68 65 6e  :.**.**   * When
0670: 20 61 20 63 6f 6d 6d 69 74 20 66 61 69 6c 73 20   a commit fails 
0680: 64 75 65 20 74 6f 20 61 20 64 65 66 65 72 72 65  due to a deferre
0690: 64 20 66 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f  d foreign key co
06a0: 6e 73 74 72 61 69 6e 74 2c 20 0a 2a 2a 20 20 20  nstraint, .**   
06b0: 20 20 74 68 65 72 65 20 69 73 20 6e 6f 20 77 61    there is no wa
06c0: 79 20 74 6f 20 74 65 6c 6c 20 77 68 69 63 68 20  y to tell which 
06d0: 66 6f 72 65 69 67 6e 20 63 6f 6e 73 74 72 61 69  foreign constrai
06e0: 6e 74 20 69 73 20 6e 6f 74 20 73 61 74 69 73 66  nt is not satisf
06f0: 69 65 64 2c 0a 2a 2a 20 20 20 20 20 6f 72 20 77  ied,.**     or w
0700: 68 69 63 68 20 72 6f 77 20 69 74 20 69 73 20 6e  hich row it is n
0710: 6f 74 20 73 61 74 69 73 66 69 65 64 20 66 6f 72  ot satisfied for
0720: 2e 0a 2a 2a 0a 2a 2a 20 20 20 2a 20 49 66 20 74  ..**.**   * If t
0730: 68 65 20 64 61 74 61 62 61 73 65 20 63 6f 6e 74  he database cont
0740: 61 69 6e 73 20 66 6f 72 65 69 67 6e 20 6b 65 79  ains foreign key
0750: 20 76 69 6f 6c 61 74 69 6f 6e 73 20 77 68 65 6e   violations when
0760: 20 74 68 65 20 0a 2a 2a 20 20 20 20 20 74 72 61   the .**     tra
0770: 6e 73 61 63 74 69 6f 6e 20 69 73 20 6f 70 65 6e  nsaction is open
0780: 65 64 2c 20 74 68 69 73 20 6d 61 79 20 63 61 75  ed, this may cau
0790: 73 65 20 74 68 65 20 6d 65 63 68 61 6e 69 73 6d  se the mechanism
07a0: 20 74 6f 20 6d 61 6c 66 75 6e 63 74 69 6f 6e 2e   to malfunction.
07b0: 0a 2a 2a 0a 2a 2a 20 44 65 73 70 69 74 65 20 74  .**.** Despite t
07c0: 68 65 73 65 20 70 72 6f 62 6c 65 6d 73 2c 20 74  hese problems, t
07d0: 68 69 73 20 61 70 70 72 6f 61 63 68 20 69 73 20  his approach is 
07e0: 61 64 6f 70 74 65 64 20 61 73 20 69 74 20 73 65  adopted as it se
07f0: 65 6d 73 20 73 69 6d 70 6c 65 72 0a 2a 2a 20 74  ems simpler.** t
0800: 68 61 6e 20 74 68 65 20 61 6c 74 65 72 6e 61 74  han the alternat
0810: 69 76 65 73 2e 0a 2a 2a 0a 2a 2a 20 49 4e 53 45  ives..**.** INSE
0820: 52 54 20 6f 70 65 72 61 74 69 6f 6e 73 3a 0a 2a  RT operations:.*
0830: 2a 0a 2a 2a 20 20 20 49 2e 31 29 20 46 6f 72 20  *.**   I.1) For 
0840: 65 61 63 68 20 46 4b 20 66 6f 72 20 77 68 69 63  each FK for whic
0850: 68 20 74 68 65 20 74 61 62 6c 65 20 69 73 20 74  h the table is t
0860: 68 65 20 63 68 69 6c 64 20 74 61 62 6c 65 2c 20  he child table, 
0870: 73 65 61 72 63 68 0a 2a 2a 20 20 20 20 20 20 20  search.**       
0880: 20 74 68 65 20 70 61 72 65 6e 74 20 74 61 62 6c   the parent tabl
0890: 65 20 66 6f 72 20 61 20 6d 61 74 63 68 2e 20 49  e for a match. I
08a0: 66 20 6e 6f 6e 65 20 69 73 20 66 6f 75 6e 64 20  f none is found 
08b0: 69 6e 63 72 65 6d 65 6e 74 20 74 68 65 0a 2a 2a  increment the.**
08c0: 20 20 20 20 20 20 20 20 63 6f 6e 73 74 72 61 69          constrai
08d0: 6e 74 20 63 6f 75 6e 74 65 72 2e 0a 2a 2a 0a 2a  nt counter..**.*
08e0: 2a 20 20 20 49 2e 32 29 20 46 6f 72 20 65 61 63  *   I.2) For eac
08f0: 68 20 46 4b 20 66 6f 72 20 77 68 69 63 68 20 74  h FK for which t
0900: 68 65 20 74 61 62 6c 65 20 69 73 20 74 68 65 20  he table is the 
0910: 70 61 72 65 6e 74 20 74 61 62 6c 65 2c 20 0a 2a  parent table, .*
0920: 2a 20 20 20 20 20 20 20 20 73 65 61 72 63 68 20  *        search 
0930: 74 68 65 20 63 68 69 6c 64 20 74 61 62 6c 65 20  the child table 
0940: 66 6f 72 20 72 6f 77 73 20 74 68 61 74 20 63 6f  for rows that co
0950: 72 72 65 73 70 6f 6e 64 20 74 6f 20 74 68 65 20  rrespond to the 
0960: 6e 65 77 0a 2a 2a 20 20 20 20 20 20 20 20 72 6f  new.**        ro
0970: 77 20 69 6e 20 74 68 65 20 70 61 72 65 6e 74 20  w in the parent 
0980: 74 61 62 6c 65 2e 20 44 65 63 72 65 6d 65 6e 74  table. Decrement
0990: 20 74 68 65 20 63 6f 75 6e 74 65 72 20 66 6f 72   the counter for
09a0: 20 65 61 63 68 20 72 6f 77 0a 2a 2a 20 20 20 20   each row.**    
09b0: 20 20 20 20 66 6f 75 6e 64 20 28 61 73 20 74 68      found (as th
09c0: 65 20 63 6f 6e 73 74 72 61 69 6e 74 20 69 73 20  e constraint is 
09d0: 6e 6f 77 20 73 61 74 69 73 66 69 65 64 29 2e 0a  now satisfied)..
09e0: 2a 2a 0a 2a 2a 20 44 45 4c 45 54 45 20 6f 70 65  **.** DELETE ope
09f0: 72 61 74 69 6f 6e 73 3a 0a 2a 2a 0a 2a 2a 20 20  rations:.**.**  
0a00: 20 44 2e 31 29 20 46 6f 72 20 65 61 63 68 20 46   D.1) For each F
0a10: 4b 20 66 6f 72 20 77 68 69 63 68 20 74 68 65 20  K for which the 
0a20: 74 61 62 6c 65 20 69 73 20 74 68 65 20 63 68 69  table is the chi
0a30: 6c 64 20 74 61 62 6c 65 2c 20 0a 2a 2a 20 20 20  ld table, .**   
0a40: 20 20 20 20 20 73 65 61 72 63 68 20 74 68 65 20       search the 
0a50: 70 61 72 65 6e 74 20 74 61 62 6c 65 20 66 6f 72  parent table for
0a60: 20 61 20 72 6f 77 20 74 68 61 74 20 63 6f 72 72   a row that corr
0a70: 65 73 70 6f 6e 64 73 20 74 6f 20 74 68 65 20 0a  esponds to the .
0a80: 2a 2a 20 20 20 20 20 20 20 20 64 65 6c 65 74 65  **        delete
0a90: 64 20 72 6f 77 20 69 6e 20 74 68 65 20 63 68 69  d row in the chi
0aa0: 6c 64 20 74 61 62 6c 65 2e 20 49 66 20 73 75 63  ld table. If suc
0ab0: 68 20 61 20 72 6f 77 20 69 73 20 6e 6f 74 20 66  h a row is not f
0ac0: 6f 75 6e 64 2c 20 0a 2a 2a 20 20 20 20 20 20 20  ound, .**       
0ad0: 20 64 65 63 72 65 6d 65 6e 74 20 74 68 65 20 63   decrement the c
0ae0: 6f 75 6e 74 65 72 2e 0a 2a 2a 0a 2a 2a 20 20 20  ounter..**.**   
0af0: 44 2e 32 29 20 46 6f 72 20 65 61 63 68 20 46 4b  D.2) For each FK
0b00: 20 66 6f 72 20 77 68 69 63 68 20 74 68 65 20 74   for which the t
0b10: 61 62 6c 65 20 69 73 20 74 68 65 20 70 61 72 65  able is the pare
0b20: 6e 74 20 74 61 62 6c 65 2c 20 73 65 61 72 63 68  nt table, search
0b30: 20 0a 2a 2a 20 20 20 20 20 20 20 20 74 68 65 20   .**        the 
0b40: 63 68 69 6c 64 20 74 61 62 6c 65 20 66 6f 72 20  child table for 
0b50: 72 6f 77 73 20 74 68 61 74 20 63 6f 72 72 65 73  rows that corres
0b60: 70 6f 6e 64 20 74 6f 20 74 68 65 20 64 65 6c 65  pond to the dele
0b70: 74 65 64 20 72 6f 77 20 0a 2a 2a 20 20 20 20 20  ted row .**     
0b80: 20 20 20 69 6e 20 74 68 65 20 70 61 72 65 6e 74     in the parent
0b90: 20 74 61 62 6c 65 2e 20 46 6f 72 20 65 61 63 68   table. For each
0ba0: 20 66 6f 75 6e 64 20 69 6e 63 72 65 6d 65 6e 74   found increment
0bb0: 20 74 68 65 20 63 6f 75 6e 74 65 72 2e 0a 2a 2a   the counter..**
0bc0: 0a 2a 2a 20 55 50 44 41 54 45 20 6f 70 65 72 61  .** UPDATE opera
0bd0: 74 69 6f 6e 73 3a 0a 2a 2a 0a 2a 2a 20 20 20 41  tions:.**.**   A
0be0: 6e 20 55 50 44 41 54 45 20 63 6f 6d 6d 61 6e 64  n UPDATE command
0bf0: 20 72 65 71 75 69 72 65 73 20 74 68 61 74 20 61   requires that a
0c00: 6c 6c 20 34 20 73 74 65 70 73 20 61 62 6f 76 65  ll 4 steps above
0c10: 20 61 72 65 20 74 61 6b 65 6e 2c 20 62 75 74 20   are taken, but 
0c20: 6f 6e 6c 79 0a 2a 2a 20 20 20 66 6f 72 20 46 4b  only.**   for FK
0c30: 20 63 6f 6e 73 74 72 61 69 6e 74 73 20 66 6f 72   constraints for
0c40: 20 77 68 69 63 68 20 74 68 65 20 61 66 66 65 63   which the affec
0c50: 74 65 64 20 63 6f 6c 75 6d 6e 73 20 61 72 65 20  ted columns are 
0c60: 61 63 74 75 61 6c 6c 79 20 0a 2a 2a 20 20 20 6d  actually .**   m
0c70: 6f 64 69 66 69 65 64 20 28 76 61 6c 75 65 73 20  odified (values 
0c80: 6d 75 73 74 20 62 65 20 63 6f 6d 70 61 72 65 64  must be compared
0c90: 20 61 74 20 72 75 6e 74 69 6d 65 29 2e 0a 2a 2a   at runtime)..**
0ca0: 0a 2a 2a 20 4e 6f 74 65 20 74 68 61 74 20 49 2e  .** Note that I.
0cb0: 31 20 61 6e 64 20 44 2e 31 20 61 72 65 20 76 65  1 and D.1 are ve
0cc0: 72 79 20 73 69 6d 69 6c 61 72 20 6f 70 65 72 61  ry similar opera
0cd0: 74 69 6f 6e 73 2c 20 61 73 20 61 72 65 20 49 2e  tions, as are I.
0ce0: 32 20 61 6e 64 20 44 2e 32 2e 0a 2a 2a 20 54 68  2 and D.2..** Th
0cf0: 69 73 20 73 69 6d 70 6c 69 66 69 65 73 20 74 68  is simplifies th
0d00: 65 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e  e implementation
0d10: 20 61 20 62 69 74 2e 0a 2a 2a 0a 2a 2a 20 46 6f   a bit..**.** Fo
0d20: 72 20 74 68 65 20 70 75 72 70 6f 73 65 73 20 6f  r the purposes o
0d30: 66 20 69 6d 6d 65 64 69 61 74 65 20 46 4b 20 63  f immediate FK c
0d40: 6f 6e 73 74 72 61 69 6e 74 73 2c 20 74 68 65 20  onstraints, the 
0d50: 4f 52 20 52 45 50 4c 41 43 45 20 63 6f 6e 66 6c  OR REPLACE confl
0d60: 69 63 74 0a 2a 2a 20 72 65 73 6f 6c 75 74 69 6f  ict.** resolutio
0d70: 6e 20 69 73 20 63 6f 6e 73 69 64 65 72 65 64 20  n is considered 
0d80: 74 6f 20 64 65 6c 65 74 65 20 72 6f 77 73 20 62  to delete rows b
0d90: 65 66 6f 72 65 20 74 68 65 20 6e 65 77 20 72 6f  efore the new ro
0da0: 77 20 69 73 20 69 6e 73 65 72 74 65 64 2e 0a 2a  w is inserted..*
0db0: 2a 20 49 66 20 61 20 64 65 6c 65 74 65 20 63 61  * If a delete ca
0dc0: 75 73 65 64 20 62 79 20 4f 52 20 52 45 50 4c 41  used by OR REPLA
0dd0: 43 45 20 76 69 6f 6c 61 74 65 73 20 61 6e 20 46  CE violates an F
0de0: 4b 20 63 6f 6e 73 74 72 61 69 6e 74 2c 20 61 6e  K constraint, an
0df0: 20 65 78 63 65 70 74 69 6f 6e 0a 2a 2a 20 69 73   exception.** is
0e00: 20 74 68 72 6f 77 6e 2c 20 65 76 65 6e 20 69 66   thrown, even if
0e10: 20 74 68 65 20 46 4b 20 63 6f 6e 73 74 72 61 69   the FK constrai
0e20: 6e 74 20 77 6f 75 6c 64 20 62 65 20 73 61 74 69  nt would be sati
0e30: 73 66 69 65 64 20 61 66 74 65 72 20 74 68 65 20  sfied after the 
0e40: 6e 65 77 20 0a 2a 2a 20 72 6f 77 20 69 73 20 69  new .** row is i
0e50: 6e 73 65 72 74 65 64 2e 0a 2a 2a 0a 2a 2a 20 49  nserted..**.** I
0e60: 6d 6d 65 64 69 61 74 65 20 63 6f 6e 73 74 72 61  mmediate constra
0e70: 69 6e 74 73 20 61 72 65 20 75 73 75 61 6c 6c 79  ints are usually
0e80: 20 68 61 6e 64 6c 65 64 20 73 69 6d 69 6c 61 72   handled similar
0e90: 6c 79 2e 20 54 68 65 20 6f 6e 6c 79 20 64 69 66  ly. The only dif
0ea0: 66 65 72 65 6e 63 65 20 0a 2a 2a 20 69 73 20 74  ference .** is t
0eb0: 68 61 74 20 74 68 65 20 63 6f 75 6e 74 65 72 20  hat the counter 
0ec0: 75 73 65 64 20 69 73 20 73 74 6f 72 65 64 20 61  used is stored a
0ed0: 73 20 70 61 72 74 20 6f 66 20 65 61 63 68 20 69  s part of each i
0ee0: 6e 64 69 76 69 64 75 61 6c 20 73 74 61 74 65 6d  ndividual statem
0ef0: 65 6e 74 0a 2a 2a 20 6f 62 6a 65 63 74 20 28 73  ent.** object (s
0f00: 74 72 75 63 74 20 56 64 62 65 29 2e 20 49 66 2c  truct Vdbe). If,
0f10: 20 61 66 74 65 72 20 74 68 65 20 73 74 61 74 65   after the state
0f20: 6d 65 6e 74 20 68 61 73 20 72 75 6e 2c 20 69 74  ment has run, it
0f30: 73 20 69 6d 6d 65 64 69 61 74 65 0a 2a 2a 20 63  s immediate.** c
0f40: 6f 6e 73 74 72 61 69 6e 74 20 63 6f 75 6e 74 65  onstraint counte
0f50: 72 20 69 73 20 67 72 65 61 74 65 72 20 74 68 61  r is greater tha
0f60: 6e 20 7a 65 72 6f 2c 0a 2a 2a 20 69 74 20 72 65  n zero,.** it re
0f70: 74 75 72 6e 73 20 53 51 4c 49 54 45 5f 43 4f 4e  turns SQLITE_CON
0f80: 53 54 52 41 49 4e 54 5f 46 4f 52 45 49 47 4e 4b  STRAINT_FOREIGNK
0f90: 45 59 0a 2a 2a 20 61 6e 64 20 74 68 65 20 73 74  EY.** and the st
0fa0: 61 74 65 6d 65 6e 74 20 74 72 61 6e 73 61 63 74  atement transact
0fb0: 69 6f 6e 20 69 73 20 72 6f 6c 6c 65 64 20 62 61  ion is rolled ba
0fc0: 63 6b 2e 20 41 6e 20 65 78 63 65 70 74 69 6f 6e  ck. An exception
0fd0: 20 69 73 20 61 6e 20 49 4e 53 45 52 54 0a 2a 2a   is an INSERT.**
0fe0: 20 73 74 61 74 65 6d 65 6e 74 20 74 68 61 74 20   statement that 
0ff0: 69 6e 73 65 72 74 73 20 61 20 73 69 6e 67 6c 65  inserts a single
1000: 20 72 6f 77 20 6f 6e 6c 79 20 28 6e 6f 20 74 72   row only (no tr
1010: 69 67 67 65 72 73 29 2e 20 49 6e 20 74 68 69 73  iggers). In this
1020: 20 63 61 73 65 2c 0a 2a 2a 20 69 6e 73 74 65 61   case,.** instea
1030: 64 20 6f 66 20 75 73 69 6e 67 20 61 20 63 6f 75  d of using a cou
1040: 6e 74 65 72 2c 20 61 6e 20 65 78 63 65 70 74 69  nter, an excepti
1050: 6f 6e 20 69 73 20 74 68 72 6f 77 6e 20 69 6d 6d  on is thrown imm
1060: 65 64 69 61 74 65 6c 79 20 69 66 20 74 68 65 0a  ediately if the.
1070: 2a 2a 20 49 4e 53 45 52 54 20 76 69 6f 6c 61 74  ** INSERT violat
1080: 65 73 20 61 20 66 6f 72 65 69 67 6e 20 6b 65 79  es a foreign key
1090: 20 63 6f 6e 73 74 72 61 69 6e 74 2e 20 54 68 69   constraint. Thi
10a0: 73 20 69 73 20 6e 65 63 65 73 73 61 72 79 20 61  s is necessary a
10b0: 73 20 73 75 63 68 0a 2a 2a 20 61 6e 20 49 4e 53  s such.** an INS
10c0: 45 52 54 20 64 6f 65 73 20 6e 6f 74 20 6f 70 65  ERT does not ope
10d0: 6e 20 61 20 73 74 61 74 65 6d 65 6e 74 20 74 72  n a statement tr
10e0: 61 6e 73 61 63 74 69 6f 6e 2e 0a 2a 2a 0a 2a 2a  ansaction..**.**
10f0: 20 54 4f 44 4f 3a 20 48 6f 77 20 73 68 6f 75 6c   TODO: How shoul
1100: 64 20 64 72 6f 70 70 69 6e 67 20 61 20 74 61 62  d dropping a tab
1110: 6c 65 20 62 65 20 68 61 6e 64 6c 65 64 3f 20 48  le be handled? H
1120: 6f 77 20 73 68 6f 75 6c 64 20 72 65 6e 61 6d 69  ow should renami
1130: 6e 67 20 61 20 0a 2a 2a 20 74 61 62 6c 65 20 62  ng a .** table b
1140: 65 20 68 61 6e 64 6c 65 64 3f 0a 2a 2a 0a 2a 2a  e handled?.**.**
1150: 0a 2a 2a 20 51 75 65 72 79 20 41 50 49 20 4e 6f  .** Query API No
1160: 74 65 73 0a 2a 2a 20 2d 2d 2d 2d 2d 2d 2d 2d 2d  tes.** ---------
1170: 2d 2d 2d 2d 2d 2d 0a 2a 2a 0a 2a 2a 20 42 65 66  ------.**.** Bef
1180: 6f 72 65 20 63 6f 64 69 6e 67 20 61 6e 20 55 50  ore coding an UP
1190: 44 41 54 45 20 6f 72 20 44 45 4c 45 54 45 20 72  DATE or DELETE r
11a0: 6f 77 20 6f 70 65 72 61 74 69 6f 6e 2c 20 74 68  ow operation, th
11b0: 65 20 63 6f 64 65 2d 67 65 6e 65 72 61 74 6f 72  e code-generator
11c0: 0a 2a 2a 20 66 6f 72 20 74 68 6f 73 65 20 74 77  .** for those tw
11d0: 6f 20 6f 70 65 72 61 74 69 6f 6e 73 20 6e 65 65  o operations nee
11e0: 64 73 20 74 6f 20 6b 6e 6f 77 20 77 68 65 74 68  ds to know wheth
11f0: 65 72 20 6f 72 20 6e 6f 74 20 74 68 65 20 6f 70  er or not the op
1200: 65 72 61 74 69 6f 6e 0a 2a 2a 20 72 65 71 75 69  eration.** requi
1210: 72 65 73 20 61 6e 79 20 46 4b 20 70 72 6f 63 65  res any FK proce
1220: 73 73 69 6e 67 20 61 6e 64 2c 20 69 66 20 73 6f  ssing and, if so
1230: 2c 20 77 68 69 63 68 20 63 6f 6c 75 6d 6e 73 20  , which columns 
1240: 6f 66 20 74 68 65 20 6f 72 69 67 69 6e 61 6c 0a  of the original.
1250: 2a 2a 20 72 6f 77 20 61 72 65 20 72 65 71 75 69  ** row are requi
1260: 72 65 64 20 62 79 20 74 68 65 20 46 4b 20 70 72  red by the FK pr
1270: 6f 63 65 73 73 69 6e 67 20 56 44 42 45 20 63 6f  ocessing VDBE co
1280: 64 65 20 28 69 2e 65 2e 20 69 66 20 46 4b 73 20  de (i.e. if FKs 
1290: 77 65 72 65 0a 2a 2a 20 69 6d 70 6c 65 6d 65 6e  were.** implemen
12a0: 74 65 64 20 75 73 69 6e 67 20 74 72 69 67 67 65  ted using trigge
12b0: 72 73 2c 20 77 68 69 63 68 20 6f 66 20 74 68 65  rs, which of the
12c0: 20 6f 6c 64 2e 2a 20 63 6f 6c 75 6d 6e 73 20 77   old.* columns w
12d0: 6f 75 6c 64 20 62 65 20 0a 2a 2a 20 61 63 63 65  ould be .** acce
12e0: 73 73 65 64 29 2e 20 4e 6f 20 69 6e 66 6f 72 6d  ssed). No inform
12f0: 61 74 69 6f 6e 20 69 73 20 72 65 71 75 69 72 65  ation is require
1300: 64 20 62 79 20 74 68 65 20 63 6f 64 65 2d 67 65  d by the code-ge
1310: 6e 65 72 61 74 6f 72 20 62 65 66 6f 72 65 0a 2a  nerator before.*
1320: 2a 20 63 6f 64 69 6e 67 20 61 6e 20 49 4e 53 45  * coding an INSE
1330: 52 54 20 6f 70 65 72 61 74 69 6f 6e 2e 20 54 68  RT operation. Th
1340: 65 20 66 75 6e 63 74 69 6f 6e 73 20 75 73 65 64  e functions used
1350: 20 62 79 20 74 68 65 20 55 50 44 41 54 45 2f 44   by the UPDATE/D
1360: 45 4c 45 54 45 0a 2a 2a 20 67 65 6e 65 72 61 74  ELETE.** generat
1370: 69 6f 6e 20 63 6f 64 65 20 74 6f 20 71 75 65 72  ion code to quer
1380: 79 20 66 6f 72 20 74 68 69 73 20 69 6e 66 6f 72  y for this infor
1390: 6d 61 74 69 6f 6e 20 61 72 65 3a 0a 2a 2a 0a 2a  mation are:.**.*
13a0: 2a 20 20 20 73 71 6c 69 74 65 33 46 6b 52 65 71  *   sqlite3FkReq
13b0: 75 69 72 65 64 28 29 20 2d 20 54 65 73 74 20 74  uired() - Test t
13c0: 6f 20 73 65 65 20 69 66 20 46 4b 20 70 72 6f 63  o see if FK proc
13d0: 65 73 73 69 6e 67 20 69 73 20 72 65 71 75 69 72  essing is requir
13e0: 65 64 2e 0a 2a 2a 20 20 20 73 71 6c 69 74 65 33  ed..**   sqlite3
13f0: 46 6b 4f 6c 64 6d 61 73 6b 28 29 20 20 2d 20 51  FkOldmask()  - Q
1400: 75 65 72 79 20 66 6f 72 20 74 68 65 20 73 65 74  uery for the set
1410: 20 6f 66 20 72 65 71 75 69 72 65 64 20 6f 6c 64   of required old
1420: 2e 2a 20 63 6f 6c 75 6d 6e 73 2e 0a 2a 2a 0a 2a  .* columns..**.*
1430: 2a 0a 2a 2a 20 45 78 74 65 72 6e 61 6c 6c 79 20  *.** Externally 
1440: 61 63 63 65 73 73 69 62 6c 65 20 6d 6f 64 75 6c  accessible modul
1450: 65 20 66 75 6e 63 74 69 6f 6e 73 0a 2a 2a 20 2d  e functions.** -
1460: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1470: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1480: 2d 2d 2d 2d 2d 0a 2a 2a 0a 2a 2a 20 20 20 73 71  -----.**.**   sq
1490: 6c 69 74 65 33 46 6b 43 68 65 63 6b 28 29 20 20  lite3FkCheck()  
14a0: 20 20 2d 20 43 68 65 63 6b 20 66 6f 72 20 66 6f    - Check for fo
14b0: 72 65 69 67 6e 20 6b 65 79 20 76 69 6f 6c 61 74  reign key violat
14c0: 69 6f 6e 73 2e 0a 2a 2a 20 20 20 73 71 6c 69 74  ions..**   sqlit
14d0: 65 33 46 6b 41 63 74 69 6f 6e 73 28 29 20 20 2d  e3FkActions()  -
14e0: 20 43 6f 64 65 20 74 72 69 67 67 65 72 73 20 66   Code triggers f
14f0: 6f 72 20 4f 4e 20 55 50 44 41 54 45 2f 4f 4e 20  or ON UPDATE/ON 
1500: 44 45 4c 45 54 45 20 61 63 74 69 6f 6e 73 2e 0a  DELETE actions..
1510: 2a 2a 20 20 20 73 71 6c 69 74 65 33 46 6b 44 65  **   sqlite3FkDe
1520: 6c 65 74 65 28 29 20 20 20 2d 20 44 65 6c 65 74  lete()   - Delet
1530: 65 20 61 6e 20 46 4b 65 79 20 73 74 72 75 63 74  e an FKey struct
1540: 75 72 65 2e 0a 2a 2f 0a 0a 2f 2a 0a 2a 2a 20 56  ure..*/../*.** V
1550: 44 42 45 20 43 61 6c 6c 69 6e 67 20 43 6f 6e 76  DBE Calling Conv
1560: 65 6e 74 69 6f 6e 0a 2a 2a 20 2d 2d 2d 2d 2d 2d  ention.** ------
1570: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1580: 2d 0a 2a 2a 0a 2a 2a 20 45 78 61 6d 70 6c 65 3a  -.**.** Example:
1590: 0a 2a 2a 0a 2a 2a 20 20 20 46 6f 72 20 74 68 65  .**.**   For the
15a0: 20 66 6f 6c 6c 6f 77 69 6e 67 20 49 4e 53 45 52   following INSER
15b0: 54 20 73 74 61 74 65 6d 65 6e 74 3a 0a 2a 2a 0a  T statement:.**.
15c0: 2a 2a 20 20 20 20 20 43 52 45 41 54 45 20 54 41  **     CREATE TA
15d0: 42 4c 45 20 74 31 28 61 2c 20 62 20 49 4e 54 45  BLE t1(a, b INTE
15e0: 47 45 52 20 50 52 49 4d 41 52 59 20 4b 45 59 2c  GER PRIMARY KEY,
15f0: 20 63 29 3b 0a 2a 2a 20 20 20 20 20 49 4e 53 45   c);.**     INSE
1600: 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45  RT INTO t1 VALUE
1610: 53 28 31 2c 20 32 2c 20 33 2e 31 29 3b 0a 2a 2a  S(1, 2, 3.1);.**
1620: 0a 2a 2a 20 20 20 52 65 67 69 73 74 65 72 20 28  .**   Register (
1630: 78 29 3a 20 20 20 20 20 20 20 20 32 20 20 20 20  x):        2    
1640: 28 74 79 70 65 20 69 6e 74 65 67 65 72 29 0a 2a  (type integer).*
1650: 2a 20 20 20 52 65 67 69 73 74 65 72 20 28 78 2b  *   Register (x+
1660: 31 29 3a 20 20 20 20 20 20 31 20 20 20 20 28 74  1):      1    (t
1670: 79 70 65 20 69 6e 74 65 67 65 72 29 0a 2a 2a 20  ype integer).** 
1680: 20 20 52 65 67 69 73 74 65 72 20 28 78 2b 32 29    Register (x+2)
1690: 3a 20 20 20 20 20 20 4e 55 4c 4c 20 28 74 79 70  :      NULL (typ
16a0: 65 20 4e 55 4c 4c 29 0a 2a 2a 20 20 20 52 65 67  e NULL).**   Reg
16b0: 69 73 74 65 72 20 28 78 2b 33 29 3a 20 20 20 20  ister (x+3):    
16c0: 20 20 33 2e 31 20 20 28 74 79 70 65 20 72 65 61    3.1  (type rea
16d0: 6c 29 0a 2a 2f 0a 0a 2f 2a 0a 2a 2a 20 41 20 66  l).*/../*.** A f
16e0: 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73 74  oreign key const
16f0: 72 61 69 6e 74 20 72 65 71 75 69 72 65 73 20 74  raint requires t
1700: 68 61 74 20 74 68 65 20 6b 65 79 20 63 6f 6c 75  hat the key colu
1710: 6d 6e 73 20 69 6e 20 74 68 65 20 70 61 72 65 6e  mns in the paren
1720: 74 0a 2a 2a 20 74 61 62 6c 65 20 61 72 65 20 63  t.** table are c
1730: 6f 6c 6c 65 63 74 69 76 65 6c 79 20 73 75 62 6a  ollectively subj
1740: 65 63 74 20 74 6f 20 61 20 55 4e 49 51 55 45 20  ect to a UNIQUE 
1750: 6f 72 20 50 52 49 4d 41 52 59 20 4b 45 59 20 63  or PRIMARY KEY c
1760: 6f 6e 73 74 72 61 69 6e 74 2e 0a 2a 2a 20 47 69  onstraint..** Gi
1770: 76 65 6e 20 74 68 61 74 20 70 50 61 72 65 6e 74  ven that pParent
1780: 20 69 73 20 74 68 65 20 70 61 72 65 6e 74 20 74   is the parent t
1790: 61 62 6c 65 20 66 6f 72 20 66 6f 72 65 69 67 6e  able for foreign
17a0: 20 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e 74 20   key constraint 
17b0: 70 46 4b 65 79 2c 20 0a 2a 2a 20 73 65 61 72 63  pFKey, .** searc
17c0: 68 20 74 68 65 20 73 63 68 65 6d 61 20 66 6f 72  h the schema for
17d0: 20 61 20 75 6e 69 71 75 65 20 69 6e 64 65 78 20   a unique index 
17e0: 6f 6e 20 74 68 65 20 70 61 72 65 6e 74 20 6b 65  on the parent ke
17f0: 79 20 63 6f 6c 75 6d 6e 73 2e 20 0a 2a 2a 0a 2a  y columns. .**.*
1800: 2a 20 49 66 20 73 75 63 63 65 73 73 66 75 6c 2c  * If successful,
1810: 20 7a 65 72 6f 20 69 73 20 72 65 74 75 72 6e 65   zero is returne
1820: 64 2e 20 49 66 20 74 68 65 20 70 61 72 65 6e 74  d. If the parent
1830: 20 6b 65 79 20 69 73 20 61 6e 20 49 4e 54 45 47   key is an INTEG
1840: 45 52 20 50 52 49 4d 41 52 59 20 0a 2a 2a 20 4b  ER PRIMARY .** K
1850: 45 59 20 63 6f 6c 75 6d 6e 2c 20 74 68 65 6e 20  EY column, then 
1860: 6f 75 74 70 75 74 20 76 61 72 69 61 62 6c 65 20  output variable 
1870: 2a 70 70 49 64 78 20 69 73 20 73 65 74 20 74 6f  *ppIdx is set to
1880: 20 4e 55 4c 4c 2e 20 4f 74 68 65 72 77 69 73 65   NULL. Otherwise
1890: 2c 20 2a 70 70 49 64 78 20 0a 2a 2a 20 69 73 20  , *ppIdx .** is 
18a0: 73 65 74 20 74 6f 20 70 6f 69 6e 74 20 74 6f 20  set to point to 
18b0: 74 68 65 20 75 6e 69 71 75 65 20 69 6e 64 65 78  the unique index
18c0: 2e 20 0a 2a 2a 20 0a 2a 2a 20 49 66 20 74 68 65  . .** .** If the
18d0: 20 70 61 72 65 6e 74 20 6b 65 79 20 63 6f 6e 73   parent key cons
18e0: 69 73 74 73 20 6f 66 20 61 20 73 69 6e 67 6c 65  ists of a single
18f0: 20 63 6f 6c 75 6d 6e 20 28 74 68 65 20 66 6f 72   column (the for
1900: 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61  eign key constra
1910: 69 6e 74 0a 2a 2a 20 69 73 20 6e 6f 74 20 61 20  int.** is not a 
1920: 63 6f 6d 70 6f 73 69 74 65 20 66 6f 72 65 69 67  composite foreig
1930: 6e 20 6b 65 79 29 2c 20 6f 75 74 70 75 74 20 76  n key), output v
1940: 61 72 69 61 62 6c 65 20 2a 70 61 69 43 6f 6c 20  ariable *paiCol 
1950: 69 73 20 73 65 74 20 74 6f 20 4e 55 4c 4c 2e 0a  is set to NULL..
1960: 2a 2a 20 4f 74 68 65 72 77 69 73 65 2c 20 69 74  ** Otherwise, it
1970: 20 69 73 20 73 65 74 20 74 6f 20 70 6f 69 6e 74   is set to point
1980: 20 74 6f 20 61 6e 20 61 6c 6c 6f 63 61 74 65 64   to an allocated
1990: 20 61 72 72 61 79 20 6f 66 20 73 69 7a 65 20 4e   array of size N
19a0: 2c 20 77 68 65 72 65 0a 2a 2a 20 4e 20 69 73 20  , where.** N is 
19b0: 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 63 6f  the number of co
19c0: 6c 75 6d 6e 73 20 69 6e 20 74 68 65 20 70 61 72  lumns in the par
19d0: 65 6e 74 20 6b 65 79 2e 20 54 68 65 20 66 69 72  ent key. The fir
19e0: 73 74 20 65 6c 65 6d 65 6e 74 20 6f 66 20 74 68  st element of th
19f0: 65 0a 2a 2a 20 61 72 72 61 79 20 69 73 20 74 68  e.** array is th
1a00: 65 20 69 6e 64 65 78 20 6f 66 20 74 68 65 20 63  e index of the c
1a10: 68 69 6c 64 20 74 61 62 6c 65 20 63 6f 6c 75 6d  hild table colum
1a20: 6e 20 74 68 61 74 20 69 73 20 6d 61 70 70 65 64  n that is mapped
1a30: 20 62 79 20 74 68 65 20 46 4b 0a 2a 2a 20 63 6f   by the FK.** co
1a40: 6e 73 74 72 61 69 6e 74 20 74 6f 20 74 68 65 20  nstraint to the 
1a50: 70 61 72 65 6e 74 20 74 61 62 6c 65 20 63 6f 6c  parent table col
1a60: 75 6d 6e 20 73 74 6f 72 65 64 20 69 6e 20 74 68  umn stored in th
1a70: 65 20 6c 65 66 74 2d 6d 6f 73 74 20 63 6f 6c 75  e left-most colu
1a80: 6d 6e 0a 2a 2a 20 6f 66 20 69 6e 64 65 78 20 2a  mn.** of index *
1a90: 70 70 49 64 78 2e 20 54 68 65 20 73 65 63 6f 6e  ppIdx. The secon
1aa0: 64 20 65 6c 65 6d 65 6e 74 20 6f 66 20 74 68 65  d element of the
1ab0: 20 61 72 72 61 79 20 69 73 20 74 68 65 20 69 6e   array is the in
1ac0: 64 65 78 20 6f 66 20 74 68 65 0a 2a 2a 20 63 68  dex of the.** ch
1ad0: 69 6c 64 20 74 61 62 6c 65 20 63 6f 6c 75 6d 6e  ild table column
1ae0: 20 74 68 61 74 20 63 6f 72 72 65 73 70 6f 6e 64   that correspond
1af0: 73 20 74 6f 20 74 68 65 20 73 65 63 6f 6e 64 20  s to the second 
1b00: 6c 65 66 74 2d 6d 6f 73 74 20 63 6f 6c 75 6d 6e  left-most column
1b10: 20 6f 66 0a 2a 2a 20 2a 70 70 49 64 78 2c 20 61   of.** *ppIdx, a
1b20: 6e 64 20 73 6f 20 6f 6e 2e 0a 2a 2a 0a 2a 2a 20  nd so on..**.** 
1b30: 49 66 20 74 68 65 20 72 65 71 75 69 72 65 64 20  If the required 
1b40: 69 6e 64 65 78 20 63 61 6e 6e 6f 74 20 62 65 20  index cannot be 
1b50: 66 6f 75 6e 64 2c 20 65 69 74 68 65 72 20 62 65  found, either be
1b60: 63 61 75 73 65 3a 0a 2a 2a 0a 2a 2a 20 20 20 31  cause:.**.**   1
1b70: 29 20 54 68 65 20 6e 61 6d 65 64 20 70 61 72 65  ) The named pare
1b80: 6e 74 20 6b 65 79 20 63 6f 6c 75 6d 6e 73 20 64  nt key columns d
1b90: 6f 20 6e 6f 74 20 65 78 69 73 74 2c 20 6f 72 0a  o not exist, or.
1ba0: 2a 2a 0a 2a 2a 20 20 20 32 29 20 54 68 65 20 6e  **.**   2) The n
1bb0: 61 6d 65 64 20 70 61 72 65 6e 74 20 6b 65 79 20  amed parent key 
1bc0: 63 6f 6c 75 6d 6e 73 20 64 6f 20 65 78 69 73 74  columns do exist
1bd0: 2c 20 62 75 74 20 61 72 65 20 6e 6f 74 20 73 75  , but are not su
1be0: 62 6a 65 63 74 20 74 6f 20 61 0a 2a 2a 20 20 20  bject to a.**   
1bf0: 20 20 20 55 4e 49 51 55 45 20 6f 72 20 50 52 49     UNIQUE or PRI
1c00: 4d 41 52 59 20 4b 45 59 20 63 6f 6e 73 74 72 61  MARY KEY constra
1c10: 69 6e 74 2c 20 6f 72 0a 2a 2a 0a 2a 2a 20 20 20  int, or.**.**   
1c20: 33 29 20 4e 6f 20 70 61 72 65 6e 74 20 6b 65 79  3) No parent key
1c30: 20 63 6f 6c 75 6d 6e 73 20 77 65 72 65 20 70 72   columns were pr
1c40: 6f 76 69 64 65 64 20 65 78 70 6c 69 63 69 74 6c  ovided explicitl
1c50: 79 20 61 73 20 70 61 72 74 20 6f 66 20 74 68 65  y as part of the
1c60: 0a 2a 2a 20 20 20 20 20 20 66 6f 72 65 69 67 6e  .**      foreign
1c70: 20 6b 65 79 20 64 65 66 69 6e 69 74 69 6f 6e 2c   key definition,
1c80: 20 61 6e 64 20 74 68 65 20 70 61 72 65 6e 74 20   and the parent 
1c90: 74 61 62 6c 65 20 64 6f 65 73 20 6e 6f 74 20 68  table does not h
1ca0: 61 76 65 20 61 0a 2a 2a 20 20 20 20 20 20 50 52  ave a.**      PR
1cb0: 49 4d 41 52 59 20 4b 45 59 2c 20 6f 72 0a 2a 2a  IMARY KEY, or.**
1cc0: 0a 2a 2a 20 20 20 34 29 20 4e 6f 20 70 61 72 65  .**   4) No pare
1cd0: 6e 74 20 6b 65 79 20 63 6f 6c 75 6d 6e 73 20 77  nt key columns w
1ce0: 65 72 65 20 70 72 6f 76 69 64 65 64 20 65 78 70  ere provided exp
1cf0: 6c 69 63 69 74 6c 79 20 61 73 20 70 61 72 74 20  licitly as part 
1d00: 6f 66 20 74 68 65 0a 2a 2a 20 20 20 20 20 20 66  of the.**      f
1d10: 6f 72 65 69 67 6e 20 6b 65 79 20 64 65 66 69 6e  oreign key defin
1d20: 69 74 69 6f 6e 2c 20 61 6e 64 20 74 68 65 20 50  ition, and the P
1d30: 52 49 4d 41 52 59 20 4b 45 59 20 6f 66 20 74 68  RIMARY KEY of th
1d40: 65 20 70 61 72 65 6e 74 20 74 61 62 6c 65 20 0a  e parent table .
1d50: 2a 2a 20 20 20 20 20 20 63 6f 6e 73 69 73 74 73  **      consists
1d60: 20 6f 66 20 61 20 64 69 66 66 65 72 65 6e 74 20   of a different 
1d70: 6e 75 6d 62 65 72 20 6f 66 20 63 6f 6c 75 6d 6e  number of column
1d80: 73 20 74 6f 20 74 68 65 20 63 68 69 6c 64 20 6b  s to the child k
1d90: 65 79 20 69 6e 20 0a 2a 2a 20 20 20 20 20 20 74  ey in .**      t
1da0: 68 65 20 63 68 69 6c 64 20 74 61 62 6c 65 2e 0a  he child table..
1db0: 2a 2a 0a 2a 2a 20 74 68 65 6e 20 6e 6f 6e 2d 7a  **.** then non-z
1dc0: 65 72 6f 20 69 73 20 72 65 74 75 72 6e 65 64 2c  ero is returned,
1dd0: 20 61 6e 64 20 61 20 22 66 6f 72 65 69 67 6e 20   and a "foreign 
1de0: 6b 65 79 20 6d 69 73 6d 61 74 63 68 22 20 65 72  key mismatch" er
1df0: 72 6f 72 20 6c 6f 61 64 65 64 0a 2a 2a 20 69 6e  ror loaded.** in
1e00: 74 6f 20 70 50 61 72 73 65 2e 20 49 66 20 61 6e  to pParse. If an
1e10: 20 4f 4f 4d 20 65 72 72 6f 72 20 6f 63 63 75 72   OOM error occur
1e20: 73 2c 20 6e 6f 6e 2d 7a 65 72 6f 20 69 73 20 72  s, non-zero is r
1e30: 65 74 75 72 6e 65 64 20 61 6e 64 20 74 68 65 0a  eturned and the.
1e40: 2a 2a 20 70 50 61 72 73 65 2d 3e 64 62 2d 3e 6d  ** pParse->db->m
1e50: 61 6c 6c 6f 63 46 61 69 6c 65 64 20 66 6c 61 67  allocFailed flag
1e60: 20 69 73 20 73 65 74 2e 0a 2a 2f 0a 69 6e 74 20   is set..*/.int 
1e70: 73 71 6c 69 74 65 33 46 6b 4c 6f 63 61 74 65 49  sqlite3FkLocateI
1e80: 6e 64 65 78 28 0a 20 20 50 61 72 73 65 20 2a 70  ndex(.  Parse *p
1e90: 50 61 72 73 65 2c 20 20 20 20 20 20 20 20 20 20  Parse,          
1ea0: 20 20 20 20 20 20 20 20 2f 2a 20 50 61 72 73 65          /* Parse
1eb0: 20 63 6f 6e 74 65 78 74 20 74 6f 20 73 74 6f 72   context to stor
1ec0: 65 20 61 6e 79 20 65 72 72 6f 72 20 69 6e 20 2a  e any error in *
1ed0: 2f 0a 20 20 54 61 62 6c 65 20 2a 70 50 61 72 65  /.  Table *pPare
1ee0: 6e 74 2c 20 20 20 20 20 20 20 20 20 20 20 20 20  nt,             
1ef0: 20 20 20 20 2f 2a 20 50 61 72 65 6e 74 20 74 61      /* Parent ta
1f00: 62 6c 65 20 6f 66 20 46 4b 20 63 6f 6e 73 74 72  ble of FK constr
1f10: 61 69 6e 74 20 70 46 4b 65 79 20 2a 2f 0a 20 20  aint pFKey */.  
1f20: 46 4b 65 79 20 2a 70 46 4b 65 79 2c 20 20 20 20  FKey *pFKey,    
1f30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1f40: 2f 2a 20 46 6f 72 65 69 67 6e 20 6b 65 79 20 74  /* Foreign key t
1f50: 6f 20 66 69 6e 64 20 69 6e 64 65 78 20 66 6f 72  o find index for
1f60: 20 2a 2f 0a 20 20 49 6e 64 65 78 20 2a 2a 70 70   */.  Index **pp
1f70: 49 64 78 2c 20 20 20 20 20 20 20 20 20 20 20 20  Idx,            
1f80: 20 20 20 20 20 20 2f 2a 20 4f 55 54 3a 20 55 6e        /* OUT: Un
1f90: 69 71 75 65 20 69 6e 64 65 78 20 6f 6e 20 70 61  ique index on pa
1fa0: 72 65 6e 74 20 74 61 62 6c 65 20 2a 2f 0a 20 20  rent table */.  
1fb0: 69 6e 74 20 2a 2a 70 61 69 43 6f 6c 20 20 20 20  int **paiCol    
1fc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1fd0: 2f 2a 20 4f 55 54 3a 20 4d 61 70 20 6f 66 20 69  /* OUT: Map of i
1fe0: 6e 64 65 78 20 63 6f 6c 75 6d 6e 73 20 69 6e 20  ndex columns in 
1ff0: 70 46 4b 65 79 20 2a 2f 0a 29 7b 0a 20 20 49 6e  pFKey */.){.  In
2000: 64 65 78 20 2a 70 49 64 78 20 3d 20 30 3b 20 20  dex *pIdx = 0;  
2010: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2020: 20 20 2f 2a 20 56 61 6c 75 65 20 74 6f 20 72 65    /* Value to re
2030: 74 75 72 6e 20 76 69 61 20 2a 70 70 49 64 78 20  turn via *ppIdx 
2040: 2a 2f 0a 20 20 69 6e 74 20 2a 61 69 43 6f 6c 20  */.  int *aiCol 
2050: 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20 20 20  = 0;            
2060: 20 20 20 20 20 20 20 20 20 2f 2a 20 56 61 6c 75           /* Valu
2070: 65 20 74 6f 20 72 65 74 75 72 6e 20 76 69 61 20  e to return via 
2080: 2a 70 61 69 43 6f 6c 20 2a 2f 0a 20 20 69 6e 74  *paiCol */.  int
2090: 20 6e 43 6f 6c 20 3d 20 70 46 4b 65 79 2d 3e 6e   nCol = pFKey->n
20a0: 43 6f 6c 3b 20 20 20 20 20 20 20 20 20 20 20 20  Col;            
20b0: 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 63 6f   /* Number of co
20c0: 6c 75 6d 6e 73 20 69 6e 20 70 61 72 65 6e 74 20  lumns in parent 
20d0: 6b 65 79 20 2a 2f 0a 20 20 63 68 61 72 20 2a 7a  key */.  char *z
20e0: 4b 65 79 20 3d 20 70 46 4b 65 79 2d 3e 61 43 6f  Key = pFKey->aCo
20f0: 6c 5b 30 5d 2e 7a 43 6f 6c 3b 20 20 20 2f 2a 20  l[0].zCol;   /* 
2100: 4e 61 6d 65 20 6f 66 20 6c 65 66 74 2d 6d 6f 73  Name of left-mos
2110: 74 20 70 61 72 65 6e 74 20 6b 65 79 20 63 6f 6c  t parent key col
2120: 75 6d 6e 20 2a 2f 0a 0a 20 20 2f 2a 20 54 68 65  umn */..  /* The
2130: 20 63 61 6c 6c 65 72 20 69 73 20 72 65 73 70 6f   caller is respo
2140: 6e 73 69 62 6c 65 20 66 6f 72 20 7a 65 72 6f 69  nsible for zeroi
2150: 6e 67 20 6f 75 74 70 75 74 20 70 61 72 61 6d 65  ng output parame
2160: 74 65 72 73 2e 20 2a 2f 0a 20 20 61 73 73 65 72  ters. */.  asser
2170: 74 28 20 70 70 49 64 78 20 26 26 20 2a 70 70 49  t( ppIdx && *ppI
2180: 64 78 3d 3d 30 20 29 3b 0a 20 20 61 73 73 65 72  dx==0 );.  asser
2190: 74 28 20 21 70 61 69 43 6f 6c 20 7c 7c 20 2a 70  t( !paiCol || *p
21a0: 61 69 43 6f 6c 3d 3d 30 20 29 3b 0a 20 20 61 73  aiCol==0 );.  as
21b0: 73 65 72 74 28 20 70 50 61 72 73 65 20 29 3b 0a  sert( pParse );.
21c0: 0a 20 20 2f 2a 20 49 66 20 74 68 69 73 20 69 73  .  /* If this is
21d0: 20 61 20 6e 6f 6e 2d 63 6f 6d 70 6f 73 69 74 65   a non-composite
21e0: 20 28 73 69 6e 67 6c 65 20 63 6f 6c 75 6d 6e 29   (single column)
21f0: 20 66 6f 72 65 69 67 6e 20 6b 65 79 2c 20 63 68   foreign key, ch
2200: 65 63 6b 20 69 66 20 69 74 20 0a 20 20 2a 2a 20  eck if it .  ** 
2210: 6d 61 70 73 20 74 6f 20 74 68 65 20 49 4e 54 45  maps to the INTE
2220: 47 45 52 20 50 52 49 4d 41 52 59 20 4b 45 59 20  GER PRIMARY KEY 
2230: 6f 66 20 74 61 62 6c 65 20 70 50 61 72 65 6e 74  of table pParent
2240: 2e 20 49 66 20 73 6f 2c 20 6c 65 61 76 65 20 2a  . If so, leave *
2250: 70 70 49 64 78 20 0a 20 20 2a 2a 20 61 6e 64 20  ppIdx .  ** and 
2260: 2a 70 61 69 43 6f 6c 20 73 65 74 20 74 6f 20 7a  *paiCol set to z
2270: 65 72 6f 20 61 6e 64 20 72 65 74 75 72 6e 20 65  ero and return e
2280: 61 72 6c 79 2e 20 0a 20 20 2a 2a 0a 20 20 2a 2a  arly. .  **.  **
2290: 20 4f 74 68 65 72 77 69 73 65 2c 20 66 6f 72 20   Otherwise, for 
22a0: 61 20 63 6f 6d 70 6f 73 69 74 65 20 66 6f 72 65  a composite fore
22b0: 69 67 6e 20 6b 65 79 20 28 6d 6f 72 65 20 74 68  ign key (more th
22c0: 61 6e 20 6f 6e 65 20 63 6f 6c 75 6d 6e 29 2c 20  an one column), 
22d0: 61 6c 6c 6f 63 61 74 65 0a 20 20 2a 2a 20 73 70  allocate.  ** sp
22e0: 61 63 65 20 66 6f 72 20 74 68 65 20 61 69 43 6f  ace for the aiCo
22f0: 6c 20 61 72 72 61 79 20 28 72 65 74 75 72 6e 65  l array (returne
2300: 64 20 76 69 61 20 6f 75 74 70 75 74 20 70 61 72  d via output par
2310: 61 6d 65 74 65 72 20 2a 70 61 69 43 6f 6c 29 2e  ameter *paiCol).
2320: 0a 20 20 2a 2a 20 4e 6f 6e 2d 63 6f 6d 70 6f 73  .  ** Non-compos
2330: 69 74 65 20 66 6f 72 65 69 67 6e 20 6b 65 79 73  ite foreign keys
2340: 20 64 6f 20 6e 6f 74 20 72 65 71 75 69 72 65 20   do not require 
2350: 74 68 65 20 61 69 43 6f 6c 20 61 72 72 61 79 2e  the aiCol array.
2360: 0a 20 20 2a 2f 0a 20 20 69 66 28 20 6e 43 6f 6c  .  */.  if( nCol
2370: 3d 3d 31 20 29 7b 0a 20 20 20 20 2f 2a 20 54 68  ==1 ){.    /* Th
2380: 65 20 46 4b 20 6d 61 70 73 20 74 6f 20 74 68 65  e FK maps to the
2390: 20 49 50 4b 20 69 66 20 61 6e 79 20 6f 66 20 74   IPK if any of t
23a0: 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 61 72 65  he following are
23b0: 20 74 72 75 65 3a 0a 20 20 20 20 2a 2a 0a 20 20   true:.    **.  
23c0: 20 20 2a 2a 20 20 20 31 29 20 54 68 65 72 65 20    **   1) There 
23d0: 69 73 20 61 6e 20 49 4e 54 45 47 45 52 20 50 52  is an INTEGER PR
23e0: 49 4d 41 52 59 20 4b 45 59 20 63 6f 6c 75 6d 6e  IMARY KEY column
23f0: 20 61 6e 64 20 74 68 65 20 46 4b 20 69 73 20 69   and the FK is i
2400: 6d 70 6c 69 63 69 74 6c 79 20 0a 20 20 20 20 2a  mplicitly .    *
2410: 2a 20 20 20 20 20 20 6d 61 70 70 65 64 20 74 6f  *      mapped to
2420: 20 74 68 65 20 70 72 69 6d 61 72 79 20 6b 65 79   the primary key
2430: 20 6f 66 20 74 61 62 6c 65 20 70 50 61 72 65 6e   of table pParen
2440: 74 2c 20 6f 72 0a 20 20 20 20 2a 2a 20 20 20 32  t, or.    **   2
2450: 29 20 54 68 65 20 46 4b 20 69 73 20 65 78 70 6c  ) The FK is expl
2460: 69 63 69 74 6c 79 20 6d 61 70 70 65 64 20 74 6f  icitly mapped to
2470: 20 61 20 63 6f 6c 75 6d 6e 20 64 65 63 6c 61 72   a column declar
2480: 65 64 20 61 73 20 49 4e 54 45 47 45 52 0a 20 20  ed as INTEGER.  
2490: 20 20 2a 2a 20 20 20 20 20 20 50 52 49 4d 41 52    **      PRIMAR
24a0: 59 20 4b 45 59 2e 0a 20 20 20 20 2a 2f 0a 20 20  Y KEY..    */.  
24b0: 20 20 69 66 28 20 70 50 61 72 65 6e 74 2d 3e 69    if( pParent->i
24c0: 50 4b 65 79 3e 3d 30 20 29 7b 0a 20 20 20 20 20  PKey>=0 ){.     
24d0: 20 69 66 28 20 21 7a 4b 65 79 20 29 20 72 65 74   if( !zKey ) ret
24e0: 75 72 6e 20 30 3b 0a 20 20 20 20 20 20 69 66 28  urn 0;.      if(
24f0: 20 21 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70   !sqlite3StrICmp
2500: 28 70 50 61 72 65 6e 74 2d 3e 61 43 6f 6c 5b 70  (pParent->aCol[p
2510: 50 61 72 65 6e 74 2d 3e 69 50 4b 65 79 5d 2e 7a  Parent->iPKey].z
2520: 4e 61 6d 65 2c 20 7a 4b 65 79 29 20 29 20 72 65  Name, zKey) ) re
2530: 74 75 72 6e 20 30 3b 0a 20 20 20 20 7d 0a 20 20  turn 0;.    }.  
2540: 7d 65 6c 73 65 20 69 66 28 20 70 61 69 43 6f 6c  }else if( paiCol
2550: 20 29 7b 0a 20 20 20 20 61 73 73 65 72 74 28 20   ){.    assert( 
2560: 6e 43 6f 6c 3e 31 20 29 3b 0a 20 20 20 20 61 69  nCol>1 );.    ai
2570: 43 6f 6c 20 3d 20 28 69 6e 74 20 2a 29 73 71 6c  Col = (int *)sql
2580: 69 74 65 33 44 62 4d 61 6c 6c 6f 63 52 61 77 4e  ite3DbMallocRawN
2590: 4e 28 70 50 61 72 73 65 2d 3e 64 62 2c 20 6e 43  N(pParse->db, nC
25a0: 6f 6c 2a 73 69 7a 65 6f 66 28 69 6e 74 29 29 3b  ol*sizeof(int));
25b0: 0a 20 20 20 20 69 66 28 20 21 61 69 43 6f 6c 20  .    if( !aiCol 
25c0: 29 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 20 20  ) return 1;.    
25d0: 2a 70 61 69 43 6f 6c 20 3d 20 61 69 43 6f 6c 3b  *paiCol = aiCol;
25e0: 0a 20 20 7d 0a 0a 20 20 66 6f 72 28 70 49 64 78  .  }..  for(pIdx
25f0: 3d 70 50 61 72 65 6e 74 2d 3e 70 49 6e 64 65 78  =pParent->pIndex
2600: 3b 20 70 49 64 78 3b 20 70 49 64 78 3d 70 49 64  ; pIdx; pIdx=pId
2610: 78 2d 3e 70 4e 65 78 74 29 7b 0a 20 20 20 20 69  x->pNext){.    i
2620: 66 28 20 70 49 64 78 2d 3e 6e 4b 65 79 43 6f 6c  f( pIdx->nKeyCol
2630: 3d 3d 6e 43 6f 6c 20 26 26 20 49 73 55 6e 69 71  ==nCol && IsUniq
2640: 75 65 49 6e 64 65 78 28 70 49 64 78 29 20 26 26  ueIndex(pIdx) &&
2650: 20 70 49 64 78 2d 3e 70 50 61 72 74 49 64 78 57   pIdx->pPartIdxW
2660: 68 65 72 65 3d 3d 30 20 29 7b 20 0a 20 20 20 20  here==0 ){ .    
2670: 20 20 2f 2a 20 70 49 64 78 20 69 73 20 61 20 55    /* pIdx is a U
2680: 4e 49 51 55 45 20 69 6e 64 65 78 20 28 6f 72 20  NIQUE index (or 
2690: 61 20 50 52 49 4d 41 52 59 20 4b 45 59 29 20 61  a PRIMARY KEY) a
26a0: 6e 64 20 68 61 73 20 74 68 65 20 72 69 67 68 74  nd has the right
26b0: 20 6e 75 6d 62 65 72 0a 20 20 20 20 20 20 2a 2a   number.      **
26c0: 20 6f 66 20 63 6f 6c 75 6d 6e 73 2e 20 49 66 20   of columns. If 
26d0: 65 61 63 68 20 69 6e 64 65 78 65 64 20 63 6f 6c  each indexed col
26e0: 75 6d 6e 20 63 6f 72 72 65 73 70 6f 6e 64 73 20  umn corresponds 
26f0: 74 6f 20 61 20 66 6f 72 65 69 67 6e 20 6b 65 79  to a foreign key
2700: 0a 20 20 20 20 20 20 2a 2a 20 63 6f 6c 75 6d 6e  .      ** column
2710: 20 6f 66 20 70 46 4b 65 79 2c 20 74 68 65 6e 20   of pFKey, then 
2720: 74 68 69 73 20 69 6e 64 65 78 20 69 73 20 61 20  this index is a 
2730: 77 69 6e 6e 65 72 2e 20 20 2a 2f 0a 0a 20 20 20  winner.  */..   
2740: 20 20 20 69 66 28 20 7a 4b 65 79 3d 3d 30 20 29     if( zKey==0 )
2750: 7b 0a 20 20 20 20 20 20 20 20 2f 2a 20 49 66 20  {.        /* If 
2760: 7a 4b 65 79 20 69 73 20 4e 55 4c 4c 2c 20 74 68  zKey is NULL, th
2770: 65 6e 20 74 68 69 73 20 66 6f 72 65 69 67 6e 20  en this foreign 
2780: 6b 65 79 20 69 73 20 69 6d 70 6c 69 63 69 74 6c  key is implicitl
2790: 79 20 6d 61 70 70 65 64 20 74 6f 20 0a 20 20 20  y mapped to .   
27a0: 20 20 20 20 20 2a 2a 20 74 68 65 20 50 52 49 4d       ** the PRIM
27b0: 41 52 59 20 4b 45 59 20 6f 66 20 74 61 62 6c 65  ARY KEY of table
27c0: 20 70 50 61 72 65 6e 74 2e 20 54 68 65 20 50 52   pParent. The PR
27d0: 49 4d 41 52 59 20 4b 45 59 20 69 6e 64 65 78 20  IMARY KEY index 
27e0: 6d 61 79 20 62 65 20 0a 20 20 20 20 20 20 20 20  may be .        
27f0: 2a 2a 20 69 64 65 6e 74 69 66 69 65 64 20 62 79  ** identified by
2800: 20 74 68 65 20 74 65 73 74 2e 20 20 2a 2f 0a 20   the test.  */. 
2810: 20 20 20 20 20 20 20 69 66 28 20 49 73 50 72 69         if( IsPri
2820: 6d 61 72 79 4b 65 79 49 6e 64 65 78 28 70 49 64  maryKeyIndex(pId
2830: 78 29 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  x) ){.          
2840: 69 66 28 20 61 69 43 6f 6c 20 29 7b 0a 20 20 20  if( aiCol ){.   
2850: 20 20 20 20 20 20 20 20 20 69 6e 74 20 69 3b 0a           int i;.
2860: 20 20 20 20 20 20 20 20 20 20 20 20 66 6f 72 28              for(
2870: 69 3d 30 3b 20 69 3c 6e 43 6f 6c 3b 20 69 2b 2b  i=0; i<nCol; i++
2880: 29 20 61 69 43 6f 6c 5b 69 5d 20 3d 20 70 46 4b  ) aiCol[i] = pFK
2890: 65 79 2d 3e 61 43 6f 6c 5b 69 5d 2e 69 46 72 6f  ey->aCol[i].iFro
28a0: 6d 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20  m;.          }. 
28b0: 20 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a           break;.
28c0: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
28d0: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 2f  }else{.        /
28e0: 2a 20 49 66 20 7a 4b 65 79 20 69 73 20 6e 6f 6e  * If zKey is non
28f0: 2d 4e 55 4c 4c 2c 20 74 68 65 6e 20 74 68 69 73  -NULL, then this
2900: 20 66 6f 72 65 69 67 6e 20 6b 65 79 20 77 61 73   foreign key was
2910: 20 64 65 63 6c 61 72 65 64 20 74 6f 0a 20 20 20   declared to.   
2920: 20 20 20 20 20 2a 2a 20 6d 61 70 20 74 6f 20 61       ** map to a
2930: 6e 20 65 78 70 6c 69 63 69 74 20 6c 69 73 74 20  n explicit list 
2940: 6f 66 20 63 6f 6c 75 6d 6e 73 20 69 6e 20 74 61  of columns in ta
2950: 62 6c 65 20 70 50 61 72 65 6e 74 2e 20 43 68 65  ble pParent. Che
2960: 63 6b 20 69 66 20 74 68 69 73 0a 20 20 20 20 20  ck if this.     
2970: 20 20 20 2a 2a 20 69 6e 64 65 78 20 6d 61 74 63     ** index matc
2980: 68 65 73 20 74 68 6f 73 65 20 63 6f 6c 75 6d 6e  hes those column
2990: 73 2e 20 41 6c 73 6f 2c 20 63 68 65 63 6b 20 74  s. Also, check t
29a0: 68 61 74 20 74 68 65 20 69 6e 64 65 78 20 75 73  hat the index us
29b0: 65 73 0a 20 20 20 20 20 20 20 20 2a 2a 20 74 68  es.        ** th
29c0: 65 20 64 65 66 61 75 6c 74 20 63 6f 6c 6c 61 74  e default collat
29d0: 69 6f 6e 20 73 65 71 75 65 6e 63 65 73 20 66 6f  ion sequences fo
29e0: 72 20 65 61 63 68 20 63 6f 6c 75 6d 6e 2e 20 2a  r each column. *
29f0: 2f 0a 20 20 20 20 20 20 20 20 69 6e 74 20 69 2c  /.        int i,
2a00: 20 6a 3b 0a 20 20 20 20 20 20 20 20 66 6f 72 28   j;.        for(
2a10: 69 3d 30 3b 20 69 3c 6e 43 6f 6c 3b 20 69 2b 2b  i=0; i<nCol; i++
2a20: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 69 31 36  ){.          i16
2a30: 20 69 43 6f 6c 20 3d 20 70 49 64 78 2d 3e 61 69   iCol = pIdx->ai
2a40: 43 6f 6c 75 6d 6e 5b 69 5d 3b 20 20 20 20 20 2f  Column[i];     /
2a50: 2a 20 49 6e 64 65 78 20 6f 66 20 63 6f 6c 75 6d  * Index of colum
2a60: 6e 20 69 6e 20 70 61 72 65 6e 74 20 74 62 6c 20  n in parent tbl 
2a70: 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 63 6f 6e  */.          con
2a80: 73 74 20 63 68 61 72 20 2a 7a 44 66 6c 74 43 6f  st char *zDfltCo
2a90: 6c 6c 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f  ll;            /
2aa0: 2a 20 44 65 66 2e 20 63 6f 6c 6c 61 74 69 6f 6e  * Def. collation
2ab0: 20 66 6f 72 20 63 6f 6c 75 6d 6e 20 2a 2f 0a 20   for column */. 
2ac0: 20 20 20 20 20 20 20 20 20 63 68 61 72 20 2a 7a           char *z
2ad0: 49 64 78 43 6f 6c 3b 20 20 20 20 20 20 20 20 20  IdxCol;         
2ae0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 61             /* Na
2af0: 6d 65 20 6f 66 20 69 6e 64 65 78 65 64 20 63 6f  me of indexed co
2b00: 6c 75 6d 6e 20 2a 2f 0a 0a 20 20 20 20 20 20 20  lumn */..       
2b10: 20 20 20 69 66 28 20 69 43 6f 6c 3c 30 20 29 20     if( iCol<0 ) 
2b20: 62 72 65 61 6b 3b 20 2f 2a 20 4e 6f 20 66 6f 72  break; /* No for
2b30: 65 69 67 6e 20 6b 65 79 73 20 61 67 61 69 6e 73  eign keys agains
2b40: 74 20 65 78 70 72 65 73 73 69 6f 6e 20 69 6e 64  t expression ind
2b50: 65 78 65 73 20 2a 2f 0a 0a 20 20 20 20 20 20 20  exes */..       
2b60: 20 20 20 2f 2a 20 49 66 20 74 68 65 20 69 6e 64     /* If the ind
2b70: 65 78 20 75 73 65 73 20 61 20 63 6f 6c 6c 61 74  ex uses a collat
2b80: 69 6f 6e 20 73 65 71 75 65 6e 63 65 20 74 68 61  ion sequence tha
2b90: 74 20 69 73 20 64 69 66 66 65 72 65 6e 74 20 66  t is different f
2ba0: 72 6f 6d 0a 20 20 20 20 20 20 20 20 20 20 2a 2a  rom.          **
2bb0: 20 74 68 65 20 64 65 66 61 75 6c 74 20 63 6f 6c   the default col
2bc0: 6c 61 74 69 6f 6e 20 73 65 71 75 65 6e 63 65 20  lation sequence 
2bd0: 66 6f 72 20 74 68 65 20 63 6f 6c 75 6d 6e 2c 20  for the column, 
2be0: 74 68 69 73 20 69 6e 64 65 78 20 69 73 0a 20 20  this index is.  
2bf0: 20 20 20 20 20 20 20 20 2a 2a 20 75 6e 75 73 61          ** unusa
2c00: 62 6c 65 2e 20 42 61 69 6c 20 6f 75 74 20 65 61  ble. Bail out ea
2c10: 72 6c 79 20 69 6e 20 74 68 69 73 20 63 61 73 65  rly in this case
2c20: 2e 20 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20  .  */.          
2c30: 7a 44 66 6c 74 43 6f 6c 6c 20 3d 20 70 50 61 72  zDfltColl = pPar
2c40: 65 6e 74 2d 3e 61 43 6f 6c 5b 69 43 6f 6c 5d 2e  ent->aCol[iCol].
2c50: 7a 43 6f 6c 6c 3b 0a 20 20 20 20 20 20 20 20 20  zColl;.         
2c60: 20 69 66 28 20 21 7a 44 66 6c 74 43 6f 6c 6c 20   if( !zDfltColl 
2c70: 29 20 7a 44 66 6c 74 43 6f 6c 6c 20 3d 20 73 71  ) zDfltColl = sq
2c80: 6c 69 74 65 33 53 74 72 42 49 4e 41 52 59 3b 0a  lite3StrBINARY;.
2c90: 20 20 20 20 20 20 20 20 20 20 69 66 28 20 73 71            if( sq
2ca0: 6c 69 74 65 33 53 74 72 49 43 6d 70 28 70 49 64  lite3StrICmp(pId
2cb0: 78 2d 3e 61 7a 43 6f 6c 6c 5b 69 5d 2c 20 7a 44  x->azColl[i], zD
2cc0: 66 6c 74 43 6f 6c 6c 29 20 29 20 62 72 65 61 6b  fltColl) ) break
2cd0: 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 7a 49 64  ;..          zId
2ce0: 78 43 6f 6c 20 3d 20 70 50 61 72 65 6e 74 2d 3e  xCol = pParent->
2cf0: 61 43 6f 6c 5b 69 43 6f 6c 5d 2e 7a 4e 61 6d 65  aCol[iCol].zName
2d00: 3b 0a 20 20 20 20 20 20 20 20 20 20 66 6f 72 28  ;.          for(
2d10: 6a 3d 30 3b 20 6a 3c 6e 43 6f 6c 3b 20 6a 2b 2b  j=0; j<nCol; j++
2d20: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 69  ){.            i
2d30: 66 28 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d  f( sqlite3StrICm
2d40: 70 28 70 46 4b 65 79 2d 3e 61 43 6f 6c 5b 6a 5d  p(pFKey->aCol[j]
2d50: 2e 7a 43 6f 6c 2c 20 7a 49 64 78 43 6f 6c 29 3d  .zCol, zIdxCol)=
2d60: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  =0 ){.          
2d70: 20 20 20 20 69 66 28 20 61 69 43 6f 6c 20 29 20      if( aiCol ) 
2d80: 61 69 43 6f 6c 5b 69 5d 20 3d 20 70 46 4b 65 79  aiCol[i] = pFKey
2d90: 2d 3e 61 43 6f 6c 5b 6a 5d 2e 69 46 72 6f 6d 3b  ->aCol[j].iFrom;
2da0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 62  .              b
2db0: 72 65 61 6b 3b 0a 20 20 20 20 20 20 20 20 20 20  reak;.          
2dc0: 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 7d 0a    }.          }.
2dd0: 20 20 20 20 20 20 20 20 20 20 69 66 28 20 6a 3d            if( j=
2de0: 3d 6e 43 6f 6c 20 29 20 62 72 65 61 6b 3b 0a 20  =nCol ) break;. 
2df0: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
2e00: 20 69 66 28 20 69 3d 3d 6e 43 6f 6c 20 29 20 62   if( i==nCol ) b
2e10: 72 65 61 6b 3b 20 20 20 20 20 20 2f 2a 20 70 49  reak;      /* pI
2e20: 64 78 20 69 73 20 75 73 61 62 6c 65 20 2a 2f 0a  dx is usable */.
2e30: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20        }.    }.  
2e40: 7d 0a 0a 20 20 69 66 28 20 21 70 49 64 78 20 29  }..  if( !pIdx )
2e50: 7b 0a 20 20 20 20 69 66 28 20 21 70 50 61 72 73  {.    if( !pPars
2e60: 65 2d 3e 64 69 73 61 62 6c 65 54 72 69 67 67 65  e->disableTrigge
2e70: 72 73 20 29 7b 0a 20 20 20 20 20 20 73 71 6c 69  rs ){.      sqli
2e80: 74 65 33 45 72 72 6f 72 4d 73 67 28 70 50 61 72  te3ErrorMsg(pPar
2e90: 73 65 2c 0a 20 20 20 20 20 20 20 20 20 20 20 22  se,.           "
2ea0: 66 6f 72 65 69 67 6e 20 6b 65 79 20 6d 69 73 6d  foreign key mism
2eb0: 61 74 63 68 20 2d 20 5c 22 25 77 5c 22 20 72 65  atch - \"%w\" re
2ec0: 66 65 72 65 6e 63 69 6e 67 20 5c 22 25 77 5c 22  ferencing \"%w\"
2ed0: 22 2c 0a 20 20 20 20 20 20 20 20 20 20 20 70 46  ",.           pF
2ee0: 4b 65 79 2d 3e 70 46 72 6f 6d 2d 3e 7a 4e 61 6d  Key->pFrom->zNam
2ef0: 65 2c 20 70 46 4b 65 79 2d 3e 7a 54 6f 29 3b 0a  e, pFKey->zTo);.
2f00: 20 20 20 20 7d 0a 20 20 20 20 73 71 6c 69 74 65      }.    sqlite
2f10: 33 44 62 46 72 65 65 28 70 50 61 72 73 65 2d 3e  3DbFree(pParse->
2f20: 64 62 2c 20 61 69 43 6f 6c 29 3b 0a 20 20 20 20  db, aiCol);.    
2f30: 72 65 74 75 72 6e 20 31 3b 0a 20 20 7d 0a 0a 20  return 1;.  }.. 
2f40: 20 2a 70 70 49 64 78 20 3d 20 70 49 64 78 3b 0a   *ppIdx = pIdx;.
2f50: 20 20 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a 2f    return 0;.}../
2f60: 2a 0a 2a 2a 20 54 68 69 73 20 66 75 6e 63 74 69  *.** This functi
2f70: 6f 6e 20 69 73 20 63 61 6c 6c 65 64 20 77 68 65  on is called whe
2f80: 6e 20 61 20 72 6f 77 20 69 73 20 69 6e 73 65 72  n a row is inser
2f90: 74 65 64 20 69 6e 74 6f 20 6f 72 20 64 65 6c 65  ted into or dele
2fa0: 74 65 64 20 66 72 6f 6d 20 74 68 65 20 0a 2a 2a  ted from the .**
2fb0: 20 63 68 69 6c 64 20 74 61 62 6c 65 20 6f 66 20   child table of 
2fc0: 66 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73  foreign key cons
2fd0: 74 72 61 69 6e 74 20 70 46 4b 65 79 2e 20 49 66  traint pFKey. If
2fe0: 20 61 6e 20 53 51 4c 20 55 50 44 41 54 45 20 69   an SQL UPDATE i
2ff0: 73 20 65 78 65 63 75 74 65 64 20 0a 2a 2a 20 6f  s executed .** o
3000: 6e 20 74 68 65 20 63 68 69 6c 64 20 74 61 62 6c  n the child tabl
3010: 65 20 6f 66 20 70 46 4b 65 79 2c 20 74 68 69 73  e of pFKey, this
3020: 20 66 75 6e 63 74 69 6f 6e 20 69 73 20 69 6e 76   function is inv
3030: 6f 6b 65 64 20 74 77 69 63 65 20 66 6f 72 20 65  oked twice for e
3040: 61 63 68 20 72 6f 77 0a 2a 2a 20 61 66 66 65 63  ach row.** affec
3050: 74 65 64 20 2d 20 6f 6e 63 65 20 74 6f 20 22 64  ted - once to "d
3060: 65 6c 65 74 65 22 20 74 68 65 20 6f 6c 64 20 72  elete" the old r
3070: 6f 77 2c 20 61 6e 64 20 74 68 65 6e 20 61 67 61  ow, and then aga
3080: 69 6e 20 74 6f 20 22 69 6e 73 65 72 74 22 20 74  in to "insert" t
3090: 68 65 0a 2a 2a 20 6e 65 77 20 72 6f 77 2e 0a 2a  he.** new row..*
30a0: 2a 0a 2a 2a 20 45 61 63 68 20 74 69 6d 65 20 69  *.** Each time i
30b0: 74 20 69 73 20 63 61 6c 6c 65 64 2c 20 74 68 69  t is called, thi
30c0: 73 20 66 75 6e 63 74 69 6f 6e 20 67 65 6e 65 72  s function gener
30d0: 61 74 65 73 20 56 44 42 45 20 63 6f 64 65 20 74  ates VDBE code t
30e0: 6f 20 6c 6f 63 61 74 65 20 74 68 65 0a 2a 2a 20  o locate the.** 
30f0: 72 6f 77 20 69 6e 20 74 68 65 20 70 61 72 65 6e  row in the paren
3100: 74 20 74 61 62 6c 65 20 74 68 61 74 20 63 6f 72  t table that cor
3110: 72 65 73 70 6f 6e 64 73 20 74 6f 20 74 68 65 20  responds to the 
3120: 72 6f 77 20 62 65 69 6e 67 20 69 6e 73 65 72 74  row being insert
3130: 65 64 20 69 6e 74 6f 20 0a 2a 2a 20 6f 72 20 64  ed into .** or d
3140: 65 6c 65 74 65 64 20 66 72 6f 6d 20 74 68 65 20  eleted from the 
3150: 63 68 69 6c 64 20 74 61 62 6c 65 2e 20 49 66 20  child table. If 
3160: 74 68 65 20 70 61 72 65 6e 74 20 72 6f 77 20 63  the parent row c
3170: 61 6e 20 62 65 20 66 6f 75 6e 64 2c 20 6e 6f 20  an be found, no 
3180: 0a 2a 2a 20 73 70 65 63 69 61 6c 20 61 63 74 69  .** special acti
3190: 6f 6e 20 69 73 20 74 61 6b 65 6e 2e 20 4f 74 68  on is taken. Oth
31a0: 65 72 77 69 73 65 2c 20 69 66 20 74 68 65 20 70  erwise, if the p
31b0: 61 72 65 6e 74 20 72 6f 77 20 63 61 6e 20 2a 6e  arent row can *n
31c0: 6f 74 2a 20 62 65 0a 2a 2a 20 66 6f 75 6e 64 20  ot* be.** found 
31d0: 69 6e 20 74 68 65 20 70 61 72 65 6e 74 20 74 61  in the parent ta
31e0: 62 6c 65 3a 0a 2a 2a 0a 2a 2a 20 20 20 4f 70 65  ble:.**.**   Ope
31f0: 72 61 74 69 6f 6e 20 7c 20 46 4b 20 74 79 70 65  ration | FK type
3200: 20 20 20 7c 20 41 63 74 69 6f 6e 20 74 61 6b 65     | Action take
3210: 6e 0a 2a 2a 20 20 20 2d 2d 2d 2d 2d 2d 2d 2d 2d  n.**   ---------
3220: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3230: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3240: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3250: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3260: 2d 0a 2a 2a 20 20 20 49 4e 53 45 52 54 20 20 20  -.**   INSERT   
3270: 20 20 20 69 6d 6d 65 64 69 61 74 65 20 20 20 49     immediate   I
3280: 6e 63 72 65 6d 65 6e 74 20 74 68 65 20 22 69 6d  ncrement the "im
3290: 6d 65 64 69 61 74 65 20 63 6f 6e 73 74 72 61 69  mediate constrai
32a0: 6e 74 20 63 6f 75 6e 74 65 72 22 2e 0a 2a 2a 0a  nt counter"..**.
32b0: 2a 2a 20 20 20 44 45 4c 45 54 45 20 20 20 20 20  **   DELETE     
32c0: 20 69 6d 6d 65 64 69 61 74 65 20 20 20 44 65 63   immediate   Dec
32d0: 72 65 6d 65 6e 74 20 74 68 65 20 22 69 6d 6d 65  rement the "imme
32e0: 64 69 61 74 65 20 63 6f 6e 73 74 72 61 69 6e 74  diate constraint
32f0: 20 63 6f 75 6e 74 65 72 22 2e 0a 2a 2a 0a 2a 2a   counter"..**.**
3300: 20 20 20 49 4e 53 45 52 54 20 20 20 20 20 20 64     INSERT      d
3310: 65 66 65 72 72 65 64 20 20 20 20 49 6e 63 72 65  eferred    Incre
3320: 6d 65 6e 74 20 74 68 65 20 22 64 65 66 65 72 72  ment the "deferr
3330: 65 64 20 63 6f 6e 73 74 72 61 69 6e 74 20 63 6f  ed constraint co
3340: 75 6e 74 65 72 22 2e 0a 2a 2a 0a 2a 2a 20 20 20  unter"..**.**   
3350: 44 45 4c 45 54 45 20 20 20 20 20 20 64 65 66 65  DELETE      defe
3360: 72 72 65 64 20 20 20 20 44 65 63 72 65 6d 65 6e  rred    Decremen
3370: 74 20 74 68 65 20 22 64 65 66 65 72 72 65 64 20  t the "deferred 
3380: 63 6f 6e 73 74 72 61 69 6e 74 20 63 6f 75 6e 74  constraint count
3390: 65 72 22 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 73 65  er"..**.** These
33a0: 20 6f 70 65 72 61 74 69 6f 6e 73 20 61 72 65 20   operations are 
33b0: 69 64 65 6e 74 69 66 69 65 64 20 69 6e 20 74 68  identified in th
33c0: 65 20 63 6f 6d 6d 65 6e 74 20 61 74 20 74 68 65  e comment at the
33d0: 20 74 6f 70 20 6f 66 20 74 68 69 73 20 66 69 6c   top of this fil
33e0: 65 20 0a 2a 2a 20 28 66 6b 65 79 2e 63 29 20 61  e .** (fkey.c) a
33f0: 73 20 22 49 2e 31 22 20 61 6e 64 20 22 44 2e 31  s "I.1" and "D.1
3400: 22 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69  "..*/.static voi
3410: 64 20 66 6b 4c 6f 6f 6b 75 70 50 61 72 65 6e 74  d fkLookupParent
3420: 28 0a 20 20 50 61 72 73 65 20 2a 70 50 61 72 73  (.  Parse *pPars
3430: 65 2c 20 20 20 20 20 20 20 20 2f 2a 20 50 61 72  e,        /* Par
3440: 73 65 20 63 6f 6e 74 65 78 74 20 2a 2f 0a 20 20  se context */.  
3450: 69 6e 74 20 69 44 62 2c 20 20 20 20 20 20 20 20  int iDb,        
3460: 20 20 20 20 20 20 2f 2a 20 49 6e 64 65 78 20 6f        /* Index o
3470: 66 20 64 61 74 61 62 61 73 65 20 68 6f 75 73 69  f database housi
3480: 6e 67 20 70 54 61 62 20 2a 2f 0a 20 20 54 61 62  ng pTab */.  Tab
3490: 6c 65 20 2a 70 54 61 62 2c 20 20 20 20 20 20 20  le *pTab,       
34a0: 20 20 20 2f 2a 20 50 61 72 65 6e 74 20 74 61 62     /* Parent tab
34b0: 6c 65 20 6f 66 20 46 4b 20 70 46 4b 65 79 20 2a  le of FK pFKey *
34c0: 2f 0a 20 20 49 6e 64 65 78 20 2a 70 49 64 78 2c  /.  Index *pIdx,
34d0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 55 6e 69            /* Uni
34e0: 71 75 65 20 69 6e 64 65 78 20 6f 6e 20 70 61 72  que index on par
34f0: 65 6e 74 20 6b 65 79 20 63 6f 6c 75 6d 6e 73 20  ent key columns 
3500: 69 6e 20 70 54 61 62 20 2a 2f 0a 20 20 46 4b 65  in pTab */.  FKe
3510: 79 20 2a 70 46 4b 65 79 2c 20 20 20 20 20 20 20  y *pFKey,       
3520: 20 20 20 2f 2a 20 46 6f 72 65 69 67 6e 20 6b 65     /* Foreign ke
3530: 79 20 63 6f 6e 73 74 72 61 69 6e 74 20 2a 2f 0a  y constraint */.
3540: 20 20 69 6e 74 20 2a 61 69 43 6f 6c 2c 20 20 20    int *aiCol,   
3550: 20 20 20 20 20 20 20 20 2f 2a 20 4d 61 70 20 66          /* Map f
3560: 72 6f 6d 20 70 61 72 65 6e 74 20 6b 65 79 20 63  rom parent key c
3570: 6f 6c 75 6d 6e 73 20 74 6f 20 63 68 69 6c 64 20  olumns to child 
3580: 74 61 62 6c 65 20 63 6f 6c 75 6d 6e 73 20 2a 2f  table columns */
3590: 0a 20 20 69 6e 74 20 72 65 67 44 61 74 61 2c 20  .  int regData, 
35a0: 20 20 20 20 20 20 20 20 20 2f 2a 20 41 64 64 72           /* Addr
35b0: 65 73 73 20 6f 66 20 61 72 72 61 79 20 63 6f 6e  ess of array con
35c0: 74 61 69 6e 69 6e 67 20 63 68 69 6c 64 20 74 61  taining child ta
35d0: 62 6c 65 20 72 6f 77 20 2a 2f 0a 20 20 69 6e 74  ble row */.  int
35e0: 20 6e 49 6e 63 72 2c 20 20 20 20 20 20 20 20 20   nIncr,         
35f0: 20 20 20 2f 2a 20 49 6e 63 72 65 6d 65 6e 74 20     /* Increment 
3600: 63 6f 6e 73 74 72 61 69 6e 74 20 63 6f 75 6e 74  constraint count
3610: 65 72 20 62 79 20 74 68 69 73 20 2a 2f 0a 20 20  er by this */.  
3620: 69 6e 74 20 69 73 49 67 6e 6f 72 65 20 20 20 20  int isIgnore    
3630: 20 20 20 20 20 20 2f 2a 20 49 66 20 74 72 75 65        /* If true
3640: 2c 20 70 72 65 74 65 6e 64 20 70 54 61 62 20 63  , pretend pTab c
3650: 6f 6e 74 61 69 6e 73 20 61 6c 6c 20 4e 55 4c 4c  ontains all NULL
3660: 20 76 61 6c 75 65 73 20 2a 2f 0a 29 7b 0a 20 20   values */.){.  
3670: 69 6e 74 20 69 3b 20 20 20 20 20 20 20 20 20 20  int i;          
3680: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3690: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 49 74 65            /* Ite
36a0: 72 61 74 6f 72 20 76 61 72 69 61 62 6c 65 20 2a  rator variable *
36b0: 2f 0a 20 20 56 64 62 65 20 2a 76 20 3d 20 73 71  /.  Vdbe *v = sq
36c0: 6c 69 74 65 33 47 65 74 56 64 62 65 28 70 50 61  lite3GetVdbe(pPa
36d0: 72 73 65 29 3b 20 20 20 20 20 20 20 20 20 2f 2a  rse);         /*
36e0: 20 56 64 62 65 20 74 6f 20 61 64 64 20 63 6f 64   Vdbe to add cod
36f0: 65 20 74 6f 20 2a 2f 0a 20 20 69 6e 74 20 69 43  e to */.  int iC
3700: 75 72 20 3d 20 70 50 61 72 73 65 2d 3e 6e 54 61  ur = pParse->nTa
3710: 62 20 2d 20 31 3b 20 20 20 20 20 20 20 20 20 20  b - 1;          
3720: 20 20 20 20 2f 2a 20 43 75 72 73 6f 72 20 6e 75      /* Cursor nu
3730: 6d 62 65 72 20 74 6f 20 75 73 65 20 2a 2f 0a 20  mber to use */. 
3740: 20 69 6e 74 20 69 4f 6b 20 3d 20 73 71 6c 69 74   int iOk = sqlit
3750: 65 33 56 64 62 65 4d 61 6b 65 4c 61 62 65 6c 28  e3VdbeMakeLabel(
3760: 70 50 61 72 73 65 29 3b 20 20 20 2f 2a 20 6a 75  pParse);   /* ju
3770: 6d 70 20 68 65 72 65 20 69 66 20 70 61 72 65 6e  mp here if paren
3780: 74 20 6b 65 79 20 66 6f 75 6e 64 20 2a 2f 0a 0a  t key found */..
3790: 20 20 73 71 6c 69 74 65 33 56 64 62 65 56 65 72    sqlite3VdbeVer
37a0: 69 66 79 41 62 6f 72 74 61 62 6c 65 28 76 2c 0a  ifyAbortable(v,.
37b0: 20 20 20 20 28 21 70 46 4b 65 79 2d 3e 69 73 44      (!pFKey->isD
37c0: 65 66 65 72 72 65 64 0a 20 20 20 20 20 20 26 26  eferred.      &&
37d0: 20 21 28 70 50 61 72 73 65 2d 3e 64 62 2d 3e 66   !(pParse->db->f
37e0: 6c 61 67 73 20 26 20 53 51 4c 49 54 45 5f 44 65  lags & SQLITE_De
37f0: 66 65 72 46 4b 73 29 0a 20 20 20 20 20 20 26 26  ferFKs).      &&
3800: 20 21 70 50 61 72 73 65 2d 3e 70 54 6f 70 6c 65   !pParse->pTople
3810: 76 65 6c 20 0a 20 20 20 20 20 20 26 26 20 21 70  vel .      && !p
3820: 50 61 72 73 65 2d 3e 69 73 4d 75 6c 74 69 57 72  Parse->isMultiWr
3830: 69 74 65 29 20 3f 20 4f 45 5f 41 62 6f 72 74 20  ite) ? OE_Abort 
3840: 3a 20 4f 45 5f 49 67 6e 6f 72 65 29 3b 0a 0a 20  : OE_Ignore);.. 
3850: 20 2f 2a 20 49 66 20 6e 49 6e 63 72 20 69 73 20   /* If nIncr is 
3860: 6c 65 73 73 20 74 68 61 6e 20 7a 65 72 6f 2c 20  less than zero, 
3870: 74 68 65 6e 20 63 68 65 63 6b 20 61 74 20 72 75  then check at ru
3880: 6e 74 69 6d 65 20 69 66 20 74 68 65 72 65 20 61  ntime if there a
3890: 72 65 20 61 6e 79 0a 20 20 2a 2a 20 6f 75 74 73  re any.  ** outs
38a0: 74 61 6e 64 69 6e 67 20 63 6f 6e 73 74 72 61 69  tanding constrai
38b0: 6e 74 73 20 74 6f 20 72 65 73 6f 6c 76 65 2e 20  nts to resolve. 
38c0: 49 66 20 74 68 65 72 65 20 61 72 65 20 6e 6f 74  If there are not
38d0: 2c 20 74 68 65 72 65 20 69 73 20 6e 6f 20 6e 65  , there is no ne
38e0: 65 64 0a 20 20 2a 2a 20 74 6f 20 63 68 65 63 6b  ed.  ** to check
38f0: 20 69 66 20 64 65 6c 65 74 69 6e 67 20 74 68 69   if deleting thi
3900: 73 20 72 6f 77 20 72 65 73 6f 6c 76 65 73 20 61  s row resolves a
3910: 6e 79 20 6f 75 74 73 74 61 6e 64 69 6e 67 20 76  ny outstanding v
3920: 69 6f 6c 61 74 69 6f 6e 73 2e 0a 20 20 2a 2a 0a  iolations..  **.
3930: 20 20 2a 2a 20 43 68 65 63 6b 20 69 66 20 61 6e    ** Check if an
3940: 79 20 6f 66 20 74 68 65 20 6b 65 79 20 63 6f 6c  y of the key col
3950: 75 6d 6e 73 20 69 6e 20 74 68 65 20 63 68 69 6c  umns in the chil
3960: 64 20 74 61 62 6c 65 20 72 6f 77 20 61 72 65 20  d table row are 
3970: 4e 55 4c 4c 2e 20 49 66 20 0a 20 20 2a 2a 20 61  NULL. If .  ** a
3980: 6e 79 20 61 72 65 2c 20 74 68 65 6e 20 74 68 65  ny are, then the
3990: 20 63 6f 6e 73 74 72 61 69 6e 74 20 69 73 20 63   constraint is c
39a0: 6f 6e 73 69 64 65 72 65 64 20 73 61 74 69 73 66  onsidered satisf
39b0: 69 65 64 2e 20 4e 6f 20 6e 65 65 64 20 74 6f 20  ied. No need to 
39c0: 0a 20 20 2a 2a 20 73 65 61 72 63 68 20 66 6f 72  .  ** search for
39d0: 20 61 20 6d 61 74 63 68 69 6e 67 20 72 6f 77 20   a matching row 
39e0: 69 6e 20 74 68 65 20 70 61 72 65 6e 74 20 74 61  in the parent ta
39f0: 62 6c 65 2e 20 20 2a 2f 0a 20 20 69 66 28 20 6e  ble.  */.  if( n
3a00: 49 6e 63 72 3c 30 20 29 7b 0a 20 20 20 20 73 71  Incr<0 ){.    sq
3a10: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32 28  lite3VdbeAddOp2(
3a20: 76 2c 20 4f 50 5f 46 6b 49 66 5a 65 72 6f 2c 20  v, OP_FkIfZero, 
3a30: 70 46 4b 65 79 2d 3e 69 73 44 65 66 65 72 72 65  pFKey->isDeferre
3a40: 64 2c 20 69 4f 6b 29 3b 0a 20 20 20 20 56 64 62  d, iOk);.    Vdb
3a50: 65 43 6f 76 65 72 61 67 65 28 76 29 3b 0a 20 20  eCoverage(v);.  
3a60: 7d 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70  }.  for(i=0; i<p
3a70: 46 4b 65 79 2d 3e 6e 43 6f 6c 3b 20 69 2b 2b 29  FKey->nCol; i++)
3a80: 7b 0a 20 20 20 20 69 6e 74 20 69 52 65 67 20 3d  {.    int iReg =
3a90: 20 61 69 43 6f 6c 5b 69 5d 20 2b 20 72 65 67 44   aiCol[i] + regD
3aa0: 61 74 61 20 2b 20 31 3b 0a 20 20 20 20 73 71 6c  ata + 1;.    sql
3ab0: 69 74 65 33 56 64 62 65 41 64 64 4f 70 32 28 76  ite3VdbeAddOp2(v
3ac0: 2c 20 4f 50 5f 49 73 4e 75 6c 6c 2c 20 69 52 65  , OP_IsNull, iRe
3ad0: 67 2c 20 69 4f 6b 29 3b 20 56 64 62 65 43 6f 76  g, iOk); VdbeCov
3ae0: 65 72 61 67 65 28 76 29 3b 0a 20 20 7d 0a 0a 20  erage(v);.  }.. 
3af0: 20 69 66 28 20 69 73 49 67 6e 6f 72 65 3d 3d 30   if( isIgnore==0
3b00: 20 29 7b 0a 20 20 20 20 69 66 28 20 70 49 64 78   ){.    if( pIdx
3b10: 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 2f 2a 20  ==0 ){.      /* 
3b20: 49 66 20 70 49 64 78 20 69 73 20 4e 55 4c 4c 2c  If pIdx is NULL,
3b30: 20 74 68 65 6e 20 74 68 65 20 70 61 72 65 6e 74   then the parent
3b40: 20 6b 65 79 20 69 73 20 74 68 65 20 49 4e 54 45   key is the INTE
3b50: 47 45 52 20 50 52 49 4d 41 52 59 20 4b 45 59 0a  GER PRIMARY KEY.
3b60: 20 20 20 20 20 20 2a 2a 20 63 6f 6c 75 6d 6e 20        ** column 
3b70: 6f 66 20 74 68 65 20 70 61 72 65 6e 74 20 74 61  of the parent ta
3b80: 62 6c 65 20 28 74 61 62 6c 65 20 70 54 61 62 29  ble (table pTab)
3b90: 2e 20 20 2a 2f 0a 20 20 20 20 20 20 69 6e 74 20  .  */.      int 
3ba0: 69 4d 75 73 74 42 65 49 6e 74 3b 20 20 20 20 20  iMustBeInt;     
3bb0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 41 64 64            /* Add
3bc0: 72 65 73 73 20 6f 66 20 4d 75 73 74 42 65 49 6e  ress of MustBeIn
3bd0: 74 20 69 6e 73 74 72 75 63 74 69 6f 6e 20 2a 2f  t instruction */
3be0: 0a 20 20 20 20 20 20 69 6e 74 20 72 65 67 54 65  .      int regTe
3bf0: 6d 70 20 3d 20 73 71 6c 69 74 65 33 47 65 74 54  mp = sqlite3GetT
3c00: 65 6d 70 52 65 67 28 70 50 61 72 73 65 29 3b 0a  empReg(pParse);.
3c10: 20 20 0a 20 20 20 20 20 20 2f 2a 20 49 6e 76 6f    .      /* Invo
3c20: 6b 65 20 4d 75 73 74 42 65 49 6e 74 20 74 6f 20  ke MustBeInt to 
3c30: 63 6f 65 72 63 65 20 74 68 65 20 63 68 69 6c 64  coerce the child
3c40: 20 6b 65 79 20 76 61 6c 75 65 20 74 6f 20 61 6e   key value to an
3c50: 20 69 6e 74 65 67 65 72 20 28 69 2e 65 2e 20 0a   integer (i.e. .
3c60: 20 20 20 20 20 20 2a 2a 20 61 70 70 6c 79 20 74        ** apply t
3c70: 68 65 20 61 66 66 69 6e 69 74 79 20 6f 66 20 74  he affinity of t
3c80: 68 65 20 70 61 72 65 6e 74 20 6b 65 79 29 2e 20  he parent key). 
3c90: 49 66 20 74 68 69 73 20 66 61 69 6c 73 2c 20 74  If this fails, t
3ca0: 68 65 6e 20 74 68 65 72 65 0a 20 20 20 20 20 20  hen there.      
3cb0: 2a 2a 20 69 73 20 6e 6f 20 6d 61 74 63 68 69 6e  ** is no matchin
3cc0: 67 20 70 61 72 65 6e 74 20 6b 65 79 2e 20 42 65  g parent key. Be
3cd0: 66 6f 72 65 20 75 73 69 6e 67 20 4d 75 73 74 42  fore using MustB
3ce0: 65 49 6e 74 2c 20 6d 61 6b 65 20 61 20 63 6f 70  eInt, make a cop
3cf0: 79 20 6f 66 0a 20 20 20 20 20 20 2a 2a 20 74 68  y of.      ** th
3d00: 65 20 76 61 6c 75 65 2e 20 4f 74 68 65 72 77 69  e value. Otherwi
3d10: 73 65 2c 20 74 68 65 20 76 61 6c 75 65 20 69 6e  se, the value in
3d20: 73 65 72 74 65 64 20 69 6e 74 6f 20 74 68 65 20  serted into the 
3d30: 63 68 69 6c 64 20 6b 65 79 20 63 6f 6c 75 6d 6e  child key column
3d40: 0a 20 20 20 20 20 20 2a 2a 20 77 69 6c 6c 20 68  .      ** will h
3d50: 61 76 65 20 49 4e 54 45 47 45 52 20 61 66 66 69  ave INTEGER affi
3d60: 6e 69 74 79 20 61 70 70 6c 69 65 64 20 74 6f 20  nity applied to 
3d70: 69 74 2c 20 77 68 69 63 68 20 6d 61 79 20 6e 6f  it, which may no
3d80: 74 20 62 65 20 63 6f 72 72 65 63 74 2e 20 20 2a  t be correct.  *
3d90: 2f 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56  /.      sqlite3V
3da0: 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f  dbeAddOp2(v, OP_
3db0: 53 43 6f 70 79 2c 20 61 69 43 6f 6c 5b 30 5d 2b  SCopy, aiCol[0]+
3dc0: 31 2b 72 65 67 44 61 74 61 2c 20 72 65 67 54 65  1+regData, regTe
3dd0: 6d 70 29 3b 0a 20 20 20 20 20 20 69 4d 75 73 74  mp);.      iMust
3de0: 42 65 49 6e 74 20 3d 20 73 71 6c 69 74 65 33 56  BeInt = sqlite3V
3df0: 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f  dbeAddOp2(v, OP_
3e00: 4d 75 73 74 42 65 49 6e 74 2c 20 72 65 67 54 65  MustBeInt, regTe
3e10: 6d 70 2c 20 30 29 3b 0a 20 20 20 20 20 20 56 64  mp, 0);.      Vd
3e20: 62 65 43 6f 76 65 72 61 67 65 28 76 29 3b 0a 20  beCoverage(v);. 
3e30: 20 0a 20 20 20 20 20 20 2f 2a 20 49 66 20 74 68   .      /* If th
3e40: 65 20 70 61 72 65 6e 74 20 74 61 62 6c 65 20 69  e parent table i
3e50: 73 20 74 68 65 20 73 61 6d 65 20 61 73 20 74 68  s the same as th
3e60: 65 20 63 68 69 6c 64 20 74 61 62 6c 65 2c 20 61  e child table, a
3e70: 6e 64 20 77 65 20 61 72 65 20 61 62 6f 75 74 0a  nd we are about.
3e80: 20 20 20 20 20 20 2a 2a 20 74 6f 20 69 6e 63 72        ** to incr
3e90: 65 6d 65 6e 74 20 74 68 65 20 63 6f 6e 73 74 72  ement the constr
3ea0: 61 69 6e 74 2d 63 6f 75 6e 74 65 72 20 28 69 2e  aint-counter (i.
3eb0: 65 2e 20 74 68 69 73 20 69 73 20 61 6e 20 49 4e  e. this is an IN
3ec0: 53 45 52 54 20 6f 70 65 72 61 74 69 6f 6e 29 2c  SERT operation),
3ed0: 0a 20 20 20 20 20 20 2a 2a 20 74 68 65 6e 20 63  .      ** then c
3ee0: 68 65 63 6b 20 69 66 20 74 68 65 20 72 6f 77 20  heck if the row 
3ef0: 62 65 69 6e 67 20 69 6e 73 65 72 74 65 64 20 6d  being inserted m
3f00: 61 74 63 68 65 73 20 69 74 73 65 6c 66 2e 20 49  atches itself. I
3f10: 66 20 73 6f 2c 20 64 6f 20 6e 6f 74 0a 20 20 20  f so, do not.   
3f20: 20 20 20 2a 2a 20 69 6e 63 72 65 6d 65 6e 74 20     ** increment 
3f30: 74 68 65 20 63 6f 6e 73 74 72 61 69 6e 74 2d 63  the constraint-c
3f40: 6f 75 6e 74 65 72 2e 20 20 2a 2f 0a 20 20 20 20  ounter.  */.    
3f50: 20 20 69 66 28 20 70 54 61 62 3d 3d 70 46 4b 65    if( pTab==pFKe
3f60: 79 2d 3e 70 46 72 6f 6d 20 26 26 20 6e 49 6e 63  y->pFrom && nInc
3f70: 72 3d 3d 31 20 29 7b 0a 20 20 20 20 20 20 20 20  r==1 ){.        
3f80: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
3f90: 33 28 76 2c 20 4f 50 5f 45 71 2c 20 72 65 67 44  3(v, OP_Eq, regD
3fa0: 61 74 61 2c 20 69 4f 6b 2c 20 72 65 67 54 65 6d  ata, iOk, regTem
3fb0: 70 29 3b 20 56 64 62 65 43 6f 76 65 72 61 67 65  p); VdbeCoverage
3fc0: 28 76 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c  (v);.        sql
3fd0: 69 74 65 33 56 64 62 65 43 68 61 6e 67 65 50 35  ite3VdbeChangeP5
3fe0: 28 76 2c 20 53 51 4c 49 54 45 5f 4e 4f 54 4e 55  (v, SQLITE_NOTNU
3ff0: 4c 4c 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 0a  LL);.      }.  .
4000: 20 20 20 20 20 20 73 71 6c 69 74 65 33 4f 70 65        sqlite3Ope
4010: 6e 54 61 62 6c 65 28 70 50 61 72 73 65 2c 20 69  nTable(pParse, i
4020: 43 75 72 2c 20 69 44 62 2c 20 70 54 61 62 2c 20  Cur, iDb, pTab, 
4030: 4f 50 5f 4f 70 65 6e 52 65 61 64 29 3b 0a 20 20  OP_OpenRead);.  
4040: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
4050: 64 64 4f 70 33 28 76 2c 20 4f 50 5f 4e 6f 74 45  ddOp3(v, OP_NotE
4060: 78 69 73 74 73 2c 20 69 43 75 72 2c 20 30 2c 20  xists, iCur, 0, 
4070: 72 65 67 54 65 6d 70 29 3b 20 56 64 62 65 43 6f  regTemp); VdbeCo
4080: 76 65 72 61 67 65 28 76 29 3b 0a 20 20 20 20 20  verage(v);.     
4090: 20 73 71 6c 69 74 65 33 56 64 62 65 47 6f 74 6f   sqlite3VdbeGoto
40a0: 28 76 2c 20 69 4f 6b 29 3b 0a 20 20 20 20 20 20  (v, iOk);.      
40b0: 73 71 6c 69 74 65 33 56 64 62 65 4a 75 6d 70 48  sqlite3VdbeJumpH
40c0: 65 72 65 28 76 2c 20 73 71 6c 69 74 65 33 56 64  ere(v, sqlite3Vd
40d0: 62 65 43 75 72 72 65 6e 74 41 64 64 72 28 76 29  beCurrentAddr(v)
40e0: 2d 32 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  -2);.      sqlit
40f0: 65 33 56 64 62 65 4a 75 6d 70 48 65 72 65 28 76  e3VdbeJumpHere(v
4100: 2c 20 69 4d 75 73 74 42 65 49 6e 74 29 3b 0a 20  , iMustBeInt);. 
4110: 20 20 20 20 20 73 71 6c 69 74 65 33 52 65 6c 65       sqlite3Rele
4120: 61 73 65 54 65 6d 70 52 65 67 28 70 50 61 72 73  aseTempReg(pPars
4130: 65 2c 20 72 65 67 54 65 6d 70 29 3b 0a 20 20 20  e, regTemp);.   
4140: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 69 6e   }else{.      in
4150: 74 20 6e 43 6f 6c 20 3d 20 70 46 4b 65 79 2d 3e  t nCol = pFKey->
4160: 6e 43 6f 6c 3b 0a 20 20 20 20 20 20 69 6e 74 20  nCol;.      int 
4170: 72 65 67 54 65 6d 70 20 3d 20 73 71 6c 69 74 65  regTemp = sqlite
4180: 33 47 65 74 54 65 6d 70 52 61 6e 67 65 28 70 50  3GetTempRange(pP
4190: 61 72 73 65 2c 20 6e 43 6f 6c 29 3b 0a 20 20 20  arse, nCol);.   
41a0: 20 20 20 69 6e 74 20 72 65 67 52 65 63 20 3d 20     int regRec = 
41b0: 73 71 6c 69 74 65 33 47 65 74 54 65 6d 70 52 65  sqlite3GetTempRe
41c0: 67 28 70 50 61 72 73 65 29 3b 0a 20 20 0a 20 20  g(pParse);.  .  
41d0: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
41e0: 64 64 4f 70 33 28 76 2c 20 4f 50 5f 4f 70 65 6e  ddOp3(v, OP_Open
41f0: 52 65 61 64 2c 20 69 43 75 72 2c 20 70 49 64 78  Read, iCur, pIdx
4200: 2d 3e 74 6e 75 6d 2c 20 69 44 62 29 3b 0a 20 20  ->tnum, iDb);.  
4210: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 53      sqlite3VdbeS
4220: 65 74 50 34 4b 65 79 49 6e 66 6f 28 70 50 61 72  etP4KeyInfo(pPar
4230: 73 65 2c 20 70 49 64 78 29 3b 0a 20 20 20 20 20  se, pIdx);.     
4240: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 6e 43 6f 6c   for(i=0; i<nCol
4250: 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20  ; i++){.        
4260: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
4270: 32 28 76 2c 20 4f 50 5f 43 6f 70 79 2c 20 61 69  2(v, OP_Copy, ai
4280: 43 6f 6c 5b 69 5d 2b 31 2b 72 65 67 44 61 74 61  Col[i]+1+regData
4290: 2c 20 72 65 67 54 65 6d 70 2b 69 29 3b 0a 20 20  , regTemp+i);.  
42a0: 20 20 20 20 7d 0a 20 20 0a 20 20 20 20 20 20 2f      }.  .      /
42b0: 2a 20 49 66 20 74 68 65 20 70 61 72 65 6e 74 20  * If the parent 
42c0: 74 61 62 6c 65 20 69 73 20 74 68 65 20 73 61 6d  table is the sam
42d0: 65 20 61 73 20 74 68 65 20 63 68 69 6c 64 20 74  e as the child t
42e0: 61 62 6c 65 2c 20 61 6e 64 20 77 65 20 61 72 65  able, and we are
42f0: 20 61 62 6f 75 74 0a 20 20 20 20 20 20 2a 2a 20   about.      ** 
4300: 74 6f 20 69 6e 63 72 65 6d 65 6e 74 20 74 68 65  to increment the
4310: 20 63 6f 6e 73 74 72 61 69 6e 74 2d 63 6f 75 6e   constraint-coun
4320: 74 65 72 20 28 69 2e 65 2e 20 74 68 69 73 20 69  ter (i.e. this i
4330: 73 20 61 6e 20 49 4e 53 45 52 54 20 6f 70 65 72  s an INSERT oper
4340: 61 74 69 6f 6e 29 2c 0a 20 20 20 20 20 20 2a 2a  ation),.      **
4350: 20 74 68 65 6e 20 63 68 65 63 6b 20 69 66 20 74   then check if t
4360: 68 65 20 72 6f 77 20 62 65 69 6e 67 20 69 6e 73  he row being ins
4370: 65 72 74 65 64 20 6d 61 74 63 68 65 73 20 69 74  erted matches it
4380: 73 65 6c 66 2e 20 49 66 20 73 6f 2c 20 64 6f 20  self. If so, do 
4390: 6e 6f 74 0a 20 20 20 20 20 20 2a 2a 20 69 6e 63  not.      ** inc
43a0: 72 65 6d 65 6e 74 20 74 68 65 20 63 6f 6e 73 74  rement the const
43b0: 72 61 69 6e 74 2d 63 6f 75 6e 74 65 72 2e 20 0a  raint-counter. .
43c0: 20 20 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 2a        **.      *
43d0: 2a 20 49 66 20 61 6e 79 20 6f 66 20 74 68 65 20  * If any of the 
43e0: 70 61 72 65 6e 74 2d 6b 65 79 20 76 61 6c 75 65  parent-key value
43f0: 73 20 61 72 65 20 4e 55 4c 4c 2c 20 74 68 65 6e  s are NULL, then
4400: 20 74 68 65 20 72 6f 77 20 63 61 6e 6e 6f 74 20   the row cannot 
4410: 6d 61 74 63 68 20 0a 20 20 20 20 20 20 2a 2a 20  match .      ** 
4420: 69 74 73 65 6c 66 2e 20 53 6f 20 73 65 74 20 4a  itself. So set J
4430: 55 4d 50 49 46 4e 55 4c 4c 20 74 6f 20 6d 61 6b  UMPIFNULL to mak
4440: 65 20 73 75 72 65 20 77 65 20 64 6f 20 74 68 65  e sure we do the
4450: 20 4f 50 5f 46 6f 75 6e 64 20 69 66 20 61 6e 79   OP_Found if any
4460: 0a 20 20 20 20 20 20 2a 2a 20 6f 66 20 74 68 65  .      ** of the
4470: 20 70 61 72 65 6e 74 2d 6b 65 79 20 76 61 6c 75   parent-key valu
4480: 65 73 20 61 72 65 20 4e 55 4c 4c 20 28 61 74 20  es are NULL (at 
4490: 74 68 69 73 20 70 6f 69 6e 74 20 69 74 20 69 73  this point it is
44a0: 20 6b 6e 6f 77 6e 20 74 68 61 74 0a 20 20 20 20   known that.    
44b0: 20 20 2a 2a 20 6e 6f 6e 65 20 6f 66 20 74 68 65    ** none of the
44c0: 20 63 68 69 6c 64 20 6b 65 79 20 76 61 6c 75 65   child key value
44d0: 73 20 61 72 65 29 2e 0a 20 20 20 20 20 20 2a 2f  s are)..      */
44e0: 0a 20 20 20 20 20 20 69 66 28 20 70 54 61 62 3d  .      if( pTab=
44f0: 3d 70 46 4b 65 79 2d 3e 70 46 72 6f 6d 20 26 26  =pFKey->pFrom &&
4500: 20 6e 49 6e 63 72 3d 3d 31 20 29 7b 0a 20 20 20   nIncr==1 ){.   
4510: 20 20 20 20 20 69 6e 74 20 69 4a 75 6d 70 20 3d       int iJump =
4520: 20 73 71 6c 69 74 65 33 56 64 62 65 43 75 72 72   sqlite3VdbeCurr
4530: 65 6e 74 41 64 64 72 28 76 29 20 2b 20 6e 43 6f  entAddr(v) + nCo
4540: 6c 20 2b 20 31 3b 0a 20 20 20 20 20 20 20 20 66  l + 1;.        f
4550: 6f 72 28 69 3d 30 3b 20 69 3c 6e 43 6f 6c 3b 20  or(i=0; i<nCol; 
4560: 69 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 20 20  i++){.          
4570: 69 6e 74 20 69 43 68 69 6c 64 20 3d 20 61 69 43  int iChild = aiC
4580: 6f 6c 5b 69 5d 2b 31 2b 72 65 67 44 61 74 61 3b  ol[i]+1+regData;
4590: 0a 20 20 20 20 20 20 20 20 20 20 69 6e 74 20 69  .          int i
45a0: 50 61 72 65 6e 74 20 3d 20 70 49 64 78 2d 3e 61  Parent = pIdx->a
45b0: 69 43 6f 6c 75 6d 6e 5b 69 5d 2b 31 2b 72 65 67  iColumn[i]+1+reg
45c0: 44 61 74 61 3b 0a 20 20 20 20 20 20 20 20 20 20  Data;.          
45d0: 61 73 73 65 72 74 28 20 70 49 64 78 2d 3e 61 69  assert( pIdx->ai
45e0: 43 6f 6c 75 6d 6e 5b 69 5d 3e 3d 30 20 29 3b 0a  Column[i]>=0 );.
45f0: 20 20 20 20 20 20 20 20 20 20 61 73 73 65 72 74            assert
4600: 28 20 61 69 43 6f 6c 5b 69 5d 21 3d 70 54 61 62  ( aiCol[i]!=pTab
4610: 2d 3e 69 50 4b 65 79 20 29 3b 0a 20 20 20 20 20  ->iPKey );.     
4620: 20 20 20 20 20 69 66 28 20 70 49 64 78 2d 3e 61       if( pIdx->a
4630: 69 43 6f 6c 75 6d 6e 5b 69 5d 3d 3d 70 54 61 62  iColumn[i]==pTab
4640: 2d 3e 69 50 4b 65 79 20 29 7b 0a 20 20 20 20 20  ->iPKey ){.     
4650: 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20 70 61         /* The pa
4660: 72 65 6e 74 20 6b 65 79 20 69 73 20 61 20 63 6f  rent key is a co
4670: 6d 70 6f 73 69 74 65 20 6b 65 79 20 74 68 61 74  mposite key that
4680: 20 69 6e 63 6c 75 64 65 73 20 74 68 65 20 49 50   includes the IP
4690: 4b 20 63 6f 6c 75 6d 6e 20 2a 2f 0a 20 20 20 20  K column */.    
46a0: 20 20 20 20 20 20 20 20 69 50 61 72 65 6e 74 20          iParent 
46b0: 3d 20 72 65 67 44 61 74 61 3b 0a 20 20 20 20 20  = regData;.     
46c0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
46d0: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
46e0: 70 33 28 76 2c 20 4f 50 5f 4e 65 2c 20 69 43 68  p3(v, OP_Ne, iCh
46f0: 69 6c 64 2c 20 69 4a 75 6d 70 2c 20 69 50 61 72  ild, iJump, iPar
4700: 65 6e 74 29 3b 20 56 64 62 65 43 6f 76 65 72 61  ent); VdbeCovera
4710: 67 65 28 76 29 3b 0a 20 20 20 20 20 20 20 20 20  ge(v);.         
4720: 20 73 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e   sqlite3VdbeChan
4730: 67 65 50 35 28 76 2c 20 53 51 4c 49 54 45 5f 4a  geP5(v, SQLITE_J
4740: 55 4d 50 49 46 4e 55 4c 4c 29 3b 0a 20 20 20 20  UMPIFNULL);.    
4750: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 73 71      }.        sq
4760: 6c 69 74 65 33 56 64 62 65 47 6f 74 6f 28 76 2c  lite3VdbeGoto(v,
4770: 20 69 4f 6b 29 3b 0a 20 20 20 20 20 20 7d 0a 20   iOk);.      }. 
4780: 20 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56   .      sqlite3V
4790: 64 62 65 41 64 64 4f 70 34 28 76 2c 20 4f 50 5f  dbeAddOp4(v, OP_
47a0: 4d 61 6b 65 52 65 63 6f 72 64 2c 20 72 65 67 54  MakeRecord, regT
47b0: 65 6d 70 2c 20 6e 43 6f 6c 2c 20 72 65 67 52 65  emp, nCol, regRe
47c0: 63 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  c,.             
47d0: 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74             sqlit
47e0: 65 33 49 6e 64 65 78 41 66 66 69 6e 69 74 79 53  e3IndexAffinityS
47f0: 74 72 28 70 50 61 72 73 65 2d 3e 64 62 2c 70 49  tr(pParse->db,pI
4800: 64 78 29 2c 20 6e 43 6f 6c 29 3b 0a 20 20 20 20  dx), nCol);.    
4810: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
4820: 4f 70 34 49 6e 74 28 76 2c 20 4f 50 5f 46 6f 75  Op4Int(v, OP_Fou
4830: 6e 64 2c 20 69 43 75 72 2c 20 69 4f 6b 2c 20 72  nd, iCur, iOk, r
4840: 65 67 52 65 63 2c 20 30 29 3b 20 56 64 62 65 43  egRec, 0); VdbeC
4850: 6f 76 65 72 61 67 65 28 76 29 3b 0a 20 20 0a 20  overage(v);.  . 
4860: 20 20 20 20 20 73 71 6c 69 74 65 33 52 65 6c 65       sqlite3Rele
4870: 61 73 65 54 65 6d 70 52 65 67 28 70 50 61 72 73  aseTempReg(pPars
4880: 65 2c 20 72 65 67 52 65 63 29 3b 0a 20 20 20 20  e, regRec);.    
4890: 20 20 73 71 6c 69 74 65 33 52 65 6c 65 61 73 65    sqlite3Release
48a0: 54 65 6d 70 52 61 6e 67 65 28 70 50 61 72 73 65  TempRange(pParse
48b0: 2c 20 72 65 67 54 65 6d 70 2c 20 6e 43 6f 6c 29  , regTemp, nCol)
48c0: 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 69  ;.    }.  }..  i
48d0: 66 28 20 21 70 46 4b 65 79 2d 3e 69 73 44 65 66  f( !pFKey->isDef
48e0: 65 72 72 65 64 20 26 26 20 21 28 70 50 61 72 73  erred && !(pPars
48f0: 65 2d 3e 64 62 2d 3e 66 6c 61 67 73 20 26 20 53  e->db->flags & S
4900: 51 4c 49 54 45 5f 44 65 66 65 72 46 4b 73 29 0a  QLITE_DeferFKs).
4910: 20 20 20 26 26 20 21 70 50 61 72 73 65 2d 3e 70     && !pParse->p
4920: 54 6f 70 6c 65 76 65 6c 20 0a 20 20 20 26 26 20  Toplevel .   && 
4930: 21 70 50 61 72 73 65 2d 3e 69 73 4d 75 6c 74 69  !pParse->isMulti
4940: 57 72 69 74 65 20 0a 20 20 29 7b 0a 20 20 20 20  Write .  ){.    
4950: 2f 2a 20 53 70 65 63 69 61 6c 20 63 61 73 65 3a  /* Special case:
4960: 20 49 66 20 74 68 69 73 20 69 73 20 61 6e 20 49   If this is an I
4970: 4e 53 45 52 54 20 73 74 61 74 65 6d 65 6e 74 20  NSERT statement 
4980: 74 68 61 74 20 77 69 6c 6c 20 69 6e 73 65 72 74  that will insert
4990: 20 65 78 61 63 74 6c 79 0a 20 20 20 20 2a 2a 20   exactly.    ** 
49a0: 6f 6e 65 20 72 6f 77 20 69 6e 74 6f 20 74 68 65  one row into the
49b0: 20 74 61 62 6c 65 2c 20 72 61 69 73 65 20 61 20   table, raise a 
49c0: 63 6f 6e 73 74 72 61 69 6e 74 20 69 6d 6d 65 64  constraint immed
49d0: 69 61 74 65 6c 79 20 69 6e 73 74 65 61 64 20 6f  iately instead o
49e0: 66 0a 20 20 20 20 2a 2a 20 69 6e 63 72 65 6d 65  f.    ** increme
49f0: 6e 74 69 6e 67 20 61 20 63 6f 75 6e 74 65 72 2e  nting a counter.
4a00: 20 54 68 69 73 20 69 73 20 6e 65 63 65 73 73 61   This is necessa
4a10: 72 79 20 61 73 20 74 68 65 20 56 4d 20 63 6f 64  ry as the VM cod
4a20: 65 20 69 73 20 62 65 69 6e 67 0a 20 20 20 20 2a  e is being.    *
4a30: 2a 20 67 65 6e 65 72 61 74 65 64 20 66 6f 72 20  * generated for 
4a40: 77 69 6c 6c 20 6e 6f 74 20 6f 70 65 6e 20 61 20  will not open a 
4a50: 73 74 61 74 65 6d 65 6e 74 20 74 72 61 6e 73 61  statement transa
4a60: 63 74 69 6f 6e 2e 20 20 2a 2f 0a 20 20 20 20 61  ction.  */.    a
4a70: 73 73 65 72 74 28 20 6e 49 6e 63 72 3d 3d 31 20  ssert( nIncr==1 
4a80: 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 48 61  );.    sqlite3Ha
4a90: 6c 74 43 6f 6e 73 74 72 61 69 6e 74 28 70 50 61  ltConstraint(pPa
4aa0: 72 73 65 2c 20 53 51 4c 49 54 45 5f 43 4f 4e 53  rse, SQLITE_CONS
4ab0: 54 52 41 49 4e 54 5f 46 4f 52 45 49 47 4e 4b 45  TRAINT_FOREIGNKE
4ac0: 59 2c 0a 20 20 20 20 20 20 20 20 4f 45 5f 41 62  Y,.        OE_Ab
4ad0: 6f 72 74 2c 20 30 2c 20 50 34 5f 53 54 41 54 49  ort, 0, P4_STATI
4ae0: 43 2c 20 50 35 5f 43 6f 6e 73 74 72 61 69 6e 74  C, P5_Constraint
4af0: 46 4b 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20  FK);.  }else{.  
4b00: 20 20 69 66 28 20 6e 49 6e 63 72 3e 30 20 26 26    if( nIncr>0 &&
4b10: 20 70 46 4b 65 79 2d 3e 69 73 44 65 66 65 72 72   pFKey->isDeferr
4b20: 65 64 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 73  ed==0 ){.      s
4b30: 71 6c 69 74 65 33 4d 61 79 41 62 6f 72 74 28 70  qlite3MayAbort(p
4b40: 50 61 72 73 65 29 3b 0a 20 20 20 20 7d 0a 20 20  Parse);.    }.  
4b50: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
4b60: 4f 70 32 28 76 2c 20 4f 50 5f 46 6b 43 6f 75 6e  Op2(v, OP_FkCoun
4b70: 74 65 72 2c 20 70 46 4b 65 79 2d 3e 69 73 44 65  ter, pFKey->isDe
4b80: 66 65 72 72 65 64 2c 20 6e 49 6e 63 72 29 3b 0a  ferred, nIncr);.
4b90: 20 20 7d 0a 0a 20 20 73 71 6c 69 74 65 33 56 64    }..  sqlite3Vd
4ba0: 62 65 52 65 73 6f 6c 76 65 4c 61 62 65 6c 28 76  beResolveLabel(v
4bb0: 2c 20 69 4f 6b 29 3b 0a 20 20 73 71 6c 69 74 65  , iOk);.  sqlite
4bc0: 33 56 64 62 65 41 64 64 4f 70 31 28 76 2c 20 4f  3VdbeAddOp1(v, O
4bd0: 50 5f 43 6c 6f 73 65 2c 20 69 43 75 72 29 3b 0a  P_Close, iCur);.
4be0: 7d 0a 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e  }.../*.** Return
4bf0: 20 61 6e 20 45 78 70 72 20 6f 62 6a 65 63 74 20   an Expr object 
4c00: 74 68 61 74 20 72 65 66 65 72 73 20 74 6f 20 61  that refers to a
4c10: 20 6d 65 6d 6f 72 79 20 72 65 67 69 73 74 65 72   memory register
4c20: 20 63 6f 72 72 65 73 70 6f 6e 64 69 6e 67 0a 2a   corresponding.*
4c30: 2a 20 74 6f 20 63 6f 6c 75 6d 6e 20 69 43 6f 6c  * to column iCol
4c40: 20 6f 66 20 74 61 62 6c 65 20 70 54 61 62 2e 0a   of table pTab..
4c50: 2a 2a 0a 2a 2a 20 72 65 67 42 61 73 65 20 69 73  **.** regBase is
4c60: 20 74 68 65 20 66 69 72 73 74 20 6f 66 20 61 6e   the first of an
4c70: 20 61 72 72 61 79 20 6f 66 20 72 65 67 69 73 74   array of regist
4c80: 65 72 20 74 68 61 74 20 63 6f 6e 74 61 69 6e 73  er that contains
4c90: 20 74 68 65 20 64 61 74 61 0a 2a 2a 20 66 6f 72   the data.** for
4ca0: 20 70 54 61 62 2e 20 20 72 65 67 42 61 73 65 20   pTab.  regBase 
4cb0: 69 74 73 65 6c 66 20 68 6f 6c 64 73 20 74 68 65  itself holds the
4cc0: 20 72 6f 77 69 64 2e 20 20 72 65 67 42 61 73 65   rowid.  regBase
4cd0: 2b 31 20 68 6f 6c 64 73 20 74 68 65 20 66 69 72  +1 holds the fir
4ce0: 73 74 0a 2a 2a 20 63 6f 6c 75 6d 6e 2e 20 20 72  st.** column.  r
4cf0: 65 67 42 61 73 65 2b 32 20 68 6f 6c 64 73 20 74  egBase+2 holds t
4d00: 68 65 20 73 65 63 6f 6e 64 20 63 6f 6c 75 6d 6e  he second column
4d10: 2c 20 61 6e 64 20 73 6f 20 66 6f 72 74 68 2e 0a  , and so forth..
4d20: 2a 2f 0a 73 74 61 74 69 63 20 45 78 70 72 20 2a  */.static Expr *
4d30: 65 78 70 72 54 61 62 6c 65 52 65 67 69 73 74 65  exprTableRegiste
4d40: 72 28 0a 20 20 50 61 72 73 65 20 2a 70 50 61 72  r(.  Parse *pPar
4d50: 73 65 2c 20 20 20 20 20 2f 2a 20 50 61 72 73 69  se,     /* Parsi
4d60: 6e 67 20 61 6e 64 20 63 6f 64 65 20 67 65 6e 65  ng and code gene
4d70: 72 61 74 69 6e 67 20 63 6f 6e 74 65 78 74 20 2a  rating context *
4d80: 2f 0a 20 20 54 61 62 6c 65 20 2a 70 54 61 62 2c  /.  Table *pTab,
4d90: 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20 74 61         /* The ta
4da0: 62 6c 65 20 77 68 6f 73 65 20 63 6f 6e 74 65 6e  ble whose conten
4db0: 74 20 69 73 20 61 74 20 72 5b 72 65 67 42 61 73  t is at r[regBas
4dc0: 65 5d 2e 2e 2e 20 2a 2f 0a 20 20 69 6e 74 20 72  e]... */.  int r
4dd0: 65 67 42 61 73 65 2c 20 20 20 20 20 20 20 2f 2a  egBase,       /*
4de0: 20 43 6f 6e 74 65 6e 74 73 20 6f 66 20 74 61 62   Contents of tab
4df0: 6c 65 20 70 54 61 62 20 2a 2f 0a 20 20 69 31 36  le pTab */.  i16
4e00: 20 69 43 6f 6c 20 20 20 20 20 20 20 20 20 20 20   iCol           
4e10: 2f 2a 20 57 68 69 63 68 20 63 6f 6c 75 6d 6e 20  /* Which column 
4e20: 6f 66 20 70 54 61 62 20 69 73 20 64 65 73 69 72  of pTab is desir
4e30: 65 64 20 2a 2f 0a 29 7b 0a 20 20 45 78 70 72 20  ed */.){.  Expr 
4e40: 2a 70 45 78 70 72 3b 0a 20 20 43 6f 6c 75 6d 6e  *pExpr;.  Column
4e50: 20 2a 70 43 6f 6c 3b 0a 20 20 63 6f 6e 73 74 20   *pCol;.  const 
4e60: 63 68 61 72 20 2a 7a 43 6f 6c 6c 3b 0a 20 20 73  char *zColl;.  s
4e70: 71 6c 69 74 65 33 20 2a 64 62 20 3d 20 70 50 61  qlite3 *db = pPa
4e80: 72 73 65 2d 3e 64 62 3b 0a 0a 20 20 70 45 78 70  rse->db;..  pExp
4e90: 72 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72 28  r = sqlite3Expr(
4ea0: 64 62 2c 20 54 4b 5f 52 45 47 49 53 54 45 52 2c  db, TK_REGISTER,
4eb0: 20 30 29 3b 0a 20 20 69 66 28 20 70 45 78 70 72   0);.  if( pExpr
4ec0: 20 29 7b 0a 20 20 20 20 69 66 28 20 69 43 6f 6c   ){.    if( iCol
4ed0: 3e 3d 30 20 26 26 20 69 43 6f 6c 21 3d 70 54 61  >=0 && iCol!=pTa
4ee0: 62 2d 3e 69 50 4b 65 79 20 29 7b 0a 20 20 20 20  b->iPKey ){.    
4ef0: 20 20 70 43 6f 6c 20 3d 20 26 70 54 61 62 2d 3e    pCol = &pTab->
4f00: 61 43 6f 6c 5b 69 43 6f 6c 5d 3b 0a 20 20 20 20  aCol[iCol];.    
4f10: 20 20 70 45 78 70 72 2d 3e 69 54 61 62 6c 65 20    pExpr->iTable 
4f20: 3d 20 72 65 67 42 61 73 65 20 2b 20 69 43 6f 6c  = regBase + iCol
4f30: 20 2b 20 31 3b 0a 20 20 20 20 20 20 70 45 78 70   + 1;.      pExp
4f40: 72 2d 3e 61 66 66 45 78 70 72 20 3d 20 70 43 6f  r->affExpr = pCo
4f50: 6c 2d 3e 61 66 66 69 6e 69 74 79 3b 0a 20 20 20  l->affinity;.   
4f60: 20 20 20 7a 43 6f 6c 6c 20 3d 20 70 43 6f 6c 2d     zColl = pCol-
4f70: 3e 7a 43 6f 6c 6c 3b 0a 20 20 20 20 20 20 69 66  >zColl;.      if
4f80: 28 20 7a 43 6f 6c 6c 3d 3d 30 20 29 20 7a 43 6f  ( zColl==0 ) zCo
4f90: 6c 6c 20 3d 20 64 62 2d 3e 70 44 66 6c 74 43 6f  ll = db->pDfltCo
4fa0: 6c 6c 2d 3e 7a 4e 61 6d 65 3b 0a 20 20 20 20 20  ll->zName;.     
4fb0: 20 70 45 78 70 72 20 3d 20 73 71 6c 69 74 65 33   pExpr = sqlite3
4fc0: 45 78 70 72 41 64 64 43 6f 6c 6c 61 74 65 53 74  ExprAddCollateSt
4fd0: 72 69 6e 67 28 70 50 61 72 73 65 2c 20 70 45 78  ring(pParse, pEx
4fe0: 70 72 2c 20 7a 43 6f 6c 6c 29 3b 0a 20 20 20 20  pr, zColl);.    
4ff0: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 70 45 78  }else{.      pEx
5000: 70 72 2d 3e 69 54 61 62 6c 65 20 3d 20 72 65 67  pr->iTable = reg
5010: 42 61 73 65 3b 0a 20 20 20 20 20 20 70 45 78 70  Base;.      pExp
5020: 72 2d 3e 61 66 66 45 78 70 72 20 3d 20 53 51 4c  r->affExpr = SQL
5030: 49 54 45 5f 41 46 46 5f 49 4e 54 45 47 45 52 3b  ITE_AFF_INTEGER;
5040: 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 72 65 74  .    }.  }.  ret
5050: 75 72 6e 20 70 45 78 70 72 3b 0a 7d 0a 0a 2f 2a  urn pExpr;.}../*
5060: 0a 2a 2a 20 52 65 74 75 72 6e 20 61 6e 20 45 78  .** Return an Ex
5070: 70 72 20 6f 62 6a 65 63 74 20 74 68 61 74 20 72  pr object that r
5080: 65 66 65 72 73 20 74 6f 20 63 6f 6c 75 6d 6e 20  efers to column 
5090: 69 43 6f 6c 20 6f 66 20 74 61 62 6c 65 20 70 54  iCol of table pT
50a0: 61 62 20 77 68 69 63 68 0a 2a 2a 20 68 61 73 20  ab which.** has 
50b0: 63 75 72 73 6f 72 20 69 43 75 72 2e 0a 2a 2f 0a  cursor iCur..*/.
50c0: 73 74 61 74 69 63 20 45 78 70 72 20 2a 65 78 70  static Expr *exp
50d0: 72 54 61 62 6c 65 43 6f 6c 75 6d 6e 28 0a 20 20  rTableColumn(.  
50e0: 73 71 6c 69 74 65 33 20 2a 64 62 2c 20 20 20 20  sqlite3 *db,    
50f0: 20 20 2f 2a 20 54 68 65 20 64 61 74 61 62 61 73    /* The databas
5100: 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 2a 2f 0a  e connection */.
5110: 20 20 54 61 62 6c 65 20 2a 70 54 61 62 2c 20 20    Table *pTab,  
5120: 20 20 20 20 2f 2a 20 54 68 65 20 74 61 62 6c 65      /* The table
5130: 20 77 68 6f 73 65 20 63 6f 6c 75 6d 6e 20 69 73   whose column is
5140: 20 64 65 73 69 72 65 64 20 2a 2f 0a 20 20 69 6e   desired */.  in
5150: 74 20 69 43 75 72 73 6f 72 2c 20 20 20 20 20 20  t iCursor,      
5160: 2f 2a 20 54 68 65 20 6f 70 65 6e 20 63 75 72 73  /* The open curs
5170: 6f 72 20 6f 6e 20 74 68 65 20 74 61 62 6c 65 20  or on the table 
5180: 2a 2f 0a 20 20 69 31 36 20 69 43 6f 6c 20 20 20  */.  i16 iCol   
5190: 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20 63 6f         /* The co
51a0: 6c 75 6d 6e 20 74 68 61 74 20 69 73 20 77 61 6e  lumn that is wan
51b0: 74 65 64 20 2a 2f 0a 29 7b 0a 20 20 45 78 70 72  ted */.){.  Expr
51c0: 20 2a 70 45 78 70 72 20 3d 20 73 71 6c 69 74 65   *pExpr = sqlite
51d0: 33 45 78 70 72 28 64 62 2c 20 54 4b 5f 43 4f 4c  3Expr(db, TK_COL
51e0: 55 4d 4e 2c 20 30 29 3b 0a 20 20 69 66 28 20 70  UMN, 0);.  if( p
51f0: 45 78 70 72 20 29 7b 0a 20 20 20 20 70 45 78 70  Expr ){.    pExp
5200: 72 2d 3e 79 2e 70 54 61 62 20 3d 20 70 54 61 62  r->y.pTab = pTab
5210: 3b 0a 20 20 20 20 70 45 78 70 72 2d 3e 69 54 61  ;.    pExpr->iTa
5220: 62 6c 65 20 3d 20 69 43 75 72 73 6f 72 3b 0a 20  ble = iCursor;. 
5230: 20 20 20 70 45 78 70 72 2d 3e 69 43 6f 6c 75 6d     pExpr->iColum
5240: 6e 20 3d 20 69 43 6f 6c 3b 0a 20 20 7d 0a 20 20  n = iCol;.  }.  
5250: 72 65 74 75 72 6e 20 70 45 78 70 72 3b 0a 7d 0a  return pExpr;.}.
5260: 0a 2f 2a 0a 2a 2a 20 54 68 69 73 20 66 75 6e 63  ./*.** This func
5270: 74 69 6f 6e 20 69 73 20 63 61 6c 6c 65 64 20 74  tion is called t
5280: 6f 20 67 65 6e 65 72 61 74 65 20 63 6f 64 65 20  o generate code 
5290: 65 78 65 63 75 74 65 64 20 77 68 65 6e 20 61 20  executed when a 
52a0: 72 6f 77 20 69 73 20 64 65 6c 65 74 65 64 0a 2a  row is deleted.*
52b0: 2a 20 66 72 6f 6d 20 74 68 65 20 70 61 72 65 6e  * from the paren
52c0: 74 20 74 61 62 6c 65 20 6f 66 20 66 6f 72 65 69  t table of forei
52d0: 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e  gn key constrain
52e0: 74 20 70 46 4b 65 79 20 61 6e 64 2c 20 69 66 20  t pFKey and, if 
52f0: 70 46 4b 65 79 20 69 73 20 0a 2a 2a 20 64 65 66  pFKey is .** def
5300: 65 72 72 65 64 2c 20 77 68 65 6e 20 61 20 72 6f  erred, when a ro
5310: 77 20 69 73 20 69 6e 73 65 72 74 65 64 20 69 6e  w is inserted in
5320: 74 6f 20 74 68 65 20 73 61 6d 65 20 74 61 62 6c  to the same tabl
5330: 65 2e 20 57 68 65 6e 20 67 65 6e 65 72 61 74 69  e. When generati
5340: 6e 67 0a 2a 2a 20 63 6f 64 65 20 66 6f 72 20 61  ng.** code for a
5350: 6e 20 53 51 4c 20 55 50 44 41 54 45 20 6f 70 65  n SQL UPDATE ope
5360: 72 61 74 69 6f 6e 2c 20 74 68 69 73 20 66 75 6e  ration, this fun
5370: 63 74 69 6f 6e 20 6d 61 79 20 62 65 20 63 61 6c  ction may be cal
5380: 6c 65 64 20 74 77 69 63 65 20 2d 0a 2a 2a 20 6f  led twice -.** o
5390: 6e 63 65 20 74 6f 20 22 64 65 6c 65 74 65 22 20  nce to "delete" 
53a0: 74 68 65 20 6f 6c 64 20 72 6f 77 20 61 6e 64 20  the old row and 
53b0: 6f 6e 63 65 20 74 6f 20 22 69 6e 73 65 72 74 22  once to "insert"
53c0: 20 74 68 65 20 6e 65 77 20 72 6f 77 2e 0a 2a 2a   the new row..**
53d0: 0a 2a 2a 20 50 61 72 61 6d 65 74 65 72 20 6e 49  .** Parameter nI
53e0: 6e 63 72 20 69 73 20 70 61 73 73 65 64 20 2d 31  ncr is passed -1
53f0: 20 77 68 65 6e 20 69 6e 73 65 72 74 69 6e 67 20   when inserting 
5400: 61 20 72 6f 77 20 28 61 73 20 74 68 69 73 20 6d  a row (as this m
5410: 61 79 20 64 65 63 72 65 61 73 65 0a 2a 2a 20 74  ay decrease.** t
5420: 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 46 4b 20  he number of FK 
5430: 76 69 6f 6c 61 74 69 6f 6e 73 20 69 6e 20 74 68  violations in th
5440: 65 20 64 62 29 20 6f 72 20 2b 31 20 77 68 65 6e  e db) or +1 when
5450: 20 64 65 6c 65 74 69 6e 67 20 6f 6e 65 20 28 61   deleting one (a
5460: 73 20 74 68 69 73 0a 2a 2a 20 6d 61 79 20 69 6e  s this.** may in
5470: 63 72 65 61 73 65 20 74 68 65 20 6e 75 6d 62 65  crease the numbe
5480: 72 20 6f 66 20 46 4b 20 63 6f 6e 73 74 72 61 69  r of FK constrai
5490: 6e 74 20 70 72 6f 62 6c 65 6d 73 29 2e 0a 2a 2a  nt problems)..**
54a0: 0a 2a 2a 20 54 68 65 20 63 6f 64 65 20 67 65 6e  .** The code gen
54b0: 65 72 61 74 65 64 20 62 79 20 74 68 69 73 20 66  erated by this f
54c0: 75 6e 63 74 69 6f 6e 20 73 63 61 6e 73 20 74 68  unction scans th
54d0: 72 6f 75 67 68 20 74 68 65 20 72 6f 77 73 20 69  rough the rows i
54e0: 6e 20 74 68 65 20 63 68 69 6c 64 0a 2a 2a 20 74  n the child.** t
54f0: 61 62 6c 65 20 74 68 61 74 20 63 6f 72 72 65 73  able that corres
5500: 70 6f 6e 64 20 74 6f 20 74 68 65 20 70 61 72 65  pond to the pare
5510: 6e 74 20 74 61 62 6c 65 20 72 6f 77 20 62 65 69  nt table row bei
5520: 6e 67 20 64 65 6c 65 74 65 64 20 6f 72 20 69 6e  ng deleted or in
5530: 73 65 72 74 65 64 2e 0a 2a 2a 20 46 6f 72 20 65  serted..** For e
5540: 61 63 68 20 63 68 69 6c 64 20 72 6f 77 20 66 6f  ach child row fo
5550: 75 6e 64 2c 20 6f 6e 65 20 6f 66 20 74 68 65 20  und, one of the 
5560: 66 6f 6c 6c 6f 77 69 6e 67 20 61 63 74 69 6f 6e  following action
5570: 73 20 69 73 20 74 61 6b 65 6e 3a 0a 2a 2a 0a 2a  s is taken:.**.*
5580: 2a 20 20 20 4f 70 65 72 61 74 69 6f 6e 20 7c 20  *   Operation | 
5590: 46 4b 20 74 79 70 65 20 20 20 7c 20 41 63 74 69  FK type   | Acti
55a0: 6f 6e 20 74 61 6b 65 6e 0a 2a 2a 20 20 20 2d 2d  on taken.**   --
55b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
55c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
55d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
55e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
55f0: 2d 2d 2d 2d 2d 2d 2d 2d 0a 2a 2a 20 20 20 44 45  --------.**   DE
5600: 4c 45 54 45 20 20 20 20 20 20 69 6d 6d 65 64 69  LETE      immedi
5610: 61 74 65 20 20 20 49 6e 63 72 65 6d 65 6e 74 20  ate   Increment 
5620: 74 68 65 20 22 69 6d 6d 65 64 69 61 74 65 20 63  the "immediate c
5630: 6f 6e 73 74 72 61 69 6e 74 20 63 6f 75 6e 74 65  onstraint counte
5640: 72 22 2e 0a 2a 2a 20 20 20 20 20 20 20 20 20 20  r"..**          
5650: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5660: 20 4f 72 2c 20 69 66 20 74 68 65 20 4f 4e 20 28   Or, if the ON (
5670: 55 50 44 41 54 45 7c 44 45 4c 45 54 45 29 20 61  UPDATE|DELETE) a
5680: 63 74 69 6f 6e 20 69 73 20 52 45 53 54 52 49 43  ction is RESTRIC
5690: 54 2c 0a 2a 2a 20 20 20 20 20 20 20 20 20 20 20  T,.**           
56a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
56b0: 74 68 72 6f 77 20 61 20 22 46 4f 52 45 49 47 4e  throw a "FOREIGN
56c0: 20 4b 45 59 20 63 6f 6e 73 74 72 61 69 6e 74 20   KEY constraint 
56d0: 66 61 69 6c 65 64 22 20 65 78 63 65 70 74 69 6f  failed" exceptio
56e0: 6e 2e 0a 2a 2a 0a 2a 2a 20 20 20 49 4e 53 45 52  n..**.**   INSER
56f0: 54 20 20 20 20 20 20 69 6d 6d 65 64 69 61 74 65  T      immediate
5700: 20 20 20 44 65 63 72 65 6d 65 6e 74 20 74 68 65     Decrement the
5710: 20 22 69 6d 6d 65 64 69 61 74 65 20 63 6f 6e 73   "immediate cons
5720: 74 72 61 69 6e 74 20 63 6f 75 6e 74 65 72 22 2e  traint counter".
5730: 0a 2a 2a 0a 2a 2a 20 20 20 44 45 4c 45 54 45 20  .**.**   DELETE 
5740: 20 20 20 20 20 64 65 66 65 72 72 65 64 20 20 20       deferred   
5750: 20 49 6e 63 72 65 6d 65 6e 74 20 74 68 65 20 22   Increment the "
5760: 64 65 66 65 72 72 65 64 20 63 6f 6e 73 74 72 61  deferred constra
5770: 69 6e 74 20 63 6f 75 6e 74 65 72 22 2e 0a 2a 2a  int counter"..**
5780: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5790: 20 20 20 20 20 20 20 20 20 20 20 4f 72 2c 20 69             Or, i
57a0: 66 20 74 68 65 20 4f 4e 20 28 55 50 44 41 54 45  f the ON (UPDATE
57b0: 7c 44 45 4c 45 54 45 29 20 61 63 74 69 6f 6e 20  |DELETE) action 
57c0: 69 73 20 52 45 53 54 52 49 43 54 2c 0a 2a 2a 20  is RESTRICT,.** 
57d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
57e0: 20 20 20 20 20 20 20 20 20 20 74 68 72 6f 77 20            throw 
57f0: 61 20 22 46 4f 52 45 49 47 4e 20 4b 45 59 20 63  a "FOREIGN KEY c
5800: 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64  onstraint failed
5810: 22 20 65 78 63 65 70 74 69 6f 6e 2e 0a 2a 2a 0a  " exception..**.
5820: 2a 2a 20 20 20 49 4e 53 45 52 54 20 20 20 20 20  **   INSERT     
5830: 20 64 65 66 65 72 72 65 64 20 20 20 20 44 65 63   deferred    Dec
5840: 72 65 6d 65 6e 74 20 74 68 65 20 22 64 65 66 65  rement the "defe
5850: 72 72 65 64 20 63 6f 6e 73 74 72 61 69 6e 74 20  rred constraint 
5860: 63 6f 75 6e 74 65 72 22 2e 0a 2a 2a 0a 2a 2a 20  counter"..**.** 
5870: 54 68 65 73 65 20 6f 70 65 72 61 74 69 6f 6e 73  These operations
5880: 20 61 72 65 20 69 64 65 6e 74 69 66 69 65 64 20   are identified 
5890: 69 6e 20 74 68 65 20 63 6f 6d 6d 65 6e 74 20 61  in the comment a
58a0: 74 20 74 68 65 20 74 6f 70 20 6f 66 20 74 68 69  t the top of thi
58b0: 73 20 66 69 6c 65 20 0a 2a 2a 20 28 66 6b 65 79  s file .** (fkey
58c0: 2e 63 29 20 61 73 20 22 49 2e 32 22 20 61 6e 64  .c) as "I.2" and
58d0: 20 22 44 2e 32 22 2e 0a 2a 2f 0a 73 74 61 74 69   "D.2"..*/.stati
58e0: 63 20 76 6f 69 64 20 66 6b 53 63 61 6e 43 68 69  c void fkScanChi
58f0: 6c 64 72 65 6e 28 0a 20 20 50 61 72 73 65 20 2a  ldren(.  Parse *
5900: 70 50 61 72 73 65 2c 20 20 20 20 20 20 20 20 20  pParse,         
5910: 20 20 20 20 20 20 20 20 20 2f 2a 20 50 61 72 73           /* Pars
5920: 65 20 63 6f 6e 74 65 78 74 20 2a 2f 0a 20 20 53  e context */.  S
5930: 72 63 4c 69 73 74 20 2a 70 53 72 63 2c 20 20 20  rcList *pSrc,   
5940: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
5950: 2a 20 54 68 65 20 63 68 69 6c 64 20 74 61 62 6c  * The child tabl
5960: 65 20 74 6f 20 62 65 20 73 63 61 6e 6e 65 64 20  e to be scanned 
5970: 2a 2f 0a 20 20 54 61 62 6c 65 20 2a 70 54 61 62  */.  Table *pTab
5980: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,               
5990: 20 20 20 20 20 2f 2a 20 54 68 65 20 70 61 72 65       /* The pare
59a0: 6e 74 20 74 61 62 6c 65 20 2a 2f 0a 20 20 49 6e  nt table */.  In
59b0: 64 65 78 20 2a 70 49 64 78 2c 20 20 20 20 20 20  dex *pIdx,      
59c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
59d0: 20 49 6e 64 65 78 20 6f 6e 20 70 61 72 65 6e 74   Index on parent
59e0: 20 63 6f 76 65 72 69 6e 67 20 74 68 65 20 66 6f   covering the fo
59f0: 72 65 69 67 6e 20 6b 65 79 20 2a 2f 0a 20 20 46  reign key */.  F
5a00: 4b 65 79 20 2a 70 46 4b 65 79 2c 20 20 20 20 20  Key *pFKey,     
5a10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
5a20: 2a 20 54 68 65 20 66 6f 72 65 69 67 6e 20 6b 65  * The foreign ke
5a30: 79 20 6c 69 6e 6b 69 6e 67 20 70 53 72 63 20 74  y linking pSrc t
5a40: 6f 20 70 54 61 62 20 2a 2f 0a 20 20 69 6e 74 20  o pTab */.  int 
5a50: 2a 61 69 43 6f 6c 2c 20 20 20 20 20 20 20 20 20  *aiCol,         
5a60: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4d              /* M
5a70: 61 70 20 66 72 6f 6d 20 70 49 64 78 20 63 6f 6c  ap from pIdx col
5a80: 73 20 74 6f 20 63 68 69 6c 64 20 74 61 62 6c 65  s to child table
5a90: 20 63 6f 6c 73 20 2a 2f 0a 20 20 69 6e 74 20 72   cols */.  int r
5aa0: 65 67 44 61 74 61 2c 20 20 20 20 20 20 20 20 20  egData,         
5ab0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 50 61             /* Pa
5ac0: 72 65 6e 74 20 72 6f 77 20 64 61 74 61 20 73 74  rent row data st
5ad0: 61 72 74 73 20 68 65 72 65 20 2a 2f 0a 20 20 69  arts here */.  i
5ae0: 6e 74 20 6e 49 6e 63 72 20 20 20 20 20 20 20 20  nt nIncr        
5af0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
5b00: 2a 20 41 6d 6f 75 6e 74 20 74 6f 20 69 6e 63 72  * Amount to incr
5b10: 65 6d 65 6e 74 20 64 65 66 65 72 72 65 64 20 63  ement deferred c
5b20: 6f 75 6e 74 65 72 20 62 79 20 2a 2f 0a 29 7b 0a  ounter by */.){.
5b30: 20 20 73 71 6c 69 74 65 33 20 2a 64 62 20 3d 20    sqlite3 *db = 
5b40: 70 50 61 72 73 65 2d 3e 64 62 3b 20 20 20 20 20  pParse->db;     
5b50: 20 20 2f 2a 20 44 61 74 61 62 61 73 65 20 68 61    /* Database ha
5b60: 6e 64 6c 65 20 2a 2f 0a 20 20 69 6e 74 20 69 3b  ndle */.  int i;
5b70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5b80: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 49 74 65            /* Ite
5b90: 72 61 74 6f 72 20 76 61 72 69 61 62 6c 65 20 2a  rator variable *
5ba0: 2f 0a 20 20 45 78 70 72 20 2a 70 57 68 65 72 65  /.  Expr *pWhere
5bb0: 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20 20   = 0;           
5bc0: 20 20 20 20 2f 2a 20 57 48 45 52 45 20 63 6c 61      /* WHERE cla
5bd0: 75 73 65 20 74 6f 20 73 63 61 6e 20 77 69 74 68  use to scan with
5be0: 20 2a 2f 0a 20 20 4e 61 6d 65 43 6f 6e 74 65 78   */.  NameContex
5bf0: 74 20 73 4e 61 6d 65 43 6f 6e 74 65 78 74 3b 20  t sNameContext; 
5c00: 20 20 20 20 20 20 2f 2a 20 43 6f 6e 74 65 78 74        /* Context
5c10: 20 75 73 65 64 20 74 6f 20 72 65 73 6f 6c 76 65   used to resolve
5c20: 20 57 48 45 52 45 20 63 6c 61 75 73 65 20 2a 2f   WHERE clause */
5c30: 0a 20 20 57 68 65 72 65 49 6e 66 6f 20 2a 70 57  .  WhereInfo *pW
5c40: 49 6e 66 6f 3b 20 20 20 20 20 20 20 20 20 20 20  Info;           
5c50: 20 20 20 2f 2a 20 43 6f 6e 74 65 78 74 20 75 73     /* Context us
5c60: 65 64 20 62 79 20 73 71 6c 69 74 65 33 57 68 65  ed by sqlite3Whe
5c70: 72 65 58 58 58 28 29 20 2a 2f 0a 20 20 69 6e 74  reXXX() */.  int
5c80: 20 69 46 6b 49 66 5a 65 72 6f 20 3d 20 30 3b 20   iFkIfZero = 0; 
5c90: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
5ca0: 41 64 64 72 65 73 73 20 6f 66 20 4f 50 5f 46 6b  Address of OP_Fk
5cb0: 49 66 5a 65 72 6f 20 2a 2f 0a 20 20 56 64 62 65  IfZero */.  Vdbe
5cc0: 20 2a 76 20 3d 20 73 71 6c 69 74 65 33 47 65 74   *v = sqlite3Get
5cd0: 56 64 62 65 28 70 50 61 72 73 65 29 3b 0a 0a 20  Vdbe(pParse);.. 
5ce0: 20 61 73 73 65 72 74 28 20 70 49 64 78 3d 3d 30   assert( pIdx==0
5cf0: 20 7c 7c 20 70 49 64 78 2d 3e 70 54 61 62 6c 65   || pIdx->pTable
5d00: 3d 3d 70 54 61 62 20 29 3b 0a 20 20 61 73 73 65  ==pTab );.  asse
5d10: 72 74 28 20 70 49 64 78 3d 3d 30 20 7c 7c 20 70  rt( pIdx==0 || p
5d20: 49 64 78 2d 3e 6e 4b 65 79 43 6f 6c 3d 3d 70 46  Idx->nKeyCol==pF
5d30: 4b 65 79 2d 3e 6e 43 6f 6c 20 29 3b 0a 20 20 61  Key->nCol );.  a
5d40: 73 73 65 72 74 28 20 70 49 64 78 21 3d 30 20 7c  ssert( pIdx!=0 |
5d50: 7c 20 70 46 4b 65 79 2d 3e 6e 43 6f 6c 3d 3d 31  | pFKey->nCol==1
5d60: 20 29 3b 0a 20 20 61 73 73 65 72 74 28 20 70 49   );.  assert( pI
5d70: 64 78 21 3d 30 20 7c 7c 20 48 61 73 52 6f 77 69  dx!=0 || HasRowi
5d80: 64 28 70 54 61 62 29 20 29 3b 0a 0a 20 20 69 66  d(pTab) );..  if
5d90: 28 20 6e 49 6e 63 72 3c 30 20 29 7b 0a 20 20 20  ( nIncr<0 ){.   
5da0: 20 69 46 6b 49 66 5a 65 72 6f 20 3d 20 73 71 6c   iFkIfZero = sql
5db0: 69 74 65 33 56 64 62 65 41 64 64 4f 70 32 28 76  ite3VdbeAddOp2(v
5dc0: 2c 20 4f 50 5f 46 6b 49 66 5a 65 72 6f 2c 20 70  , OP_FkIfZero, p
5dd0: 46 4b 65 79 2d 3e 69 73 44 65 66 65 72 72 65 64  FKey->isDeferred
5de0: 2c 20 30 29 3b 0a 20 20 20 20 56 64 62 65 43 6f  , 0);.    VdbeCo
5df0: 76 65 72 61 67 65 28 76 29 3b 0a 20 20 7d 0a 0a  verage(v);.  }..
5e00: 20 20 2f 2a 20 43 72 65 61 74 65 20 61 6e 20 45    /* Create an E
5e10: 78 70 72 20 6f 62 6a 65 63 74 20 72 65 70 72 65  xpr object repre
5e20: 73 65 6e 74 69 6e 67 20 61 6e 20 53 51 4c 20 65  senting an SQL e
5e30: 78 70 72 65 73 73 69 6f 6e 20 6c 69 6b 65 3a 0a  xpression like:.
5e40: 20 20 2a 2a 0a 20 20 2a 2a 20 20 20 3c 70 61 72    **.  **   <par
5e50: 65 6e 74 2d 6b 65 79 31 3e 20 3d 20 3c 63 68 69  ent-key1> = <chi
5e60: 6c 64 2d 6b 65 79 31 3e 20 41 4e 44 20 3c 70 61  ld-key1> AND <pa
5e70: 72 65 6e 74 2d 6b 65 79 32 3e 20 3d 20 3c 63 68  rent-key2> = <ch
5e80: 69 6c 64 2d 6b 65 79 32 3e 20 2e 2e 2e 0a 20 20  ild-key2> ....  
5e90: 2a 2a 0a 20 20 2a 2a 20 54 68 65 20 63 6f 6c 6c  **.  ** The coll
5ea0: 61 74 69 6f 6e 20 73 65 71 75 65 6e 63 65 20 75  ation sequence u
5eb0: 73 65 64 20 66 6f 72 20 74 68 65 20 63 6f 6d 70  sed for the comp
5ec0: 61 72 69 73 6f 6e 20 73 68 6f 75 6c 64 20 62 65  arison should be
5ed0: 20 74 68 61 74 20 6f 66 0a 20 20 2a 2a 20 74 68   that of.  ** th
5ee0: 65 20 70 61 72 65 6e 74 20 6b 65 79 20 63 6f 6c  e parent key col
5ef0: 75 6d 6e 73 2e 20 54 68 65 20 61 66 66 69 6e 69  umns. The affini
5f00: 74 79 20 6f 66 20 74 68 65 20 70 61 72 65 6e 74  ty of the parent
5f10: 20 6b 65 79 20 63 6f 6c 75 6d 6e 20 73 68 6f 75   key column shou
5f20: 6c 64 0a 20 20 2a 2a 20 62 65 20 61 70 70 6c 69  ld.  ** be appli
5f30: 65 64 20 74 6f 20 65 61 63 68 20 63 68 69 6c 64  ed to each child
5f40: 20 6b 65 79 20 76 61 6c 75 65 20 62 65 66 6f 72   key value befor
5f50: 65 20 74 68 65 20 63 6f 6d 70 61 72 69 73 6f 6e  e the comparison
5f60: 20 74 61 6b 65 73 20 70 6c 61 63 65 2e 0a 20 20   takes place..  
5f70: 2a 2f 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c  */.  for(i=0; i<
5f80: 70 46 4b 65 79 2d 3e 6e 43 6f 6c 3b 20 69 2b 2b  pFKey->nCol; i++
5f90: 29 7b 0a 20 20 20 20 45 78 70 72 20 2a 70 4c 65  ){.    Expr *pLe
5fa0: 66 74 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  ft;             
5fb0: 20 20 20 20 20 2f 2a 20 56 61 6c 75 65 20 66 72       /* Value fr
5fc0: 6f 6d 20 70 61 72 65 6e 74 20 74 61 62 6c 65 20  om parent table 
5fd0: 72 6f 77 20 2a 2f 0a 20 20 20 20 45 78 70 72 20  row */.    Expr 
5fe0: 2a 70 52 69 67 68 74 3b 20 20 20 20 20 20 20 20  *pRight;        
5ff0: 20 20 20 20 20 20 20 20 20 2f 2a 20 43 6f 6c 75           /* Colu
6000: 6d 6e 20 72 65 66 20 74 6f 20 63 68 69 6c 64 20  mn ref to child 
6010: 74 61 62 6c 65 20 2a 2f 0a 20 20 20 20 45 78 70  table */.    Exp
6020: 72 20 2a 70 45 71 3b 20 20 20 20 20 20 20 20 20  r *pEq;         
6030: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 45 78             /* Ex
6040: 70 72 65 73 73 69 6f 6e 20 28 70 4c 65 66 74 20  pression (pLeft 
6050: 3d 20 70 52 69 67 68 74 29 20 2a 2f 0a 20 20 20  = pRight) */.   
6060: 20 69 31 36 20 69 43 6f 6c 3b 20 20 20 20 20 20   i16 iCol;      
6070: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
6080: 2a 20 49 6e 64 65 78 20 6f 66 20 63 6f 6c 75 6d  * Index of colum
6090: 6e 20 69 6e 20 63 68 69 6c 64 20 74 61 62 6c 65  n in child table
60a0: 20 2a 2f 20 0a 20 20 20 20 63 6f 6e 73 74 20 63   */ .    const c
60b0: 68 61 72 20 2a 7a 43 6f 6c 3b 20 20 20 20 20 20  har *zCol;      
60c0: 20 20 20 20 20 20 20 2f 2a 20 4e 61 6d 65 20 6f         /* Name o
60d0: 66 20 63 6f 6c 75 6d 6e 20 69 6e 20 63 68 69 6c  f column in chil
60e0: 64 20 74 61 62 6c 65 20 2a 2f 0a 0a 20 20 20 20  d table */..    
60f0: 69 43 6f 6c 20 3d 20 70 49 64 78 20 3f 20 70 49  iCol = pIdx ? pI
6100: 64 78 2d 3e 61 69 43 6f 6c 75 6d 6e 5b 69 5d 20  dx->aiColumn[i] 
6110: 3a 20 2d 31 3b 0a 20 20 20 20 70 4c 65 66 74 20  : -1;.    pLeft 
6120: 3d 20 65 78 70 72 54 61 62 6c 65 52 65 67 69 73  = exprTableRegis
6130: 74 65 72 28 70 50 61 72 73 65 2c 20 70 54 61 62  ter(pParse, pTab
6140: 2c 20 72 65 67 44 61 74 61 2c 20 69 43 6f 6c 29  , regData, iCol)
6150: 3b 0a 20 20 20 20 69 43 6f 6c 20 3d 20 61 69 43  ;.    iCol = aiC
6160: 6f 6c 20 3f 20 61 69 43 6f 6c 5b 69 5d 20 3a 20  ol ? aiCol[i] : 
6170: 70 46 4b 65 79 2d 3e 61 43 6f 6c 5b 30 5d 2e 69  pFKey->aCol[0].i
6180: 46 72 6f 6d 3b 0a 20 20 20 20 61 73 73 65 72 74  From;.    assert
6190: 28 20 69 43 6f 6c 3e 3d 30 20 29 3b 0a 20 20 20  ( iCol>=0 );.   
61a0: 20 7a 43 6f 6c 20 3d 20 70 46 4b 65 79 2d 3e 70   zCol = pFKey->p
61b0: 46 72 6f 6d 2d 3e 61 43 6f 6c 5b 69 43 6f 6c 5d  From->aCol[iCol]
61c0: 2e 7a 4e 61 6d 65 3b 0a 20 20 20 20 70 52 69 67  .zName;.    pRig
61d0: 68 74 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72  ht = sqlite3Expr
61e0: 28 64 62 2c 20 54 4b 5f 49 44 2c 20 7a 43 6f 6c  (db, TK_ID, zCol
61f0: 29 3b 0a 20 20 20 20 70 45 71 20 3d 20 73 71 6c  );.    pEq = sql
6200: 69 74 65 33 50 45 78 70 72 28 70 50 61 72 73 65  ite3PExpr(pParse
6210: 2c 20 54 4b 5f 45 51 2c 20 70 4c 65 66 74 2c 20  , TK_EQ, pLeft, 
6220: 70 52 69 67 68 74 29 3b 0a 20 20 20 20 70 57 68  pRight);.    pWh
6230: 65 72 65 20 3d 20 73 71 6c 69 74 65 33 45 78 70  ere = sqlite3Exp
6240: 72 41 6e 64 28 70 50 61 72 73 65 2c 20 70 57 68  rAnd(pParse, pWh
6250: 65 72 65 2c 20 70 45 71 29 3b 0a 20 20 7d 0a 0a  ere, pEq);.  }..
6260: 20 20 2f 2a 20 49 66 20 74 68 65 20 63 68 69 6c    /* If the chil
6270: 64 20 74 61 62 6c 65 20 69 73 20 74 68 65 20 73  d table is the s
6280: 61 6d 65 20 61 73 20 74 68 65 20 70 61 72 65 6e  ame as the paren
6290: 74 20 74 61 62 6c 65 2c 20 74 68 65 6e 20 61 64  t table, then ad
62a0: 64 20 74 65 72 6d 73 0a 20 20 2a 2a 20 74 6f 20  d terms.  ** to 
62b0: 74 68 65 20 57 48 45 52 45 20 63 6c 61 75 73 65  the WHERE clause
62c0: 20 74 68 61 74 20 70 72 65 76 65 6e 74 20 74 68   that prevent th
62d0: 69 73 20 65 6e 74 72 79 20 66 72 6f 6d 20 62 65  is entry from be
62e0: 69 6e 67 20 73 63 61 6e 6e 65 64 2e 0a 20 20 2a  ing scanned..  *
62f0: 2a 20 54 68 65 20 61 64 64 65 64 20 57 48 45 52  * The added WHER
6300: 45 20 63 6c 61 75 73 65 20 74 65 72 6d 73 20 61  E clause terms a
6310: 72 65 20 6c 69 6b 65 20 74 68 69 73 3a 0a 20 20  re like this:.  
6320: 2a 2a 0a 20 20 2a 2a 20 20 20 20 20 24 63 75 72  **.  **     $cur
6330: 72 65 6e 74 5f 72 6f 77 69 64 21 3d 72 6f 77 69  rent_rowid!=rowi
6340: 64 0a 20 20 2a 2a 20 20 20 20 20 4e 4f 54 28 20  d.  **     NOT( 
6350: 24 63 75 72 72 65 6e 74 5f 61 3d 3d 61 20 41 4e  $current_a==a AN
6360: 44 20 24 63 75 72 72 65 6e 74 5f 62 3d 3d 62 20  D $current_b==b 
6370: 41 4e 44 20 2e 2e 2e 20 29 0a 20 20 2a 2a 0a 20  AND ... ).  **. 
6380: 20 2a 2a 20 54 68 65 20 66 69 72 73 74 20 66 6f   ** The first fo
6390: 72 6d 20 69 73 20 75 73 65 64 20 66 6f 72 20 72  rm is used for r
63a0: 6f 77 69 64 20 74 61 62 6c 65 73 2e 20 20 54 68  owid tables.  Th
63b0: 65 20 73 65 63 6f 6e 64 20 66 6f 72 6d 20 69 73  e second form is
63c0: 20 75 73 65 64 0a 20 20 2a 2a 20 66 6f 72 20 57   used.  ** for W
63d0: 49 54 48 4f 55 54 20 52 4f 57 49 44 20 74 61 62  ITHOUT ROWID tab
63e0: 6c 65 73 2e 20 49 6e 20 74 68 65 20 73 65 63 6f  les. In the seco
63f0: 6e 64 20 66 6f 72 6d 2c 20 74 68 65 20 2a 70 61  nd form, the *pa
6400: 72 65 6e 74 2a 20 6b 65 79 20 69 73 0a 20 20 2a  rent* key is.  *
6410: 2a 20 28 61 2c 62 2c 2e 2e 2e 29 2e 20 45 69 74  * (a,b,...). Eit
6420: 68 65 72 20 74 68 65 20 70 61 72 65 6e 74 20 6f  her the parent o
6430: 72 20 70 72 69 6d 61 72 79 20 6b 65 79 20 63 6f  r primary key co
6440: 75 6c 64 20 62 65 20 75 73 65 64 20 74 6f 20 0a  uld be used to .
6450: 20 20 2a 2a 20 75 6e 69 71 75 65 6c 79 20 69 64    ** uniquely id
6460: 65 6e 74 69 66 79 20 74 68 65 20 63 75 72 72 65  entify the curre
6470: 6e 74 20 72 6f 77 2c 20 62 75 74 20 74 68 65 20  nt row, but the 
6480: 70 61 72 65 6e 74 20 6b 65 79 20 69 73 20 6d 6f  parent key is mo
6490: 72 65 20 63 6f 6e 76 65 6e 69 65 6e 74 0a 20 20  re convenient.  
64a0: 2a 2a 20 61 73 20 74 68 65 20 72 65 71 75 69 72  ** as the requir
64b0: 65 64 20 76 61 6c 75 65 73 20 68 61 76 65 20 61  ed values have a
64c0: 6c 72 65 61 64 79 20 62 65 65 6e 20 6c 6f 61 64  lready been load
64d0: 65 64 20 69 6e 74 6f 20 72 65 67 69 73 74 65 72  ed into register
64e0: 73 0a 20 20 2a 2a 20 62 79 20 74 68 65 20 63 61  s.  ** by the ca
64f0: 6c 6c 65 72 2e 0a 20 20 2a 2f 0a 20 20 69 66 28  ller..  */.  if(
6500: 20 70 54 61 62 3d 3d 70 46 4b 65 79 2d 3e 70 46   pTab==pFKey->pF
6510: 72 6f 6d 20 26 26 20 6e 49 6e 63 72 3e 30 20 29  rom && nIncr>0 )
6520: 7b 0a 20 20 20 20 45 78 70 72 20 2a 70 4e 65 3b  {.    Expr *pNe;
6530: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6540: 20 20 20 20 2f 2a 20 45 78 70 72 65 73 73 69 6f      /* Expressio
6550: 6e 20 28 70 4c 65 66 74 20 21 3d 20 70 52 69 67  n (pLeft != pRig
6560: 68 74 29 20 2a 2f 0a 20 20 20 20 45 78 70 72 20  ht) */.    Expr 
6570: 2a 70 4c 65 66 74 3b 20 20 20 20 20 20 20 20 20  *pLeft;         
6580: 20 20 20 20 20 20 20 20 20 2f 2a 20 56 61 6c 75           /* Valu
6590: 65 20 66 72 6f 6d 20 70 61 72 65 6e 74 20 74 61  e from parent ta
65a0: 62 6c 65 20 72 6f 77 20 2a 2f 0a 20 20 20 20 45  ble row */.    E
65b0: 78 70 72 20 2a 70 52 69 67 68 74 3b 20 20 20 20  xpr *pRight;    
65c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
65d0: 43 6f 6c 75 6d 6e 20 72 65 66 20 74 6f 20 63 68  Column ref to ch
65e0: 69 6c 64 20 74 61 62 6c 65 20 2a 2f 0a 20 20 20  ild table */.   
65f0: 20 69 66 28 20 48 61 73 52 6f 77 69 64 28 70 54   if( HasRowid(pT
6600: 61 62 29 20 29 7b 0a 20 20 20 20 20 20 70 4c 65  ab) ){.      pLe
6610: 66 74 20 3d 20 65 78 70 72 54 61 62 6c 65 52 65  ft = exprTableRe
6620: 67 69 73 74 65 72 28 70 50 61 72 73 65 2c 20 70  gister(pParse, p
6630: 54 61 62 2c 20 72 65 67 44 61 74 61 2c 20 2d 31  Tab, regData, -1
6640: 29 3b 0a 20 20 20 20 20 20 70 52 69 67 68 74 20  );.      pRight 
6650: 3d 20 65 78 70 72 54 61 62 6c 65 43 6f 6c 75 6d  = exprTableColum
6660: 6e 28 64 62 2c 20 70 54 61 62 2c 20 70 53 72 63  n(db, pTab, pSrc
6670: 2d 3e 61 5b 30 5d 2e 69 43 75 72 73 6f 72 2c 20  ->a[0].iCursor, 
6680: 2d 31 29 3b 0a 20 20 20 20 20 20 70 4e 65 20 3d  -1);.      pNe =
6690: 20 73 71 6c 69 74 65 33 50 45 78 70 72 28 70 50   sqlite3PExpr(pP
66a0: 61 72 73 65 2c 20 54 4b 5f 4e 45 2c 20 70 4c 65  arse, TK_NE, pLe
66b0: 66 74 2c 20 70 52 69 67 68 74 29 3b 0a 20 20 20  ft, pRight);.   
66c0: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 45 78   }else{.      Ex
66d0: 70 72 20 2a 70 45 71 2c 20 2a 70 41 6c 6c 20 3d  pr *pEq, *pAll =
66e0: 20 30 3b 0a 20 20 20 20 20 20 61 73 73 65 72 74   0;.      assert
66f0: 28 20 70 49 64 78 21 3d 30 20 29 3b 0a 20 20 20  ( pIdx!=0 );.   
6700: 20 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 49     for(i=0; i<pI
6710: 64 78 2d 3e 6e 4b 65 79 43 6f 6c 3b 20 69 2b 2b  dx->nKeyCol; i++
6720: 29 7b 0a 20 20 20 20 20 20 20 20 69 31 36 20 69  ){.        i16 i
6730: 43 6f 6c 20 3d 20 70 49 64 78 2d 3e 61 69 43 6f  Col = pIdx->aiCo
6740: 6c 75 6d 6e 5b 69 5d 3b 0a 20 20 20 20 20 20 20  lumn[i];.       
6750: 20 61 73 73 65 72 74 28 20 69 43 6f 6c 3e 3d 30   assert( iCol>=0
6760: 20 29 3b 0a 20 20 20 20 20 20 20 20 70 4c 65 66   );.        pLef
6770: 74 20 3d 20 65 78 70 72 54 61 62 6c 65 52 65 67  t = exprTableReg
6780: 69 73 74 65 72 28 70 50 61 72 73 65 2c 20 70 54  ister(pParse, pT
6790: 61 62 2c 20 72 65 67 44 61 74 61 2c 20 69 43 6f  ab, regData, iCo
67a0: 6c 29 3b 0a 20 20 20 20 20 20 20 20 70 52 69 67  l);.        pRig
67b0: 68 74 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72  ht = sqlite3Expr
67c0: 28 64 62 2c 20 54 4b 5f 49 44 2c 20 70 54 61 62  (db, TK_ID, pTab
67d0: 2d 3e 61 43 6f 6c 5b 69 43 6f 6c 5d 2e 7a 4e 61  ->aCol[iCol].zNa
67e0: 6d 65 29 3b 0a 20 20 20 20 20 20 20 20 70 45 71  me);.        pEq
67f0: 20 3d 20 73 71 6c 69 74 65 33 50 45 78 70 72 28   = sqlite3PExpr(
6800: 70 50 61 72 73 65 2c 20 54 4b 5f 49 53 2c 20 70  pParse, TK_IS, p
6810: 4c 65 66 74 2c 20 70 52 69 67 68 74 29 3b 0a 20  Left, pRight);. 
6820: 20 20 20 20 20 20 20 70 41 6c 6c 20 3d 20 73 71         pAll = sq
6830: 6c 69 74 65 33 45 78 70 72 41 6e 64 28 70 50 61  lite3ExprAnd(pPa
6840: 72 73 65 2c 20 70 41 6c 6c 2c 20 70 45 71 29 3b  rse, pAll, pEq);
6850: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 70  .      }.      p
6860: 4e 65 20 3d 20 73 71 6c 69 74 65 33 50 45 78 70  Ne = sqlite3PExp
6870: 72 28 70 50 61 72 73 65 2c 20 54 4b 5f 4e 4f 54  r(pParse, TK_NOT
6880: 2c 20 70 41 6c 6c 2c 20 30 29 3b 0a 20 20 20 20  , pAll, 0);.    
6890: 7d 0a 20 20 20 20 70 57 68 65 72 65 20 3d 20 73  }.    pWhere = s
68a0: 71 6c 69 74 65 33 45 78 70 72 41 6e 64 28 70 50  qlite3ExprAnd(pP
68b0: 61 72 73 65 2c 20 70 57 68 65 72 65 2c 20 70 4e  arse, pWhere, pN
68c0: 65 29 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 52 65  e);.  }..  /* Re
68d0: 73 6f 6c 76 65 20 74 68 65 20 72 65 66 65 72 65  solve the refere
68e0: 6e 63 65 73 20 69 6e 20 74 68 65 20 57 48 45 52  nces in the WHER
68f0: 45 20 63 6c 61 75 73 65 2e 20 2a 2f 0a 20 20 6d  E clause. */.  m
6900: 65 6d 73 65 74 28 26 73 4e 61 6d 65 43 6f 6e 74  emset(&sNameCont
6910: 65 78 74 2c 20 30 2c 20 73 69 7a 65 6f 66 28 4e  ext, 0, sizeof(N
6920: 61 6d 65 43 6f 6e 74 65 78 74 29 29 3b 0a 20 20  ameContext));.  
6930: 73 4e 61 6d 65 43 6f 6e 74 65 78 74 2e 70 53 72  sNameContext.pSr
6940: 63 4c 69 73 74 20 3d 20 70 53 72 63 3b 0a 20 20  cList = pSrc;.  
6950: 73 4e 61 6d 65 43 6f 6e 74 65 78 74 2e 70 50 61  sNameContext.pPa
6960: 72 73 65 20 3d 20 70 50 61 72 73 65 3b 0a 20 20  rse = pParse;.  
6970: 73 71 6c 69 74 65 33 52 65 73 6f 6c 76 65 45 78  sqlite3ResolveEx
6980: 70 72 4e 61 6d 65 73 28 26 73 4e 61 6d 65 43 6f  prNames(&sNameCo
6990: 6e 74 65 78 74 2c 20 70 57 68 65 72 65 29 3b 0a  ntext, pWhere);.
69a0: 0a 20 20 2f 2a 20 43 72 65 61 74 65 20 56 44 42  .  /* Create VDB
69b0: 45 20 74 6f 20 6c 6f 6f 70 20 74 68 72 6f 75 67  E to loop throug
69c0: 68 20 74 68 65 20 65 6e 74 72 69 65 73 20 69 6e  h the entries in
69d0: 20 70 53 72 63 20 74 68 61 74 20 6d 61 74 63 68   pSrc that match
69e0: 20 74 68 65 20 57 48 45 52 45 0a 20 20 2a 2a 20   the WHERE.  ** 
69f0: 63 6c 61 75 73 65 2e 20 46 6f 72 20 65 61 63 68  clause. For each
6a00: 20 72 6f 77 20 66 6f 75 6e 64 2c 20 69 6e 63 72   row found, incr
6a10: 65 6d 65 6e 74 20 65 69 74 68 65 72 20 74 68 65  ement either the
6a20: 20 64 65 66 65 72 72 65 64 20 6f 72 20 69 6d 6d   deferred or imm
6a30: 65 64 69 61 74 65 0a 20 20 2a 2a 20 66 6f 72 65  ediate.  ** fore
6a40: 69 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61 69  ign key constrai
6a50: 6e 74 20 63 6f 75 6e 74 65 72 2e 20 2a 2f 0a 20  nt counter. */. 
6a60: 20 69 66 28 20 70 50 61 72 73 65 2d 3e 6e 45 72   if( pParse->nEr
6a70: 72 3d 3d 30 20 29 7b 0a 20 20 20 20 70 57 49 6e  r==0 ){.    pWIn
6a80: 66 6f 20 3d 20 73 71 6c 69 74 65 33 57 68 65 72  fo = sqlite3Wher
6a90: 65 42 65 67 69 6e 28 70 50 61 72 73 65 2c 20 70  eBegin(pParse, p
6aa0: 53 72 63 2c 20 70 57 68 65 72 65 2c 20 30 2c 20  Src, pWhere, 0, 
6ab0: 30 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 73 71  0, 0, 0);.    sq
6ac0: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32 28  lite3VdbeAddOp2(
6ad0: 76 2c 20 4f 50 5f 46 6b 43 6f 75 6e 74 65 72 2c  v, OP_FkCounter,
6ae0: 20 70 46 4b 65 79 2d 3e 69 73 44 65 66 65 72 72   pFKey->isDeferr
6af0: 65 64 2c 20 6e 49 6e 63 72 29 3b 0a 20 20 20 20  ed, nIncr);.    
6b00: 69 66 28 20 70 57 49 6e 66 6f 20 29 7b 0a 20 20  if( pWInfo ){.  
6b10: 20 20 20 20 73 71 6c 69 74 65 33 57 68 65 72 65      sqlite3Where
6b20: 45 6e 64 28 70 57 49 6e 66 6f 29 3b 0a 20 20 20  End(pWInfo);.   
6b30: 20 7d 0a 20 20 7d 0a 0a 20 20 2f 2a 20 43 6c 65   }.  }..  /* Cle
6b40: 61 6e 20 75 70 20 74 68 65 20 57 48 45 52 45 20  an up the WHERE 
6b50: 63 6c 61 75 73 65 20 63 6f 6e 73 74 72 75 63 74  clause construct
6b60: 65 64 20 61 62 6f 76 65 2e 20 2a 2f 0a 20 20 73  ed above. */.  s
6b70: 71 6c 69 74 65 33 45 78 70 72 44 65 6c 65 74 65  qlite3ExprDelete
6b80: 28 64 62 2c 20 70 57 68 65 72 65 29 3b 0a 20 20  (db, pWhere);.  
6b90: 69 66 28 20 69 46 6b 49 66 5a 65 72 6f 20 29 7b  if( iFkIfZero ){
6ba0: 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65  .    sqlite3Vdbe
6bb0: 4a 75 6d 70 48 65 72 65 28 76 2c 20 69 46 6b 49  JumpHere(v, iFkI
6bc0: 66 5a 65 72 6f 29 3b 0a 20 20 7d 0a 7d 0a 0a 2f  fZero);.  }.}../
6bd0: 2a 0a 2a 2a 20 54 68 69 73 20 66 75 6e 63 74 69  *.** This functi
6be0: 6f 6e 20 72 65 74 75 72 6e 73 20 61 20 6c 69 6e  on returns a lin
6bf0: 6b 65 64 20 6c 69 73 74 20 6f 66 20 46 4b 65 79  ked list of FKey
6c00: 20 6f 62 6a 65 63 74 73 20 28 63 6f 6e 6e 65 63   objects (connec
6c10: 74 65 64 20 62 79 0a 2a 2a 20 46 4b 65 79 2e 70  ted by.** FKey.p
6c20: 4e 65 78 74 54 6f 29 20 68 6f 6c 64 69 6e 67 20  NextTo) holding 
6c30: 61 6c 6c 20 63 68 69 6c 64 72 65 6e 20 6f 66 20  all children of 
6c40: 74 61 62 6c 65 20 70 54 61 62 2e 20 20 46 6f 72  table pTab.  For
6c50: 20 65 78 61 6d 70 6c 65 2c 0a 2a 2a 20 67 69 76   example,.** giv
6c60: 65 6e 20 74 68 65 20 66 6f 6c 6c 6f 77 69 6e 67  en the following
6c70: 20 73 63 68 65 6d 61 3a 0a 2a 2a 0a 2a 2a 20 20   schema:.**.**  
6c80: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31   CREATE TABLE t1
6c90: 28 61 20 50 52 49 4d 41 52 59 20 4b 45 59 29 3b  (a PRIMARY KEY);
6ca0: 0a 2a 2a 20 20 20 43 52 45 41 54 45 20 54 41 42  .**   CREATE TAB
6cb0: 4c 45 20 74 32 28 62 20 52 45 46 45 52 45 4e 43  LE t2(b REFERENC
6cc0: 45 53 20 74 31 28 61 29 3b 0a 2a 2a 0a 2a 2a 20  ES t1(a);.**.** 
6cd0: 43 61 6c 6c 69 6e 67 20 74 68 69 73 20 66 75 6e  Calling this fun
6ce0: 63 74 69 6f 6e 20 77 69 74 68 20 74 61 62 6c 65  ction with table
6cf0: 20 22 74 31 22 20 61 73 20 61 6e 20 61 72 67 75   "t1" as an argu
6d00: 6d 65 6e 74 20 72 65 74 75 72 6e 73 20 61 20 70  ment returns a p
6d10: 6f 69 6e 74 65 72 0a 2a 2a 20 74 6f 20 74 68 65  ointer.** to the
6d20: 20 46 4b 65 79 20 73 74 72 75 63 74 75 72 65 20   FKey structure 
6d30: 72 65 70 72 65 73 65 6e 74 69 6e 67 20 74 68 65  representing the
6d40: 20 66 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e   foreign key con
6d50: 73 74 72 61 69 6e 74 20 6f 6e 20 74 61 62 6c 65  straint on table
6d60: 0a 2a 2a 20 22 74 32 22 2e 20 43 61 6c 6c 69 6e  .** "t2". Callin
6d70: 67 20 74 68 69 73 20 66 75 6e 63 74 69 6f 6e 20  g this function 
6d80: 77 69 74 68 20 22 74 32 22 20 61 73 20 74 68 65  with "t2" as the
6d90: 20 61 72 67 75 6d 65 6e 74 20 77 6f 75 6c 64 20   argument would 
6da0: 72 65 74 75 72 6e 20 61 0a 2a 2a 20 4e 55 4c 4c  return a.** NULL
6db0: 20 70 6f 69 6e 74 65 72 20 28 61 73 20 74 68 65   pointer (as the
6dc0: 72 65 20 61 72 65 20 6e 6f 20 46 4b 20 63 6f 6e  re are no FK con
6dd0: 73 74 72 61 69 6e 74 73 20 66 6f 72 20 77 68 69  straints for whi
6de0: 63 68 20 74 32 20 69 73 20 74 68 65 20 70 61 72  ch t2 is the par
6df0: 65 6e 74 0a 2a 2a 20 74 61 62 6c 65 29 2e 0a 2a  ent.** table)..*
6e00: 2f 0a 46 4b 65 79 20 2a 73 71 6c 69 74 65 33 46  /.FKey *sqlite3F
6e10: 6b 52 65 66 65 72 65 6e 63 65 73 28 54 61 62 6c  kReferences(Tabl
6e20: 65 20 2a 70 54 61 62 29 7b 0a 20 20 72 65 74 75  e *pTab){.  retu
6e30: 72 6e 20 28 46 4b 65 79 20 2a 29 73 71 6c 69 74  rn (FKey *)sqlit
6e40: 65 33 48 61 73 68 46 69 6e 64 28 26 70 54 61 62  e3HashFind(&pTab
6e50: 2d 3e 70 53 63 68 65 6d 61 2d 3e 66 6b 65 79 48  ->pSchema->fkeyH
6e60: 61 73 68 2c 20 70 54 61 62 2d 3e 7a 4e 61 6d 65  ash, pTab->zName
6e70: 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20  );.}../*.** The 
6e80: 73 65 63 6f 6e 64 20 61 72 67 75 6d 65 6e 74 20  second argument 
6e90: 69 73 20 61 20 54 72 69 67 67 65 72 20 73 74 72  is a Trigger str
6ea0: 75 63 74 75 72 65 20 61 6c 6c 6f 63 61 74 65 64  ucture allocated
6eb0: 20 62 79 20 74 68 65 20 0a 2a 2a 20 66 6b 41 63   by the .** fkAc
6ec0: 74 69 6f 6e 54 72 69 67 67 65 72 28 29 20 72 6f  tionTrigger() ro
6ed0: 75 74 69 6e 65 2e 20 54 68 69 73 20 66 75 6e 63  utine. This func
6ee0: 74 69 6f 6e 20 64 65 6c 65 74 65 73 20 74 68 65  tion deletes the
6ef0: 20 54 72 69 67 67 65 72 20 73 74 72 75 63 74 75   Trigger structu
6f00: 72 65 0a 2a 2a 20 61 6e 64 20 61 6c 6c 20 6f 66  re.** and all of
6f10: 20 69 74 73 20 73 75 62 2d 63 6f 6d 70 6f 6e 65   its sub-compone
6f20: 6e 74 73 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 20 54  nts..**.** The T
6f30: 72 69 67 67 65 72 20 73 74 72 75 63 74 75 72 65  rigger structure
6f40: 20 6f 72 20 61 6e 79 20 6f 66 20 69 74 73 20 73   or any of its s
6f50: 75 62 2d 63 6f 6d 70 6f 6e 65 6e 74 73 20 6d 61  ub-components ma
6f60: 79 20 62 65 20 61 6c 6c 6f 63 61 74 65 64 20 66  y be allocated f
6f70: 72 6f 6d 0a 2a 2a 20 74 68 65 20 6c 6f 6f 6b 61  rom.** the looka
6f80: 73 69 64 65 20 62 75 66 66 65 72 20 62 65 6c 6f  side buffer belo
6f90: 6e 67 69 6e 67 20 74 6f 20 64 61 74 61 62 61 73  nging to databas
6fa0: 65 20 68 61 6e 64 6c 65 20 64 62 4d 65 6d 2e 0a  e handle dbMem..
6fb0: 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20 66  */.static void f
6fc0: 6b 54 72 69 67 67 65 72 44 65 6c 65 74 65 28 73  kTriggerDelete(s
6fd0: 71 6c 69 74 65 33 20 2a 64 62 4d 65 6d 2c 20 54  qlite3 *dbMem, T
6fe0: 72 69 67 67 65 72 20 2a 70 29 7b 0a 20 20 69 66  rigger *p){.  if
6ff0: 28 20 70 20 29 7b 0a 20 20 20 20 54 72 69 67 67  ( p ){.    Trigg
7000: 65 72 53 74 65 70 20 2a 70 53 74 65 70 20 3d 20  erStep *pStep = 
7010: 70 2d 3e 73 74 65 70 5f 6c 69 73 74 3b 0a 20 20  p->step_list;.  
7020: 20 20 73 71 6c 69 74 65 33 45 78 70 72 44 65 6c    sqlite3ExprDel
7030: 65 74 65 28 64 62 4d 65 6d 2c 20 70 53 74 65 70  ete(dbMem, pStep
7040: 2d 3e 70 57 68 65 72 65 29 3b 0a 20 20 20 20 73  ->pWhere);.    s
7050: 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74 44 65  qlite3ExprListDe
7060: 6c 65 74 65 28 64 62 4d 65 6d 2c 20 70 53 74 65  lete(dbMem, pSte
7070: 70 2d 3e 70 45 78 70 72 4c 69 73 74 29 3b 0a 20  p->pExprList);. 
7080: 20 20 20 73 71 6c 69 74 65 33 53 65 6c 65 63 74     sqlite3Select
7090: 44 65 6c 65 74 65 28 64 62 4d 65 6d 2c 20 70 53  Delete(dbMem, pS
70a0: 74 65 70 2d 3e 70 53 65 6c 65 63 74 29 3b 0a 20  tep->pSelect);. 
70b0: 20 20 20 73 71 6c 69 74 65 33 45 78 70 72 44 65     sqlite3ExprDe
70c0: 6c 65 74 65 28 64 62 4d 65 6d 2c 20 70 2d 3e 70  lete(dbMem, p->p
70d0: 57 68 65 6e 29 3b 0a 20 20 20 20 73 71 6c 69 74  When);.    sqlit
70e0: 65 33 44 62 46 72 65 65 28 64 62 4d 65 6d 2c 20  e3DbFree(dbMem, 
70f0: 70 29 3b 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a  p);.  }.}../*.**
7100: 20 54 68 69 73 20 66 75 6e 63 74 69 6f 6e 20 69   This function i
7110: 73 20 63 61 6c 6c 65 64 20 74 6f 20 67 65 6e 65  s called to gene
7120: 72 61 74 65 20 63 6f 64 65 20 74 68 61 74 20 72  rate code that r
7130: 75 6e 73 20 77 68 65 6e 20 74 61 62 6c 65 20 70  uns when table p
7140: 54 61 62 20 69 73 0a 2a 2a 20 62 65 69 6e 67 20  Tab is.** being 
7150: 64 72 6f 70 70 65 64 20 66 72 6f 6d 20 74 68 65  dropped from the
7160: 20 64 61 74 61 62 61 73 65 2e 20 54 68 65 20 53   database. The S
7170: 72 63 4c 69 73 74 20 70 61 73 73 65 64 20 61 73  rcList passed as
7180: 20 74 68 65 20 73 65 63 6f 6e 64 20 61 72 67 75   the second argu
7190: 6d 65 6e 74 0a 2a 2a 20 74 6f 20 74 68 69 73 20  ment.** to this 
71a0: 66 75 6e 63 74 69 6f 6e 20 63 6f 6e 74 61 69 6e  function contain
71b0: 73 20 61 20 73 69 6e 67 6c 65 20 65 6e 74 72 79  s a single entry
71c0: 20 67 75 61 72 61 6e 74 65 65 64 20 74 6f 20 72   guaranteed to r
71d0: 65 73 6f 6c 76 65 20 74 6f 0a 2a 2a 20 74 61 62  esolve to.** tab
71e0: 6c 65 20 70 54 61 62 2e 0a 2a 2a 0a 2a 2a 20 4e  le pTab..**.** N
71f0: 6f 72 6d 61 6c 6c 79 2c 20 6e 6f 20 63 6f 64 65  ormally, no code
7200: 20 69 73 20 72 65 71 75 69 72 65 64 2e 20 48 6f   is required. Ho
7210: 77 65 76 65 72 2c 20 69 66 20 65 69 74 68 65 72  wever, if either
7220: 0a 2a 2a 0a 2a 2a 20 20 20 28 61 29 20 54 68 65  .**.**   (a) The
7230: 20 74 61 62 6c 65 20 69 73 20 74 68 65 20 70 61   table is the pa
7240: 72 65 6e 74 20 74 61 62 6c 65 20 6f 66 20 61 20  rent table of a 
7250: 46 4b 20 63 6f 6e 73 74 72 61 69 6e 74 2c 20 6f  FK constraint, o
7260: 72 0a 2a 2a 20 20 20 28 62 29 20 54 68 65 20 74  r.**   (b) The t
7270: 61 62 6c 65 20 69 73 20 74 68 65 20 63 68 69 6c  able is the chil
7280: 64 20 74 61 62 6c 65 20 6f 66 20 61 20 64 65 66  d table of a def
7290: 65 72 72 65 64 20 46 4b 20 63 6f 6e 73 74 72 61  erred FK constra
72a0: 69 6e 74 20 61 6e 64 20 69 74 20 69 73 0a 2a 2a  int and it is.**
72b0: 20 20 20 20 20 20 20 64 65 74 65 72 6d 69 6e 65         determine
72c0: 64 20 61 74 20 72 75 6e 74 69 6d 65 20 74 68 61  d at runtime tha
72d0: 74 20 74 68 65 72 65 20 61 72 65 20 6f 75 74 73  t there are outs
72e0: 74 61 6e 64 69 6e 67 20 64 65 66 65 72 72 65 64  tanding deferred
72f0: 20 46 4b 20 0a 2a 2a 20 20 20 20 20 20 20 63 6f   FK .**       co
7300: 6e 73 74 72 61 69 6e 74 20 76 69 6f 6c 61 74 69  nstraint violati
7310: 6f 6e 73 20 69 6e 20 74 68 65 20 64 61 74 61 62  ons in the datab
7320: 61 73 65 2c 0a 2a 2a 0a 2a 2a 20 74 68 65 6e 20  ase,.**.** then 
7330: 74 68 65 20 65 71 75 69 76 61 6c 65 6e 74 20 6f  the equivalent o
7340: 66 20 22 44 45 4c 45 54 45 20 46 52 4f 4d 20 3c  f "DELETE FROM <
7350: 74 62 6c 3e 22 20 69 73 20 65 78 65 63 75 74 65  tbl>" is execute
7360: 64 20 62 65 66 6f 72 65 20 64 72 6f 70 70 69 6e  d before droppin
7370: 67 0a 2a 2a 20 74 68 65 20 74 61 62 6c 65 20 66  g.** the table f
7380: 72 6f 6d 20 74 68 65 20 64 61 74 61 62 61 73 65  rom the database
7390: 2e 20 54 72 69 67 67 65 72 73 20 61 72 65 20 64  . Triggers are d
73a0: 69 73 61 62 6c 65 64 20 77 68 69 6c 65 20 72 75  isabled while ru
73b0: 6e 6e 69 6e 67 20 74 68 69 73 0a 2a 2a 20 44 45  nning this.** DE
73c0: 4c 45 54 45 2c 20 62 75 74 20 66 6f 72 65 69 67  LETE, but foreig
73d0: 6e 20 6b 65 79 20 61 63 74 69 6f 6e 73 20 61 72  n key actions ar
73e0: 65 20 6e 6f 74 2e 0a 2a 2f 0a 76 6f 69 64 20 73  e not..*/.void s
73f0: 71 6c 69 74 65 33 46 6b 44 72 6f 70 54 61 62 6c  qlite3FkDropTabl
7400: 65 28 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c  e(Parse *pParse,
7410: 20 53 72 63 4c 69 73 74 20 2a 70 4e 61 6d 65 2c   SrcList *pName,
7420: 20 54 61 62 6c 65 20 2a 70 54 61 62 29 7b 0a 20   Table *pTab){. 
7430: 20 73 71 6c 69 74 65 33 20 2a 64 62 20 3d 20 70   sqlite3 *db = p
7440: 50 61 72 73 65 2d 3e 64 62 3b 0a 20 20 69 66 28  Parse->db;.  if(
7450: 20 28 64 62 2d 3e 66 6c 61 67 73 26 53 51 4c 49   (db->flags&SQLI
7460: 54 45 5f 46 6f 72 65 69 67 6e 4b 65 79 73 29 20  TE_ForeignKeys) 
7470: 26 26 20 21 49 73 56 69 72 74 75 61 6c 28 70 54  && !IsVirtual(pT
7480: 61 62 29 20 29 7b 0a 20 20 20 20 69 6e 74 20 69  ab) ){.    int i
7490: 53 6b 69 70 20 3d 20 30 3b 0a 20 20 20 20 56 64  Skip = 0;.    Vd
74a0: 62 65 20 2a 76 20 3d 20 73 71 6c 69 74 65 33 47  be *v = sqlite3G
74b0: 65 74 56 64 62 65 28 70 50 61 72 73 65 29 3b 0a  etVdbe(pParse);.
74c0: 0a 20 20 20 20 61 73 73 65 72 74 28 20 76 20 29  .    assert( v )
74d0: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
74e0: 20 20 20 2f 2a 20 56 44 42 45 20 68 61 73 20 61     /* VDBE has a
74f0: 6c 72 65 61 64 79 20 62 65 65 6e 20 61 6c 6c 6f  lready been allo
7500: 63 61 74 65 64 20 2a 2f 0a 20 20 20 20 61 73 73  cated */.    ass
7510: 65 72 74 28 20 70 54 61 62 2d 3e 70 53 65 6c 65  ert( pTab->pSele
7520: 63 74 3d 3d 30 20 29 3b 20 20 20 2f 2a 20 4e 6f  ct==0 );   /* No
7530: 74 20 61 20 76 69 65 77 20 2a 2f 0a 20 20 20 20  t a view */.    
7540: 69 66 28 20 73 71 6c 69 74 65 33 46 6b 52 65 66  if( sqlite3FkRef
7550: 65 72 65 6e 63 65 73 28 70 54 61 62 29 3d 3d 30  erences(pTab)==0
7560: 20 29 7b 0a 20 20 20 20 20 20 2f 2a 20 53 65 61   ){.      /* Sea
7570: 72 63 68 20 66 6f 72 20 61 20 64 65 66 65 72 72  rch for a deferr
7580: 65 64 20 66 6f 72 65 69 67 6e 20 6b 65 79 20 63  ed foreign key c
7590: 6f 6e 73 74 72 61 69 6e 74 20 66 6f 72 20 77 68  onstraint for wh
75a0: 69 63 68 20 74 68 69 73 20 74 61 62 6c 65 0a 20  ich this table. 
75b0: 20 20 20 20 20 2a 2a 20 69 73 20 74 68 65 20 63       ** is the c
75c0: 68 69 6c 64 20 74 61 62 6c 65 2e 20 49 66 20 6f  hild table. If o
75d0: 6e 65 20 63 61 6e 6e 6f 74 20 62 65 20 66 6f 75  ne cannot be fou
75e0: 6e 64 2c 20 72 65 74 75 72 6e 20 77 69 74 68 6f  nd, return witho
75f0: 75 74 20 0a 20 20 20 20 20 20 2a 2a 20 67 65 6e  ut .      ** gen
7600: 65 72 61 74 69 6e 67 20 61 6e 79 20 56 44 42 45  erating any VDBE
7610: 20 63 6f 64 65 2e 20 49 66 20 6f 6e 65 20 63 61   code. If one ca
7620: 6e 20 62 65 20 66 6f 75 6e 64 2c 20 74 68 65 6e  n be found, then
7630: 20 6a 75 6d 70 20 6f 76 65 72 0a 20 20 20 20 20   jump over.     
7640: 20 2a 2a 20 74 68 65 20 65 6e 74 69 72 65 20 44   ** the entire D
7650: 45 4c 45 54 45 20 69 66 20 74 68 65 72 65 20 61  ELETE if there a
7660: 72 65 20 6e 6f 20 6f 75 74 73 74 61 6e 64 69 6e  re no outstandin
7670: 67 20 64 65 66 65 72 72 65 64 20 63 6f 6e 73 74  g deferred const
7680: 72 61 69 6e 74 73 0a 20 20 20 20 20 20 2a 2a 20  raints.      ** 
7690: 77 68 65 6e 20 74 68 69 73 20 73 74 61 74 65 6d  when this statem
76a0: 65 6e 74 20 69 73 20 72 75 6e 2e 20 20 2a 2f 0a  ent is run.  */.
76b0: 20 20 20 20 20 20 46 4b 65 79 20 2a 70 3b 0a 20        FKey *p;. 
76c0: 20 20 20 20 20 66 6f 72 28 70 3d 70 54 61 62 2d       for(p=pTab-
76d0: 3e 70 46 4b 65 79 3b 20 70 3b 20 70 3d 70 2d 3e  >pFKey; p; p=p->
76e0: 70 4e 65 78 74 46 72 6f 6d 29 7b 0a 20 20 20 20  pNextFrom){.    
76f0: 20 20 20 20 69 66 28 20 70 2d 3e 69 73 44 65 66      if( p->isDef
7700: 65 72 72 65 64 20 7c 7c 20 28 64 62 2d 3e 66 6c  erred || (db->fl
7710: 61 67 73 20 26 20 53 51 4c 49 54 45 5f 44 65 66  ags & SQLITE_Def
7720: 65 72 46 4b 73 29 20 29 20 62 72 65 61 6b 3b 0a  erFKs) ) break;.
7730: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66        }.      if
7740: 28 20 21 70 20 29 20 72 65 74 75 72 6e 3b 0a 20  ( !p ) return;. 
7750: 20 20 20 20 20 69 53 6b 69 70 20 3d 20 73 71 6c       iSkip = sql
7760: 69 74 65 33 56 64 62 65 4d 61 6b 65 4c 61 62 65  ite3VdbeMakeLabe
7770: 6c 28 70 50 61 72 73 65 29 3b 0a 20 20 20 20 20  l(pParse);.     
7780: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
7790: 70 32 28 76 2c 20 4f 50 5f 46 6b 49 66 5a 65 72  p2(v, OP_FkIfZer
77a0: 6f 2c 20 31 2c 20 69 53 6b 69 70 29 3b 20 56 64  o, 1, iSkip); Vd
77b0: 62 65 43 6f 76 65 72 61 67 65 28 76 29 3b 0a 20  beCoverage(v);. 
77c0: 20 20 20 7d 0a 0a 20 20 20 20 70 50 61 72 73 65     }..    pParse
77d0: 2d 3e 64 69 73 61 62 6c 65 54 72 69 67 67 65 72  ->disableTrigger
77e0: 73 20 3d 20 31 3b 0a 20 20 20 20 73 71 6c 69 74  s = 1;.    sqlit
77f0: 65 33 44 65 6c 65 74 65 46 72 6f 6d 28 70 50 61  e3DeleteFrom(pPa
7800: 72 73 65 2c 20 73 71 6c 69 74 65 33 53 72 63 4c  rse, sqlite3SrcL
7810: 69 73 74 44 75 70 28 64 62 2c 20 70 4e 61 6d 65  istDup(db, pName
7820: 2c 20 30 29 2c 20 30 2c 20 30 2c 20 30 29 3b 0a  , 0), 0, 0, 0);.
7830: 20 20 20 20 70 50 61 72 73 65 2d 3e 64 69 73 61      pParse->disa
7840: 62 6c 65 54 72 69 67 67 65 72 73 20 3d 20 30 3b  bleTriggers = 0;
7850: 0a 0a 20 20 20 20 2f 2a 20 49 66 20 74 68 65 20  ..    /* If the 
7860: 44 45 4c 45 54 45 20 68 61 73 20 67 65 6e 65 72  DELETE has gener
7870: 61 74 65 64 20 69 6d 6d 65 64 69 61 74 65 20 66  ated immediate f
7880: 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73 74  oreign key const
7890: 72 61 69 6e 74 20 0a 20 20 20 20 2a 2a 20 76 69  raint .    ** vi
78a0: 6f 6c 61 74 69 6f 6e 73 2c 20 68 61 6c 74 20 74  olations, halt t
78b0: 68 65 20 56 44 42 45 20 61 6e 64 20 72 65 74 75  he VDBE and retu
78c0: 72 6e 20 61 6e 20 65 72 72 6f 72 20 61 74 20 74  rn an error at t
78d0: 68 69 73 20 70 6f 69 6e 74 2c 20 62 65 66 6f 72  his point, befor
78e0: 65 0a 20 20 20 20 2a 2a 20 61 6e 79 20 6d 6f 64  e.    ** any mod
78f0: 69 66 69 63 61 74 69 6f 6e 73 20 74 6f 20 74 68  ifications to th
7900: 65 20 73 63 68 65 6d 61 20 61 72 65 20 6d 61 64  e schema are mad
7910: 65 2e 20 54 68 69 73 20 69 73 20 62 65 63 61 75  e. This is becau
7920: 73 65 20 73 74 61 74 65 6d 65 6e 74 0a 20 20 20  se statement.   
7930: 20 2a 2a 20 74 72 61 6e 73 61 63 74 69 6f 6e 73   ** transactions
7940: 20 61 72 65 20 6e 6f 74 20 61 62 6c 65 20 74 6f   are not able to
7950: 20 72 6f 6c 6c 62 61 63 6b 20 73 63 68 65 6d 61   rollback schema
7960: 20 63 68 61 6e 67 65 73 2e 20 20 0a 20 20 20 20   changes.  .    
7970: 2a 2a 0a 20 20 20 20 2a 2a 20 49 66 20 74 68 65  **.    ** If the
7980: 20 53 51 4c 49 54 45 5f 44 65 66 65 72 46 4b 73   SQLITE_DeferFKs
7990: 20 66 6c 61 67 20 69 73 20 73 65 74 2c 20 74 68   flag is set, th
79a0: 65 6e 20 74 68 69 73 20 69 73 20 6e 6f 74 20 72  en this is not r
79b0: 65 71 75 69 72 65 64 2c 20 61 73 0a 20 20 20 20  equired, as.    
79c0: 2a 2a 20 74 68 65 20 73 74 61 74 65 6d 65 6e 74  ** the statement
79d0: 20 74 72 61 6e 73 61 63 74 69 6f 6e 20 77 69 6c   transaction wil
79e0: 6c 20 6e 6f 74 20 62 65 20 72 6f 6c 6c 65 64 20  l not be rolled 
79f0: 62 61 63 6b 20 65 76 65 6e 20 69 66 20 46 4b 0a  back even if FK.
7a00: 20 20 20 20 2a 2a 20 63 6f 6e 73 74 72 61 69 6e      ** constrain
7a10: 74 73 20 61 72 65 20 76 69 6f 6c 61 74 65 64 2e  ts are violated.
7a20: 0a 20 20 20 20 2a 2f 0a 20 20 20 20 69 66 28 20  .    */.    if( 
7a30: 28 64 62 2d 3e 66 6c 61 67 73 20 26 20 53 51 4c  (db->flags & SQL
7a40: 49 54 45 5f 44 65 66 65 72 46 4b 73 29 3d 3d 30  ITE_DeferFKs)==0
7a50: 20 29 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65   ){.      sqlite
7a60: 33 56 64 62 65 56 65 72 69 66 79 41 62 6f 72 74  3VdbeVerifyAbort
7a70: 61 62 6c 65 28 76 2c 20 4f 45 5f 41 62 6f 72 74  able(v, OE_Abort
7a80: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
7a90: 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50  VdbeAddOp2(v, OP
7aa0: 5f 46 6b 49 66 5a 65 72 6f 2c 20 30 2c 20 73 71  _FkIfZero, 0, sq
7ab0: 6c 69 74 65 33 56 64 62 65 43 75 72 72 65 6e 74  lite3VdbeCurrent
7ac0: 41 64 64 72 28 76 29 2b 32 29 3b 0a 20 20 20 20  Addr(v)+2);.    
7ad0: 20 20 56 64 62 65 43 6f 76 65 72 61 67 65 28 76    VdbeCoverage(v
7ae0: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
7af0: 48 61 6c 74 43 6f 6e 73 74 72 61 69 6e 74 28 70  HaltConstraint(p
7b00: 50 61 72 73 65 2c 20 53 51 4c 49 54 45 5f 43 4f  Parse, SQLITE_CO
7b10: 4e 53 54 52 41 49 4e 54 5f 46 4f 52 45 49 47 4e  NSTRAINT_FOREIGN
7b20: 4b 45 59 2c 0a 20 20 20 20 20 20 20 20 20 20 4f  KEY,.          O
7b30: 45 5f 41 62 6f 72 74 2c 20 30 2c 20 50 34 5f 53  E_Abort, 0, P4_S
7b40: 54 41 54 49 43 2c 20 50 35 5f 43 6f 6e 73 74 72  TATIC, P5_Constr
7b50: 61 69 6e 74 46 4b 29 3b 0a 20 20 20 20 7d 0a 0a  aintFK);.    }..
7b60: 20 20 20 20 69 66 28 20 69 53 6b 69 70 20 29 7b      if( iSkip ){
7b70: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
7b80: 62 65 52 65 73 6f 6c 76 65 4c 61 62 65 6c 28 76  beResolveLabel(v
7b90: 2c 20 69 53 6b 69 70 29 3b 0a 20 20 20 20 7d 0a  , iSkip);.    }.
7ba0: 20 20 7d 0a 7d 0a 0a 0a 2f 2a 0a 2a 2a 20 54 68    }.}.../*.** Th
7bb0: 65 20 73 65 63 6f 6e 64 20 61 72 67 75 6d 65 6e  e second argumen
7bc0: 74 20 70 6f 69 6e 74 73 20 74 6f 20 61 6e 20 46  t points to an F
7bd0: 4b 65 79 20 6f 62 6a 65 63 74 20 72 65 70 72 65  Key object repre
7be0: 73 65 6e 74 69 6e 67 20 61 20 66 6f 72 65 69 67  senting a foreig
7bf0: 6e 20 6b 65 79 0a 2a 2a 20 66 6f 72 20 77 68 69  n key.** for whi
7c00: 63 68 20 70 54 61 62 20 69 73 20 74 68 65 20 63  ch pTab is the c
7c10: 68 69 6c 64 20 74 61 62 6c 65 2e 20 41 6e 20 55  hild table. An U
7c20: 50 44 41 54 45 20 73 74 61 74 65 6d 65 6e 74 20  PDATE statement 
7c30: 61 67 61 69 6e 73 74 20 70 54 61 62 0a 2a 2a 20  against pTab.** 
7c40: 69 73 20 63 75 72 72 65 6e 74 6c 79 20 62 65 69  is currently bei
7c50: 6e 67 20 70 72 6f 63 65 73 73 65 64 2e 20 46 6f  ng processed. Fo
7c60: 72 20 65 61 63 68 20 63 6f 6c 75 6d 6e 20 6f 66  r each column of
7c70: 20 74 68 65 20 74 61 62 6c 65 20 74 68 61 74 20   the table that 
7c80: 69 73 20 0a 2a 2a 20 61 63 74 75 61 6c 6c 79 20  is .** actually 
7c90: 75 70 64 61 74 65 64 2c 20 74 68 65 20 63 6f 72  updated, the cor
7ca0: 72 65 73 70 6f 6e 64 69 6e 67 20 65 6c 65 6d 65  responding eleme
7cb0: 6e 74 20 69 6e 20 74 68 65 20 61 43 68 61 6e 67  nt in the aChang
7cc0: 65 5b 5d 20 61 72 72 61 79 0a 2a 2a 20 69 73 20  e[] array.** is 
7cd0: 7a 65 72 6f 20 6f 72 20 67 72 65 61 74 65 72 20  zero or greater 
7ce0: 28 69 66 20 61 20 63 6f 6c 75 6d 6e 20 69 73 20  (if a column is 
7cf0: 75 6e 6d 6f 64 69 66 69 65 64 20 74 68 65 20 63  unmodified the c
7d00: 6f 72 72 65 73 70 6f 6e 64 69 6e 67 20 65 6c 65  orresponding ele
7d10: 6d 65 6e 74 0a 2a 2a 20 69 73 20 73 65 74 20 74  ment.** is set t
7d20: 6f 20 2d 31 29 2e 20 49 66 20 74 68 65 20 72 6f  o -1). If the ro
7d30: 77 69 64 20 63 6f 6c 75 6d 6e 20 69 73 20 6d 6f  wid column is mo
7d40: 64 69 66 69 65 64 20 62 79 20 74 68 65 20 55 50  dified by the UP
7d50: 44 41 54 45 20 73 74 61 74 65 6d 65 6e 74 0a 2a  DATE statement.*
7d60: 2a 20 74 68 65 20 62 43 68 6e 67 52 6f 77 69 64  * the bChngRowid
7d70: 20 61 72 67 75 6d 65 6e 74 20 69 73 20 6e 6f 6e   argument is non
7d80: 2d 7a 65 72 6f 2e 0a 2a 2a 0a 2a 2a 20 54 68 69  -zero..**.** Thi
7d90: 73 20 66 75 6e 63 74 69 6f 6e 20 72 65 74 75 72  s function retur
7da0: 6e 73 20 74 72 75 65 20 69 66 20 61 6e 79 20 6f  ns true if any o
7db0: 66 20 74 68 65 20 63 6f 6c 75 6d 6e 73 20 74 68  f the columns th
7dc0: 61 74 20 61 72 65 20 70 61 72 74 20 6f 66 20 74  at are part of t
7dd0: 68 65 0a 2a 2a 20 63 68 69 6c 64 20 6b 65 79 20  he.** child key 
7de0: 66 6f 72 20 46 4b 20 63 6f 6e 73 74 72 61 69 6e  for FK constrain
7df0: 74 20 2a 70 20 61 72 65 20 6d 6f 64 69 66 69 65  t *p are modifie
7e00: 64 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74  d..*/.static int
7e10: 20 66 6b 43 68 69 6c 64 49 73 4d 6f 64 69 66 69   fkChildIsModifi
7e20: 65 64 28 0a 20 20 54 61 62 6c 65 20 2a 70 54 61  ed(.  Table *pTa
7e30: 62 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20  b,              
7e40: 20 20 20 20 20 20 2f 2a 20 54 61 62 6c 65 20 62        /* Table b
7e50: 65 69 6e 67 20 75 70 64 61 74 65 64 20 2a 2f 0a  eing updated */.
7e60: 20 20 46 4b 65 79 20 2a 70 2c 20 20 20 20 20 20    FKey *p,      
7e70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7e80: 20 20 2f 2a 20 46 6f 72 65 69 67 6e 20 6b 65 79    /* Foreign key
7e90: 20 66 6f 72 20 77 68 69 63 68 20 70 54 61 62 20   for which pTab 
7ea0: 69 73 20 74 68 65 20 63 68 69 6c 64 20 2a 2f 0a  is the child */.
7eb0: 20 20 69 6e 74 20 2a 61 43 68 61 6e 67 65 2c 20    int *aChange, 
7ec0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7ed0: 20 20 2f 2a 20 41 72 72 61 79 20 69 6e 64 69 63    /* Array indic
7ee0: 61 74 69 6e 67 20 6d 6f 64 69 66 69 65 64 20 63  ating modified c
7ef0: 6f 6c 75 6d 6e 73 20 2a 2f 0a 20 20 69 6e 74 20  olumns */.  int 
7f00: 62 43 68 6e 67 52 6f 77 69 64 20 20 20 20 20 20  bChngRowid      
7f10: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54              /* T
7f20: 72 75 65 20 69 66 20 72 6f 77 69 64 20 69 73 20  rue if rowid is 
7f30: 6d 6f 64 69 66 69 65 64 20 62 79 20 74 68 69 73  modified by this
7f40: 20 75 70 64 61 74 65 20 2a 2f 0a 29 7b 0a 20 20   update */.){.  
7f50: 69 6e 74 20 69 3b 0a 20 20 66 6f 72 28 69 3d 30  int i;.  for(i=0
7f60: 3b 20 69 3c 70 2d 3e 6e 43 6f 6c 3b 20 69 2b 2b  ; i<p->nCol; i++
7f70: 29 7b 0a 20 20 20 20 69 6e 74 20 69 43 68 69 6c  ){.    int iChil
7f80: 64 4b 65 79 20 3d 20 70 2d 3e 61 43 6f 6c 5b 69  dKey = p->aCol[i
7f90: 5d 2e 69 46 72 6f 6d 3b 0a 20 20 20 20 69 66 28  ].iFrom;.    if(
7fa0: 20 61 43 68 61 6e 67 65 5b 69 43 68 69 6c 64 4b   aChange[iChildK
7fb0: 65 79 5d 3e 3d 30 20 29 20 72 65 74 75 72 6e 20  ey]>=0 ) return 
7fc0: 31 3b 0a 20 20 20 20 69 66 28 20 69 43 68 69 6c  1;.    if( iChil
7fd0: 64 4b 65 79 3d 3d 70 54 61 62 2d 3e 69 50 4b 65  dKey==pTab->iPKe
7fe0: 79 20 26 26 20 62 43 68 6e 67 52 6f 77 69 64 20  y && bChngRowid 
7ff0: 29 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 7d 0a  ) return 1;.  }.
8000: 20 20 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a 2f    return 0;.}../
8010: 2a 0a 2a 2a 20 54 68 65 20 73 65 63 6f 6e 64 20  *.** The second 
8020: 61 72 67 75 6d 65 6e 74 20 70 6f 69 6e 74 73 20  argument points 
8030: 74 6f 20 61 6e 20 46 4b 65 79 20 6f 62 6a 65 63  to an FKey objec
8040: 74 20 72 65 70 72 65 73 65 6e 74 69 6e 67 20 61  t representing a
8050: 20 66 6f 72 65 69 67 6e 20 6b 65 79 0a 2a 2a 20   foreign key.** 
8060: 66 6f 72 20 77 68 69 63 68 20 70 54 61 62 20 69  for which pTab i
8070: 73 20 74 68 65 20 70 61 72 65 6e 74 20 74 61 62  s the parent tab
8080: 6c 65 2e 20 41 6e 20 55 50 44 41 54 45 20 73 74  le. An UPDATE st
8090: 61 74 65 6d 65 6e 74 20 61 67 61 69 6e 73 74 20  atement against 
80a0: 70 54 61 62 0a 2a 2a 20 69 73 20 63 75 72 72 65  pTab.** is curre
80b0: 6e 74 6c 79 20 62 65 69 6e 67 20 70 72 6f 63 65  ntly being proce
80c0: 73 73 65 64 2e 20 46 6f 72 20 65 61 63 68 20 63  ssed. For each c
80d0: 6f 6c 75 6d 6e 20 6f 66 20 74 68 65 20 74 61 62  olumn of the tab
80e0: 6c 65 20 74 68 61 74 20 69 73 20 0a 2a 2a 20 61  le that is .** a
80f0: 63 74 75 61 6c 6c 79 20 75 70 64 61 74 65 64 2c  ctually updated,
8100: 20 74 68 65 20 63 6f 72 72 65 73 70 6f 6e 64 69   the correspondi
8110: 6e 67 20 65 6c 65 6d 65 6e 74 20 69 6e 20 74 68  ng element in th
8120: 65 20 61 43 68 61 6e 67 65 5b 5d 20 61 72 72 61  e aChange[] arra
8130: 79 0a 2a 2a 20 69 73 20 7a 65 72 6f 20 6f 72 20  y.** is zero or 
8140: 67 72 65 61 74 65 72 20 28 69 66 20 61 20 63 6f  greater (if a co
8150: 6c 75 6d 6e 20 69 73 20 75 6e 6d 6f 64 69 66 69  lumn is unmodifi
8160: 65 64 20 74 68 65 20 63 6f 72 72 65 73 70 6f 6e  ed the correspon
8170: 64 69 6e 67 20 65 6c 65 6d 65 6e 74 0a 2a 2a 20  ding element.** 
8180: 69 73 20 73 65 74 20 74 6f 20 2d 31 29 2e 20 49  is set to -1). I
8190: 66 20 74 68 65 20 72 6f 77 69 64 20 63 6f 6c 75  f the rowid colu
81a0: 6d 6e 20 69 73 20 6d 6f 64 69 66 69 65 64 20 62  mn is modified b
81b0: 79 20 74 68 65 20 55 50 44 41 54 45 20 73 74 61  y the UPDATE sta
81c0: 74 65 6d 65 6e 74 0a 2a 2a 20 74 68 65 20 62 43  tement.** the bC
81d0: 68 6e 67 52 6f 77 69 64 20 61 72 67 75 6d 65 6e  hngRowid argumen
81e0: 74 20 69 73 20 6e 6f 6e 2d 7a 65 72 6f 2e 0a 2a  t is non-zero..*
81f0: 2a 0a 2a 2a 20 54 68 69 73 20 66 75 6e 63 74 69  *.** This functi
8200: 6f 6e 20 72 65 74 75 72 6e 73 20 74 72 75 65 20  on returns true 
8210: 69 66 20 61 6e 79 20 6f 66 20 74 68 65 20 63 6f  if any of the co
8220: 6c 75 6d 6e 73 20 74 68 61 74 20 61 72 65 20 70  lumns that are p
8230: 61 72 74 20 6f 66 20 74 68 65 0a 2a 2a 20 70 61  art of the.** pa
8240: 72 65 6e 74 20 6b 65 79 20 66 6f 72 20 46 4b 20  rent key for FK 
8250: 63 6f 6e 73 74 72 61 69 6e 74 20 2a 70 20 61 72  constraint *p ar
8260: 65 20 6d 6f 64 69 66 69 65 64 2e 0a 2a 2f 0a 73  e modified..*/.s
8270: 74 61 74 69 63 20 69 6e 74 20 66 6b 50 61 72 65  tatic int fkPare
8280: 6e 74 49 73 4d 6f 64 69 66 69 65 64 28 0a 20 20  ntIsModified(.  
8290: 54 61 62 6c 65 20 2a 70 54 61 62 2c 20 0a 20 20  Table *pTab, .  
82a0: 46 4b 65 79 20 2a 70 2c 20 0a 20 20 69 6e 74 20  FKey *p, .  int 
82b0: 2a 61 43 68 61 6e 67 65 2c 20 0a 20 20 69 6e 74  *aChange, .  int
82c0: 20 62 43 68 6e 67 52 6f 77 69 64 0a 29 7b 0a 20   bChngRowid.){. 
82d0: 20 69 6e 74 20 69 3b 0a 20 20 66 6f 72 28 69 3d   int i;.  for(i=
82e0: 30 3b 20 69 3c 70 2d 3e 6e 43 6f 6c 3b 20 69 2b  0; i<p->nCol; i+
82f0: 2b 29 7b 0a 20 20 20 20 63 68 61 72 20 2a 7a 4b  +){.    char *zK
8300: 65 79 20 3d 20 70 2d 3e 61 43 6f 6c 5b 69 5d 2e  ey = p->aCol[i].
8310: 7a 43 6f 6c 3b 0a 20 20 20 20 69 6e 74 20 69 4b  zCol;.    int iK
8320: 65 79 3b 0a 20 20 20 20 66 6f 72 28 69 4b 65 79  ey;.    for(iKey
8330: 3d 30 3b 20 69 4b 65 79 3c 70 54 61 62 2d 3e 6e  =0; iKey<pTab->n
8340: 43 6f 6c 3b 20 69 4b 65 79 2b 2b 29 7b 0a 20 20  Col; iKey++){.  
8350: 20 20 20 20 69 66 28 20 61 43 68 61 6e 67 65 5b      if( aChange[
8360: 69 4b 65 79 5d 3e 3d 30 20 7c 7c 20 28 69 4b 65  iKey]>=0 || (iKe
8370: 79 3d 3d 70 54 61 62 2d 3e 69 50 4b 65 79 20 26  y==pTab->iPKey &
8380: 26 20 62 43 68 6e 67 52 6f 77 69 64 29 20 29 7b  & bChngRowid) ){
8390: 0a 20 20 20 20 20 20 20 20 43 6f 6c 75 6d 6e 20  .        Column 
83a0: 2a 70 43 6f 6c 20 3d 20 26 70 54 61 62 2d 3e 61  *pCol = &pTab->a
83b0: 43 6f 6c 5b 69 4b 65 79 5d 3b 0a 20 20 20 20 20  Col[iKey];.     
83c0: 20 20 20 69 66 28 20 7a 4b 65 79 20 29 7b 0a 20     if( zKey ){. 
83d0: 20 20 20 20 20 20 20 20 20 69 66 28 20 30 3d 3d           if( 0==
83e0: 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28 70  sqlite3StrICmp(p
83f0: 43 6f 6c 2d 3e 7a 4e 61 6d 65 2c 20 7a 4b 65 79  Col->zName, zKey
8400: 29 20 29 20 72 65 74 75 72 6e 20 31 3b 0a 20 20  ) ) return 1;.  
8410: 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20        }else if( 
8420: 70 43 6f 6c 2d 3e 63 6f 6c 46 6c 61 67 73 20 26  pCol->colFlags &
8430: 20 43 4f 4c 46 4c 41 47 5f 50 52 49 4d 4b 45 59   COLFLAG_PRIMKEY
8440: 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 72 65   ){.          re
8450: 74 75 72 6e 20 31 3b 0a 20 20 20 20 20 20 20 20  turn 1;.        
8460: 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a  }.      }.    }.
8470: 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 30 3b 0a    }.  return 0;.
8480: 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e 20  }../*.** Return 
8490: 74 72 75 65 20 69 66 20 74 68 65 20 70 61 72 73  true if the pars
84a0: 65 72 20 70 61 73 73 65 64 20 61 73 20 74 68 65  er passed as the
84b0: 20 66 69 72 73 74 20 61 72 67 75 6d 65 6e 74 20   first argument 
84c0: 69 73 20 62 65 69 6e 67 0a 2a 2a 20 75 73 65 64  is being.** used
84d0: 20 74 6f 20 63 6f 64 65 20 61 20 74 72 69 67 67   to code a trigg
84e0: 65 72 20 74 68 61 74 20 69 73 20 72 65 61 6c 6c  er that is reall
84f0: 79 20 61 20 22 53 45 54 20 4e 55 4c 4c 22 20 61  y a "SET NULL" a
8500: 63 74 69 6f 6e 20 62 65 6c 6f 6e 67 69 6e 67 0a  ction belonging.
8510: 2a 2a 20 74 6f 20 74 72 69 67 67 65 72 20 70 46  ** to trigger pF
8520: 4b 65 79 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69  Key..*/.static i
8530: 6e 74 20 69 73 53 65 74 4e 75 6c 6c 41 63 74 69  nt isSetNullActi
8540: 6f 6e 28 50 61 72 73 65 20 2a 70 50 61 72 73 65  on(Parse *pParse
8550: 2c 20 46 4b 65 79 20 2a 70 46 4b 65 79 29 7b 0a  , FKey *pFKey){.
8560: 20 20 50 61 72 73 65 20 2a 70 54 6f 70 20 3d 20    Parse *pTop = 
8570: 73 71 6c 69 74 65 33 50 61 72 73 65 54 6f 70 6c  sqlite3ParseTopl
8580: 65 76 65 6c 28 70 50 61 72 73 65 29 3b 0a 20 20  evel(pParse);.  
8590: 69 66 28 20 70 54 6f 70 2d 3e 70 54 72 69 67 67  if( pTop->pTrigg
85a0: 65 72 50 72 67 20 29 7b 0a 20 20 20 20 54 72 69  erPrg ){.    Tri
85b0: 67 67 65 72 20 2a 70 20 3d 20 70 54 6f 70 2d 3e  gger *p = pTop->
85c0: 70 54 72 69 67 67 65 72 50 72 67 2d 3e 70 54 72  pTriggerPrg->pTr
85d0: 69 67 67 65 72 3b 0a 20 20 20 20 69 66 28 20 28  igger;.    if( (
85e0: 70 3d 3d 70 46 4b 65 79 2d 3e 61 70 54 72 69 67  p==pFKey->apTrig
85f0: 67 65 72 5b 30 5d 20 26 26 20 70 46 4b 65 79 2d  ger[0] && pFKey-
8600: 3e 61 41 63 74 69 6f 6e 5b 30 5d 3d 3d 4f 45 5f  >aAction[0]==OE_
8610: 53 65 74 4e 75 6c 6c 29 0a 20 20 20 20 20 7c 7c  SetNull).     ||
8620: 20 28 70 3d 3d 70 46 4b 65 79 2d 3e 61 70 54 72   (p==pFKey->apTr
8630: 69 67 67 65 72 5b 31 5d 20 26 26 20 70 46 4b 65  igger[1] && pFKe
8640: 79 2d 3e 61 41 63 74 69 6f 6e 5b 31 5d 3d 3d 4f  y->aAction[1]==O
8650: 45 5f 53 65 74 4e 75 6c 6c 29 0a 20 20 20 20 29  E_SetNull).    )
8660: 7b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 31  {.      return 1
8670: 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 72 65  ;.    }.  }.  re
8680: 74 75 72 6e 20 30 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  turn 0;.}../*.**
8690: 20 54 68 69 73 20 66 75 6e 63 74 69 6f 6e 20 69   This function i
86a0: 73 20 63 61 6c 6c 65 64 20 77 68 65 6e 20 69 6e  s called when in
86b0: 73 65 72 74 69 6e 67 2c 20 64 65 6c 65 74 69 6e  serting, deletin
86c0: 67 20 6f 72 20 75 70 64 61 74 69 6e 67 20 61 20  g or updating a 
86d0: 72 6f 77 20 6f 66 0a 2a 2a 20 74 61 62 6c 65 20  row of.** table 
86e0: 70 54 61 62 20 74 6f 20 67 65 6e 65 72 61 74 65  pTab to generate
86f0: 20 56 44 42 45 20 63 6f 64 65 20 74 6f 20 70 65   VDBE code to pe
8700: 72 66 6f 72 6d 20 66 6f 72 65 69 67 6e 20 6b 65  rform foreign ke
8710: 79 20 63 6f 6e 73 74 72 61 69 6e 74 20 0a 2a 2a  y constraint .**
8720: 20 70 72 6f 63 65 73 73 69 6e 67 20 66 6f 72 20   processing for 
8730: 74 68 65 20 6f 70 65 72 61 74 69 6f 6e 2e 0a 2a  the operation..*
8740: 2a 0a 2a 2a 20 46 6f 72 20 61 20 44 45 4c 45 54  *.** For a DELET
8750: 45 20 6f 70 65 72 61 74 69 6f 6e 2c 20 70 61 72  E operation, par
8760: 61 6d 65 74 65 72 20 72 65 67 4f 6c 64 20 69 73  ameter regOld is
8770: 20 70 61 73 73 65 64 20 74 68 65 20 69 6e 64 65   passed the inde
8780: 78 20 6f 66 20 74 68 65 0a 2a 2a 20 66 69 72 73  x of the.** firs
8790: 74 20 72 65 67 69 73 74 65 72 20 69 6e 20 61 6e  t register in an
87a0: 20 61 72 72 61 79 20 6f 66 20 28 70 54 61 62 2d   array of (pTab-
87b0: 3e 6e 43 6f 6c 2b 31 29 20 72 65 67 69 73 74 65  >nCol+1) registe
87c0: 72 73 20 63 6f 6e 74 61 69 6e 69 6e 67 20 74 68  rs containing th
87d0: 65 0a 2a 2a 20 72 6f 77 69 64 20 6f 66 20 74 68  e.** rowid of th
87e0: 65 20 72 6f 77 20 62 65 69 6e 67 20 64 65 6c 65  e row being dele
87f0: 74 65 64 2c 20 66 6f 6c 6c 6f 77 65 64 20 62 79  ted, followed by
8800: 20 65 61 63 68 20 6f 66 20 74 68 65 20 63 6f 6c   each of the col
8810: 75 6d 6e 20 76 61 6c 75 65 73 0a 2a 2a 20 6f 66  umn values.** of
8820: 20 74 68 65 20 72 6f 77 20 62 65 69 6e 67 20 64   the row being d
8830: 65 6c 65 74 65 64 2c 20 66 72 6f 6d 20 6c 65 66  eleted, from lef
8840: 74 20 74 6f 20 72 69 67 68 74 2e 20 50 61 72 61  t to right. Para
8850: 6d 65 74 65 72 20 72 65 67 4e 65 77 20 69 73 20  meter regNew is 
8860: 70 61 73 73 65 64 0a 2a 2a 20 7a 65 72 6f 20 69  passed.** zero i
8870: 6e 20 74 68 69 73 20 63 61 73 65 2e 0a 2a 2a 0a  n this case..**.
8880: 2a 2a 20 46 6f 72 20 61 6e 20 49 4e 53 45 52 54  ** For an INSERT
8890: 20 6f 70 65 72 61 74 69 6f 6e 2c 20 72 65 67 4f   operation, regO
88a0: 6c 64 20 69 73 20 70 61 73 73 65 64 20 7a 65 72  ld is passed zer
88b0: 6f 20 61 6e 64 20 72 65 67 4e 65 77 20 69 73 20  o and regNew is 
88c0: 70 61 73 73 65 64 20 74 68 65 0a 2a 2a 20 66 69  passed the.** fi
88d0: 72 73 74 20 72 65 67 69 73 74 65 72 20 6f 66 20  rst register of 
88e0: 61 6e 20 61 72 72 61 79 20 6f 66 20 28 70 54 61  an array of (pTa
88f0: 62 2d 3e 6e 43 6f 6c 2b 31 29 20 72 65 67 69 73  b->nCol+1) regis
8900: 74 65 72 73 20 63 6f 6e 74 61 69 6e 69 6e 67 20  ters containing 
8910: 74 68 65 20 6e 65 77 0a 2a 2a 20 72 6f 77 20 64  the new.** row d
8920: 61 74 61 2e 0a 2a 2a 0a 2a 2a 20 46 6f 72 20 61  ata..**.** For a
8930: 6e 20 55 50 44 41 54 45 20 6f 70 65 72 61 74 69  n UPDATE operati
8940: 6f 6e 2c 20 74 68 69 73 20 66 75 6e 63 74 69 6f  on, this functio
8950: 6e 20 69 73 20 63 61 6c 6c 65 64 20 74 77 69 63  n is called twic
8960: 65 2e 20 4f 6e 63 65 20 62 65 66 6f 72 65 0a 2a  e. Once before.*
8970: 2a 20 74 68 65 20 6f 72 69 67 69 6e 61 6c 20 72  * the original r
8980: 65 63 6f 72 64 20 69 73 20 64 65 6c 65 74 65 64  ecord is deleted
8990: 20 66 72 6f 6d 20 74 68 65 20 74 61 62 6c 65 20   from the table 
89a0: 75 73 69 6e 67 20 74 68 65 20 63 61 6c 6c 69 6e  using the callin
89b0: 67 20 63 6f 6e 76 65 6e 74 69 6f 6e 0a 2a 2a 20  g convention.** 
89c0: 64 65 73 63 72 69 62 65 64 20 66 6f 72 20 44 45  described for DE
89d0: 4c 45 54 45 2e 20 54 68 65 6e 20 61 67 61 69 6e  LETE. Then again
89e0: 20 61 66 74 65 72 20 74 68 65 20 6f 72 69 67 69   after the origi
89f0: 6e 61 6c 20 72 65 63 6f 72 64 20 69 73 20 64 65  nal record is de
8a00: 6c 65 74 65 64 0a 2a 2a 20 62 75 74 20 62 65 66  leted.** but bef
8a10: 6f 72 65 20 74 68 65 20 6e 65 77 20 72 65 63 6f  ore the new reco
8a20: 72 64 20 69 73 20 69 6e 73 65 72 74 65 64 20 75  rd is inserted u
8a30: 73 69 6e 67 20 74 68 65 20 49 4e 53 45 52 54 20  sing the INSERT 
8a40: 63 6f 6e 76 65 6e 74 69 6f 6e 2e 20 0a 2a 2f 0a  convention. .*/.
8a50: 76 6f 69 64 20 73 71 6c 69 74 65 33 46 6b 43 68  void sqlite3FkCh
8a60: 65 63 6b 28 0a 20 20 50 61 72 73 65 20 2a 70 50  eck(.  Parse *pP
8a70: 61 72 73 65 2c 20 20 20 20 20 20 20 20 20 20 20  arse,           
8a80: 20 20 20 20 20 20 20 2f 2a 20 50 61 72 73 65 20         /* Parse 
8a90: 63 6f 6e 74 65 78 74 20 2a 2f 0a 20 20 54 61 62  context */.  Tab
8aa0: 6c 65 20 2a 70 54 61 62 2c 20 20 20 20 20 20 20  le *pTab,       
8ab0: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
8ac0: 52 6f 77 20 69 73 20 62 65 69 6e 67 20 64 65 6c  Row is being del
8ad0: 65 74 65 64 20 66 72 6f 6d 20 74 68 69 73 20 74  eted from this t
8ae0: 61 62 6c 65 20 2a 2f 20 0a 20 20 69 6e 74 20 72  able */ .  int r
8af0: 65 67 4f 6c 64 2c 20 20 20 20 20 20 20 20 20 20  egOld,          
8b00: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 50 72             /* Pr
8b10: 65 76 69 6f 75 73 20 72 6f 77 20 64 61 74 61 20  evious row data 
8b20: 69 73 20 73 74 6f 72 65 64 20 68 65 72 65 20 2a  is stored here *
8b30: 2f 0a 20 20 69 6e 74 20 72 65 67 4e 65 77 2c 20  /.  int regNew, 
8b40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8b50: 20 20 20 20 2f 2a 20 4e 65 77 20 72 6f 77 20 64      /* New row d
8b60: 61 74 61 20 69 73 20 73 74 6f 72 65 64 20 68 65  ata is stored he
8b70: 72 65 20 2a 2f 0a 20 20 69 6e 74 20 2a 61 43 68  re */.  int *aCh
8b80: 61 6e 67 65 2c 20 20 20 20 20 20 20 20 20 20 20  ange,           
8b90: 20 20 20 20 20 20 20 20 2f 2a 20 41 72 72 61 79          /* Array
8ba0: 20 69 6e 64 69 63 61 74 69 6e 67 20 55 50 44 41   indicating UPDA
8bb0: 54 45 64 20 63 6f 6c 75 6d 6e 73 20 28 6f 72 20  TEd columns (or 
8bc0: 30 29 20 2a 2f 0a 20 20 69 6e 74 20 62 43 68 6e  0) */.  int bChn
8bd0: 67 52 6f 77 69 64 20 20 20 20 20 20 20 20 20 20  gRowid          
8be0: 20 20 20 20 20 20 20 20 2f 2a 20 54 72 75 65 20          /* True 
8bf0: 69 66 20 72 6f 77 69 64 20 69 73 20 55 50 44 41  if rowid is UPDA
8c00: 54 45 64 20 2a 2f 0a 29 7b 0a 20 20 73 71 6c 69  TEd */.){.  sqli
8c10: 74 65 33 20 2a 64 62 20 3d 20 70 50 61 72 73 65  te3 *db = pParse
8c20: 2d 3e 64 62 3b 20 20 20 20 20 20 20 2f 2a 20 44  ->db;       /* D
8c30: 61 74 61 62 61 73 65 20 68 61 6e 64 6c 65 20 2a  atabase handle *
8c40: 2f 0a 20 20 46 4b 65 79 20 2a 70 46 4b 65 79 3b  /.  FKey *pFKey;
8c50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8c60: 20 20 20 20 2f 2a 20 55 73 65 64 20 74 6f 20 69      /* Used to i
8c70: 74 65 72 61 74 65 20 74 68 72 6f 75 67 68 20 46  terate through F
8c80: 4b 73 20 2a 2f 0a 20 20 69 6e 74 20 69 44 62 3b  Ks */.  int iDb;
8c90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8ca0: 20 20 20 20 20 20 20 20 2f 2a 20 49 6e 64 65 78          /* Index
8cb0: 20 6f 66 20 64 61 74 61 62 61 73 65 20 63 6f 6e   of database con
8cc0: 74 61 69 6e 69 6e 67 20 70 54 61 62 20 2a 2f 0a  taining pTab */.
8cd0: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 44    const char *zD
8ce0: 62 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  b;              
8cf0: 20 20 2f 2a 20 4e 61 6d 65 20 6f 66 20 64 61 74    /* Name of dat
8d00: 61 62 61 73 65 20 63 6f 6e 74 61 69 6e 69 6e 67  abase containing
8d10: 20 70 54 61 62 20 2a 2f 0a 20 20 69 6e 74 20 69   pTab */.  int i
8d20: 73 49 67 6e 6f 72 65 45 72 72 6f 72 73 20 3d 20  sIgnoreErrors = 
8d30: 70 50 61 72 73 65 2d 3e 64 69 73 61 62 6c 65 54  pParse->disableT
8d40: 72 69 67 67 65 72 73 3b 0a 0a 20 20 2f 2a 20 45  riggers;..  /* E
8d50: 78 61 63 74 6c 79 20 6f 6e 65 20 6f 66 20 72 65  xactly one of re
8d60: 67 4f 6c 64 20 61 6e 64 20 72 65 67 4e 65 77 20  gOld and regNew 
8d70: 73 68 6f 75 6c 64 20 62 65 20 6e 6f 6e 2d 7a 65  should be non-ze
8d80: 72 6f 2e 20 2a 2f 0a 20 20 61 73 73 65 72 74 28  ro. */.  assert(
8d90: 20 28 72 65 67 4f 6c 64 3d 3d 30 29 21 3d 28 72   (regOld==0)!=(r
8da0: 65 67 4e 65 77 3d 3d 30 29 20 29 3b 0a 0a 20 20  egNew==0) );..  
8db0: 2f 2a 20 49 66 20 66 6f 72 65 69 67 6e 2d 6b 65  /* If foreign-ke
8dc0: 79 73 20 61 72 65 20 64 69 73 61 62 6c 65 64 2c  ys are disabled,
8dd0: 20 74 68 69 73 20 66 75 6e 63 74 69 6f 6e 20 69   this function i
8de0: 73 20 61 20 6e 6f 2d 6f 70 2e 20 2a 2f 0a 20 20  s a no-op. */.  
8df0: 69 66 28 20 28 64 62 2d 3e 66 6c 61 67 73 26 53  if( (db->flags&S
8e00: 51 4c 49 54 45 5f 46 6f 72 65 69 67 6e 4b 65 79  QLITE_ForeignKey
8e10: 73 29 3d 3d 30 20 29 20 72 65 74 75 72 6e 3b 0a  s)==0 ) return;.
8e20: 0a 20 20 69 44 62 20 3d 20 73 71 6c 69 74 65 33  .  iDb = sqlite3
8e30: 53 63 68 65 6d 61 54 6f 49 6e 64 65 78 28 64 62  SchemaToIndex(db
8e40: 2c 20 70 54 61 62 2d 3e 70 53 63 68 65 6d 61 29  , pTab->pSchema)
8e50: 3b 0a 20 20 7a 44 62 20 3d 20 64 62 2d 3e 61 44  ;.  zDb = db->aD
8e60: 62 5b 69 44 62 5d 2e 7a 44 62 53 4e 61 6d 65 3b  b[iDb].zDbSName;
8e70: 0a 0a 20 20 2f 2a 20 4c 6f 6f 70 20 74 68 72 6f  ..  /* Loop thro
8e80: 75 67 68 20 61 6c 6c 20 74 68 65 20 66 6f 72 65  ugh all the fore
8e90: 69 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61 69  ign key constrai
8ea0: 6e 74 73 20 66 6f 72 20 77 68 69 63 68 20 70 54  nts for which pT
8eb0: 61 62 20 69 73 20 74 68 65 0a 20 20 2a 2a 20 63  ab is the.  ** c
8ec0: 68 69 6c 64 20 74 61 62 6c 65 20 28 74 68 65 20  hild table (the 
8ed0: 74 61 62 6c 65 20 74 68 61 74 20 74 68 65 20 66  table that the f
8ee0: 6f 72 65 69 67 6e 20 6b 65 79 20 64 65 66 69 6e  oreign key defin
8ef0: 69 74 69 6f 6e 20 69 73 20 70 61 72 74 20 6f 66  ition is part of
8f00: 29 2e 20 20 2a 2f 0a 20 20 66 6f 72 28 70 46 4b  ).  */.  for(pFK
8f10: 65 79 3d 70 54 61 62 2d 3e 70 46 4b 65 79 3b 20  ey=pTab->pFKey; 
8f20: 70 46 4b 65 79 3b 20 70 46 4b 65 79 3d 70 46 4b  pFKey; pFKey=pFK
8f30: 65 79 2d 3e 70 4e 65 78 74 46 72 6f 6d 29 7b 0a  ey->pNextFrom){.
8f40: 20 20 20 20 54 61 62 6c 65 20 2a 70 54 6f 3b 20      Table *pTo; 
8f50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8f60: 20 20 2f 2a 20 50 61 72 65 6e 74 20 74 61 62 6c    /* Parent tabl
8f70: 65 20 6f 66 20 66 6f 72 65 69 67 6e 20 6b 65 79  e of foreign key
8f80: 20 70 46 4b 65 79 20 2a 2f 0a 20 20 20 20 49 6e   pFKey */.    In
8f90: 64 65 78 20 2a 70 49 64 78 20 3d 20 30 3b 20 20  dex *pIdx = 0;  
8fa0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 49              /* I
8fb0: 6e 64 65 78 20 6f 6e 20 6b 65 79 20 63 6f 6c 75  ndex on key colu
8fc0: 6d 6e 73 20 69 6e 20 70 54 6f 20 2a 2f 0a 20 20  mns in pTo */.  
8fd0: 20 20 69 6e 74 20 2a 61 69 46 72 65 65 20 3d 20    int *aiFree = 
8fe0: 30 3b 0a 20 20 20 20 69 6e 74 20 2a 61 69 43 6f  0;.    int *aiCo
8ff0: 6c 3b 0a 20 20 20 20 69 6e 74 20 69 43 6f 6c 3b  l;.    int iCol;
9000: 0a 20 20 20 20 69 6e 74 20 69 3b 0a 20 20 20 20  .    int i;.    
9010: 69 6e 74 20 62 49 67 6e 6f 72 65 20 3d 20 30 3b  int bIgnore = 0;
9020: 0a 0a 20 20 20 20 69 66 28 20 61 43 68 61 6e 67  ..    if( aChang
9030: 65 20 0a 20 20 20 20 20 26 26 20 73 71 6c 69 74  e .     && sqlit
9040: 65 33 5f 73 74 72 69 63 6d 70 28 70 54 61 62 2d  e3_stricmp(pTab-
9050: 3e 7a 4e 61 6d 65 2c 20 70 46 4b 65 79 2d 3e 7a  >zName, pFKey->z
9060: 54 6f 29 21 3d 30 0a 20 20 20 20 20 26 26 20 66  To)!=0.     && f
9070: 6b 43 68 69 6c 64 49 73 4d 6f 64 69 66 69 65 64  kChildIsModified
9080: 28 70 54 61 62 2c 20 70 46 4b 65 79 2c 20 61 43  (pTab, pFKey, aC
9090: 68 61 6e 67 65 2c 20 62 43 68 6e 67 52 6f 77 69  hange, bChngRowi
90a0: 64 29 3d 3d 30 20 0a 20 20 20 20 29 7b 0a 20 20  d)==0 .    ){.  
90b0: 20 20 20 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20      continue;.  
90c0: 20 20 7d 0a 0a 20 20 20 20 2f 2a 20 46 69 6e 64    }..    /* Find
90d0: 20 74 68 65 20 70 61 72 65 6e 74 20 74 61 62 6c   the parent tabl
90e0: 65 20 6f 66 20 74 68 69 73 20 66 6f 72 65 69 67  e of this foreig
90f0: 6e 20 6b 65 79 2e 20 41 6c 73 6f 20 66 69 6e 64  n key. Also find
9100: 20 61 20 75 6e 69 71 75 65 20 69 6e 64 65 78 20   a unique index 
9110: 0a 20 20 20 20 2a 2a 20 6f 6e 20 74 68 65 20 70  .    ** on the p
9120: 61 72 65 6e 74 20 6b 65 79 20 63 6f 6c 75 6d 6e  arent key column
9130: 73 20 69 6e 20 74 68 65 20 70 61 72 65 6e 74 20  s in the parent 
9140: 74 61 62 6c 65 2e 20 49 66 20 65 69 74 68 65 72  table. If either
9150: 20 6f 66 20 74 68 65 73 65 20 0a 20 20 20 20 2a   of these .    *
9160: 2a 20 73 63 68 65 6d 61 20 69 74 65 6d 73 20 63  * schema items c
9170: 61 6e 6e 6f 74 20 62 65 20 6c 6f 63 61 74 65 64  annot be located
9180: 2c 20 73 65 74 20 61 6e 20 65 72 72 6f 72 20 69  , set an error i
9190: 6e 20 70 50 61 72 73 65 20 61 6e 64 20 72 65 74  n pParse and ret
91a0: 75 72 6e 20 0a 20 20 20 20 2a 2a 20 65 61 72 6c  urn .    ** earl
91b0: 79 2e 20 20 2a 2f 0a 20 20 20 20 69 66 28 20 70  y.  */.    if( p
91c0: 50 61 72 73 65 2d 3e 64 69 73 61 62 6c 65 54 72  Parse->disableTr
91d0: 69 67 67 65 72 73 20 29 7b 0a 20 20 20 20 20 20  iggers ){.      
91e0: 70 54 6f 20 3d 20 73 71 6c 69 74 65 33 46 69 6e  pTo = sqlite3Fin
91f0: 64 54 61 62 6c 65 28 64 62 2c 20 70 46 4b 65 79  dTable(db, pFKey
9200: 2d 3e 7a 54 6f 2c 20 7a 44 62 29 3b 0a 20 20 20  ->zTo, zDb);.   
9210: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 70 54   }else{.      pT
9220: 6f 20 3d 20 73 71 6c 69 74 65 33 4c 6f 63 61 74  o = sqlite3Locat
9230: 65 54 61 62 6c 65 28 70 50 61 72 73 65 2c 20 30  eTable(pParse, 0
9240: 2c 20 70 46 4b 65 79 2d 3e 7a 54 6f 2c 20 7a 44  , pFKey->zTo, zD
9250: 62 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69 66  b);.    }.    if
9260: 28 20 21 70 54 6f 20 7c 7c 20 73 71 6c 69 74 65  ( !pTo || sqlite
9270: 33 46 6b 4c 6f 63 61 74 65 49 6e 64 65 78 28 70  3FkLocateIndex(p
9280: 50 61 72 73 65 2c 20 70 54 6f 2c 20 70 46 4b 65  Parse, pTo, pFKe
9290: 79 2c 20 26 70 49 64 78 2c 20 26 61 69 46 72 65  y, &pIdx, &aiFre
92a0: 65 29 20 29 7b 0a 20 20 20 20 20 20 61 73 73 65  e) ){.      asse
92b0: 72 74 28 20 69 73 49 67 6e 6f 72 65 45 72 72 6f  rt( isIgnoreErro
92c0: 72 73 3d 3d 30 20 7c 7c 20 28 72 65 67 4f 6c 64  rs==0 || (regOld
92d0: 21 3d 30 20 26 26 20 72 65 67 4e 65 77 3d 3d 30  !=0 && regNew==0
92e0: 29 20 29 3b 0a 20 20 20 20 20 20 69 66 28 20 21  ) );.      if( !
92f0: 69 73 49 67 6e 6f 72 65 45 72 72 6f 72 73 20 7c  isIgnoreErrors |
9300: 7c 20 64 62 2d 3e 6d 61 6c 6c 6f 63 46 61 69 6c  | db->mallocFail
9310: 65 64 20 29 20 72 65 74 75 72 6e 3b 0a 20 20 20  ed ) return;.   
9320: 20 20 20 69 66 28 20 70 54 6f 3d 3d 30 20 29 7b     if( pTo==0 ){
9330: 0a 20 20 20 20 20 20 20 20 2f 2a 20 49 66 20 69  .        /* If i
9340: 73 49 67 6e 6f 72 65 45 72 72 6f 72 73 20 69 73  sIgnoreErrors is
9350: 20 74 72 75 65 2c 20 74 68 65 6e 20 61 20 74 61   true, then a ta
9360: 62 6c 65 20 69 73 20 62 65 69 6e 67 20 64 72 6f  ble is being dro
9370: 70 70 65 64 2e 20 49 6e 20 74 68 69 73 0a 20 20  pped. In this.  
9380: 20 20 20 20 20 20 2a 2a 20 63 61 73 65 20 53 51        ** case SQ
9390: 4c 69 74 65 20 72 75 6e 73 20 61 20 22 44 45 4c  Lite runs a "DEL
93a0: 45 54 45 20 46 52 4f 4d 20 78 78 78 22 20 6f 6e  ETE FROM xxx" on
93b0: 20 74 68 65 20 74 61 62 6c 65 20 62 65 69 6e 67   the table being
93c0: 20 64 72 6f 70 70 65 64 0a 20 20 20 20 20 20 20   dropped.       
93d0: 20 2a 2a 20 62 65 66 6f 72 65 20 61 63 74 75 61   ** before actua
93e0: 6c 6c 79 20 64 72 6f 70 70 69 6e 67 20 69 74 20  lly dropping it 
93f0: 69 6e 20 6f 72 64 65 72 20 74 6f 20 63 68 65 63  in order to chec
9400: 6b 20 46 4b 20 63 6f 6e 73 74 72 61 69 6e 74 73  k FK constraints
9410: 2e 0a 20 20 20 20 20 20 20 20 2a 2a 20 49 66 20  ..        ** If 
9420: 74 68 65 20 70 61 72 65 6e 74 20 74 61 62 6c 65  the parent table
9430: 20 6f 66 20 61 6e 20 46 4b 20 63 6f 6e 73 74 72   of an FK constr
9440: 61 69 6e 74 20 6f 6e 20 74 68 65 20 63 75 72 72  aint on the curr
9450: 65 6e 74 20 74 61 62 6c 65 20 69 73 0a 20 20 20  ent table is.   
9460: 20 20 20 20 20 2a 2a 20 6d 69 73 73 69 6e 67 2c       ** missing,
9470: 20 62 65 68 61 76 65 20 61 73 20 69 66 20 69 74   behave as if it
9480: 20 69 73 20 65 6d 70 74 79 2e 20 69 2e 65 2e 20   is empty. i.e. 
9490: 64 65 63 72 65 6d 65 6e 74 20 74 68 65 20 72 65  decrement the re
94a0: 6c 65 76 61 6e 74 0a 20 20 20 20 20 20 20 20 2a  levant.        *
94b0: 2a 20 46 4b 20 63 6f 75 6e 74 65 72 20 66 6f 72  * FK counter for
94c0: 20 65 61 63 68 20 72 6f 77 20 6f 66 20 74 68 65   each row of the
94d0: 20 63 75 72 72 65 6e 74 20 74 61 62 6c 65 20 77   current table w
94e0: 69 74 68 20 6e 6f 6e 2d 4e 55 4c 4c 20 6b 65 79  ith non-NULL key
94f0: 73 2e 0a 20 20 20 20 20 20 20 20 2a 2f 0a 20 20  s..        */.  
9500: 20 20 20 20 20 20 56 64 62 65 20 2a 76 20 3d 20        Vdbe *v = 
9510: 73 71 6c 69 74 65 33 47 65 74 56 64 62 65 28 70  sqlite3GetVdbe(p
9520: 50 61 72 73 65 29 3b 0a 20 20 20 20 20 20 20 20  Parse);.        
9530: 69 6e 74 20 69 4a 75 6d 70 20 3d 20 73 71 6c 69  int iJump = sqli
9540: 74 65 33 56 64 62 65 43 75 72 72 65 6e 74 41 64  te3VdbeCurrentAd
9550: 64 72 28 76 29 20 2b 20 70 46 4b 65 79 2d 3e 6e  dr(v) + pFKey->n
9560: 43 6f 6c 20 2b 20 31 3b 0a 20 20 20 20 20 20 20  Col + 1;.       
9570: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 46 4b 65   for(i=0; i<pFKe
9580: 79 2d 3e 6e 43 6f 6c 3b 20 69 2b 2b 29 7b 0a 20  y->nCol; i++){. 
9590: 20 20 20 20 20 20 20 20 20 69 6e 74 20 69 52 65           int iRe
95a0: 67 20 3d 20 70 46 4b 65 79 2d 3e 61 43 6f 6c 5b  g = pFKey->aCol[
95b0: 69 5d 2e 69 46 72 6f 6d 20 2b 20 72 65 67 4f 6c  i].iFrom + regOl
95c0: 64 20 2b 20 31 3b 0a 20 20 20 20 20 20 20 20 20  d + 1;.         
95d0: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
95e0: 70 32 28 76 2c 20 4f 50 5f 49 73 4e 75 6c 6c 2c  p2(v, OP_IsNull,
95f0: 20 69 52 65 67 2c 20 69 4a 75 6d 70 29 3b 20 56   iReg, iJump); V
9600: 64 62 65 43 6f 76 65 72 61 67 65 28 76 29 3b 0a  dbeCoverage(v);.
9610: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
9620: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
9630: 4f 70 32 28 76 2c 20 4f 50 5f 46 6b 43 6f 75 6e  Op2(v, OP_FkCoun
9640: 74 65 72 2c 20 70 46 4b 65 79 2d 3e 69 73 44 65  ter, pFKey->isDe
9650: 66 65 72 72 65 64 2c 20 2d 31 29 3b 0a 20 20 20  ferred, -1);.   
9660: 20 20 20 7d 0a 20 20 20 20 20 20 63 6f 6e 74 69     }.      conti
9670: 6e 75 65 3b 0a 20 20 20 20 7d 0a 20 20 20 20 61  nue;.    }.    a
9680: 73 73 65 72 74 28 20 70 46 4b 65 79 2d 3e 6e 43  ssert( pFKey->nC
9690: 6f 6c 3d 3d 31 20 7c 7c 20 28 61 69 46 72 65 65  ol==1 || (aiFree
96a0: 20 26 26 20 70 49 64 78 29 20 29 3b 0a 0a 20 20   && pIdx) );..  
96b0: 20 20 69 66 28 20 61 69 46 72 65 65 20 29 7b 0a    if( aiFree ){.
96c0: 20 20 20 20 20 20 61 69 43 6f 6c 20 3d 20 61 69        aiCol = ai
96d0: 46 72 65 65 3b 0a 20 20 20 20 7d 65 6c 73 65 7b  Free;.    }else{
96e0: 0a 20 20 20 20 20 20 69 43 6f 6c 20 3d 20 70 46  .      iCol = pF
96f0: 4b 65 79 2d 3e 61 43 6f 6c 5b 30 5d 2e 69 46 72  Key->aCol[0].iFr
9700: 6f 6d 3b 0a 20 20 20 20 20 20 61 69 43 6f 6c 20  om;.      aiCol 
9710: 3d 20 26 69 43 6f 6c 3b 0a 20 20 20 20 7d 0a 20  = &iCol;.    }. 
9720: 20 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 46     for(i=0; i<pF
9730: 4b 65 79 2d 3e 6e 43 6f 6c 3b 20 69 2b 2b 29 7b  Key->nCol; i++){
9740: 0a 20 20 20 20 20 20 69 66 28 20 61 69 43 6f 6c  .      if( aiCol
9750: 5b 69 5d 3d 3d 70 54 61 62 2d 3e 69 50 4b 65 79  [i]==pTab->iPKey
9760: 20 29 7b 0a 20 20 20 20 20 20 20 20 61 69 43 6f   ){.        aiCo
9770: 6c 5b 69 5d 20 3d 20 2d 31 3b 0a 20 20 20 20 20  l[i] = -1;.     
9780: 20 7d 0a 20 20 20 20 20 20 61 73 73 65 72 74 28   }.      assert(
9790: 20 70 49 64 78 3d 3d 30 20 7c 7c 20 70 49 64 78   pIdx==0 || pIdx
97a0: 2d 3e 61 69 43 6f 6c 75 6d 6e 5b 69 5d 3e 3d 30  ->aiColumn[i]>=0
97b0: 20 29 3b 0a 23 69 66 6e 64 65 66 20 53 51 4c 49   );.#ifndef SQLI
97c0: 54 45 5f 4f 4d 49 54 5f 41 55 54 48 4f 52 49 5a  TE_OMIT_AUTHORIZ
97d0: 41 54 49 4f 4e 0a 20 20 20 20 20 20 2f 2a 20 52  ATION.      /* R
97e0: 65 71 75 65 73 74 20 70 65 72 6d 69 73 73 69 6f  equest permissio
97f0: 6e 20 74 6f 20 72 65 61 64 20 74 68 65 20 70 61  n to read the pa
9800: 72 65 6e 74 20 6b 65 79 20 63 6f 6c 75 6d 6e 73  rent key columns
9810: 2e 20 49 66 20 74 68 65 20 0a 20 20 20 20 20 20  . If the .      
9820: 2a 2a 20 61 75 74 68 6f 72 69 7a 61 74 69 6f 6e  ** authorization
9830: 20 63 61 6c 6c 62 61 63 6b 20 72 65 74 75 72 6e   callback return
9840: 73 20 53 51 4c 49 54 45 5f 49 47 4e 4f 52 45 2c  s SQLITE_IGNORE,
9850: 20 62 65 68 61 76 65 20 61 73 20 69 66 20 61 6e   behave as if an
9860: 79 0a 20 20 20 20 20 20 2a 2a 20 76 61 6c 75 65  y.      ** value
9870: 73 20 72 65 61 64 20 66 72 6f 6d 20 74 68 65 20  s read from the 
9880: 70 61 72 65 6e 74 20 74 61 62 6c 65 20 61 72 65  parent table are
9890: 20 4e 55 4c 4c 2e 20 2a 2f 0a 20 20 20 20 20 20   NULL. */.      
98a0: 69 66 28 20 64 62 2d 3e 78 41 75 74 68 20 29 7b  if( db->xAuth ){
98b0: 0a 20 20 20 20 20 20 20 20 69 6e 74 20 72 63 61  .        int rca
98c0: 75 74 68 3b 0a 20 20 20 20 20 20 20 20 63 68 61  uth;.        cha
98d0: 72 20 2a 7a 43 6f 6c 20 3d 20 70 54 6f 2d 3e 61  r *zCol = pTo->a
98e0: 43 6f 6c 5b 70 49 64 78 20 3f 20 70 49 64 78 2d  Col[pIdx ? pIdx-
98f0: 3e 61 69 43 6f 6c 75 6d 6e 5b 69 5d 20 3a 20 70  >aiColumn[i] : p
9900: 54 6f 2d 3e 69 50 4b 65 79 5d 2e 7a 4e 61 6d 65  To->iPKey].zName
9910: 3b 0a 20 20 20 20 20 20 20 20 72 63 61 75 74 68  ;.        rcauth
9920: 20 3d 20 73 71 6c 69 74 65 33 41 75 74 68 52 65   = sqlite3AuthRe
9930: 61 64 43 6f 6c 28 70 50 61 72 73 65 2c 20 70 54  adCol(pParse, pT
9940: 6f 2d 3e 7a 4e 61 6d 65 2c 20 7a 43 6f 6c 2c 20  o->zName, zCol, 
9950: 69 44 62 29 3b 0a 20 20 20 20 20 20 20 20 62 49  iDb);.        bI
9960: 67 6e 6f 72 65 20 3d 20 28 72 63 61 75 74 68 3d  gnore = (rcauth=
9970: 3d 53 51 4c 49 54 45 5f 49 47 4e 4f 52 45 29 3b  =SQLITE_IGNORE);
9980: 0a 20 20 20 20 20 20 7d 0a 23 65 6e 64 69 66 0a  .      }.#endif.
9990: 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a 20 54 61      }..    /* Ta
99a0: 6b 65 20 61 20 73 68 61 72 65 64 2d 63 61 63 68  ke a shared-cach
99b0: 65 20 61 64 76 69 73 6f 72 79 20 72 65 61 64 2d  e advisory read-
99c0: 6c 6f 63 6b 20 6f 6e 20 74 68 65 20 70 61 72 65  lock on the pare
99d0: 6e 74 20 74 61 62 6c 65 2e 20 41 6c 6c 6f 63 61  nt table. Alloca
99e0: 74 65 20 0a 20 20 20 20 2a 2a 20 61 20 63 75 72  te .    ** a cur
99f0: 73 6f 72 20 74 6f 20 75 73 65 20 74 6f 20 73 65  sor to use to se
9a00: 61 72 63 68 20 74 68 65 20 75 6e 69 71 75 65 20  arch the unique 
9a10: 69 6e 64 65 78 20 6f 6e 20 74 68 65 20 70 61 72  index on the par
9a20: 65 6e 74 20 6b 65 79 20 63 6f 6c 75 6d 6e 73 20  ent key columns 
9a30: 0a 20 20 20 20 2a 2a 20 69 6e 20 74 68 65 20 70  .    ** in the p
9a40: 61 72 65 6e 74 20 74 61 62 6c 65 2e 20 20 2a 2f  arent table.  */
9a50: 0a 20 20 20 20 73 71 6c 69 74 65 33 54 61 62 6c  .    sqlite3Tabl
9a60: 65 4c 6f 63 6b 28 70 50 61 72 73 65 2c 20 69 44  eLock(pParse, iD
9a70: 62 2c 20 70 54 6f 2d 3e 74 6e 75 6d 2c 20 30 2c  b, pTo->tnum, 0,
9a80: 20 70 54 6f 2d 3e 7a 4e 61 6d 65 29 3b 0a 20 20   pTo->zName);.  
9a90: 20 20 70 50 61 72 73 65 2d 3e 6e 54 61 62 2b 2b    pParse->nTab++
9aa0: 3b 0a 0a 20 20 20 20 69 66 28 20 72 65 67 4f 6c  ;..    if( regOl
9ab0: 64 21 3d 30 20 29 7b 0a 20 20 20 20 20 20 2f 2a  d!=0 ){.      /*
9ac0: 20 41 20 72 6f 77 20 69 73 20 62 65 69 6e 67 20   A row is being 
9ad0: 72 65 6d 6f 76 65 64 20 66 72 6f 6d 20 74 68 65  removed from the
9ae0: 20 63 68 69 6c 64 20 74 61 62 6c 65 2e 20 53 65   child table. Se
9af0: 61 72 63 68 20 66 6f 72 20 74 68 65 20 70 61 72  arch for the par
9b00: 65 6e 74 2e 0a 20 20 20 20 20 20 2a 2a 20 49 66  ent..      ** If
9b10: 20 74 68 65 20 70 61 72 65 6e 74 20 64 6f 65 73   the parent does
9b20: 20 6e 6f 74 20 65 78 69 73 74 2c 20 72 65 6d 6f   not exist, remo
9b30: 76 69 6e 67 20 74 68 65 20 63 68 69 6c 64 20 72  ving the child r
9b40: 6f 77 20 72 65 73 6f 6c 76 65 73 20 61 6e 20 0a  ow resolves an .
9b50: 20 20 20 20 20 20 2a 2a 20 6f 75 74 73 74 61 6e        ** outstan
9b60: 64 69 6e 67 20 66 6f 72 65 69 67 6e 20 6b 65 79  ding foreign key
9b70: 20 63 6f 6e 73 74 72 61 69 6e 74 20 76 69 6f 6c   constraint viol
9b80: 61 74 69 6f 6e 2e 20 2a 2f 0a 20 20 20 20 20 20  ation. */.      
9b90: 66 6b 4c 6f 6f 6b 75 70 50 61 72 65 6e 74 28 70  fkLookupParent(p
9ba0: 50 61 72 73 65 2c 20 69 44 62 2c 20 70 54 6f 2c  Parse, iDb, pTo,
9bb0: 20 70 49 64 78 2c 20 70 46 4b 65 79 2c 20 61 69   pIdx, pFKey, ai
9bc0: 43 6f 6c 2c 20 72 65 67 4f 6c 64 2c 20 2d 31 2c  Col, regOld, -1,
9bd0: 20 62 49 67 6e 6f 72 65 29 3b 0a 20 20 20 20 7d   bIgnore);.    }
9be0: 0a 20 20 20 20 69 66 28 20 72 65 67 4e 65 77 21  .    if( regNew!
9bf0: 3d 30 20 26 26 20 21 69 73 53 65 74 4e 75 6c 6c  =0 && !isSetNull
9c00: 41 63 74 69 6f 6e 28 70 50 61 72 73 65 2c 20 70  Action(pParse, p
9c10: 46 4b 65 79 29 20 29 7b 0a 20 20 20 20 20 20 2f  FKey) ){.      /
9c20: 2a 20 41 20 72 6f 77 20 69 73 20 62 65 69 6e 67  * A row is being
9c30: 20 61 64 64 65 64 20 74 6f 20 74 68 65 20 63 68   added to the ch
9c40: 69 6c 64 20 74 61 62 6c 65 2e 20 49 66 20 61 20  ild table. If a 
9c50: 70 61 72 65 6e 74 20 72 6f 77 20 63 61 6e 6e 6f  parent row canno
9c60: 74 0a 20 20 20 20 20 20 2a 2a 20 62 65 20 66 6f  t.      ** be fo
9c70: 75 6e 64 2c 20 61 64 64 69 6e 67 20 74 68 65 20  und, adding the 
9c80: 63 68 69 6c 64 20 72 6f 77 20 68 61 73 20 76 69  child row has vi
9c90: 6f 6c 61 74 65 64 20 74 68 65 20 46 4b 20 63 6f  olated the FK co
9ca0: 6e 73 74 72 61 69 6e 74 2e 20 0a 20 20 20 20 20  nstraint. .     
9cb0: 20 2a 2a 0a 20 20 20 20 20 20 2a 2a 20 49 66 20   **.      ** If 
9cc0: 74 68 69 73 20 6f 70 65 72 61 74 69 6f 6e 20 69  this operation i
9cd0: 73 20 62 65 69 6e 67 20 70 65 72 66 6f 72 6d 65  s being performe
9ce0: 64 20 61 73 20 70 61 72 74 20 6f 66 20 61 20 74  d as part of a t
9cf0: 72 69 67 67 65 72 20 70 72 6f 67 72 61 6d 0a 20  rigger program. 
9d00: 20 20 20 20 20 2a 2a 20 74 68 61 74 20 69 73 20       ** that is 
9d10: 61 63 74 75 61 6c 6c 79 20 61 20 22 53 45 54 20  actually a "SET 
9d20: 4e 55 4c 4c 22 20 61 63 74 69 6f 6e 20 62 65 6c  NULL" action bel
9d30: 6f 6e 67 69 6e 67 20 74 6f 20 74 68 69 73 20 76  onging to this v
9d40: 65 72 79 20 0a 20 20 20 20 20 20 2a 2a 20 66 6f  ery .      ** fo
9d50: 72 65 69 67 6e 20 6b 65 79 2c 20 74 68 65 6e 20  reign key, then 
9d60: 6f 6d 69 74 20 74 68 69 73 20 73 63 61 6e 20 61  omit this scan a
9d70: 6c 74 6f 67 65 74 68 65 72 2e 20 41 73 20 61 6c  ltogether. As al
9d80: 6c 20 63 68 69 6c 64 20 6b 65 79 0a 20 20 20 20  l child key.    
9d90: 20 20 2a 2a 20 76 61 6c 75 65 73 20 61 72 65 20    ** values are 
9da0: 67 75 61 72 61 6e 74 65 65 64 20 74 6f 20 62 65  guaranteed to be
9db0: 20 4e 55 4c 4c 2c 20 69 74 20 69 73 20 6e 6f 74   NULL, it is not
9dc0: 20 70 6f 73 73 69 62 6c 65 20 66 6f 72 20 61 64   possible for ad
9dd0: 64 69 6e 67 0a 20 20 20 20 20 20 2a 2a 20 74 68  ding.      ** th
9de0: 69 73 20 72 6f 77 20 74 6f 20 63 61 75 73 65 20  is row to cause 
9df0: 61 6e 20 46 4b 20 76 69 6f 6c 61 74 69 6f 6e 2e  an FK violation.
9e00: 20 20 2a 2f 0a 20 20 20 20 20 20 66 6b 4c 6f 6f    */.      fkLoo
9e10: 6b 75 70 50 61 72 65 6e 74 28 70 50 61 72 73 65  kupParent(pParse
9e20: 2c 20 69 44 62 2c 20 70 54 6f 2c 20 70 49 64 78  , iDb, pTo, pIdx
9e30: 2c 20 70 46 4b 65 79 2c 20 61 69 43 6f 6c 2c 20  , pFKey, aiCol, 
9e40: 72 65 67 4e 65 77 2c 20 2b 31 2c 20 62 49 67 6e  regNew, +1, bIgn
9e50: 6f 72 65 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  ore);.    }..   
9e60: 20 73 71 6c 69 74 65 33 44 62 46 72 65 65 28 64   sqlite3DbFree(d
9e70: 62 2c 20 61 69 46 72 65 65 29 3b 0a 20 20 7d 0a  b, aiFree);.  }.
9e80: 0a 20 20 2f 2a 20 4c 6f 6f 70 20 74 68 72 6f 75  .  /* Loop throu
9e90: 67 68 20 61 6c 6c 20 74 68 65 20 66 6f 72 65 69  gh all the forei
9ea0: 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e  gn key constrain
9eb0: 74 73 20 74 68 61 74 20 72 65 66 65 72 20 74 6f  ts that refer to
9ec0: 20 74 68 69 73 20 74 61 62 6c 65 2e 0a 20 20 2a   this table..  *
9ed0: 2a 20 28 74 68 65 20 22 63 68 69 6c 64 22 20 63  * (the "child" c
9ee0: 6f 6e 73 74 72 61 69 6e 74 73 29 20 2a 2f 0a 20  onstraints) */. 
9ef0: 20 66 6f 72 28 70 46 4b 65 79 20 3d 20 73 71 6c   for(pFKey = sql
9f00: 69 74 65 33 46 6b 52 65 66 65 72 65 6e 63 65 73  ite3FkReferences
9f10: 28 70 54 61 62 29 3b 20 70 46 4b 65 79 3b 20 70  (pTab); pFKey; p
9f20: 46 4b 65 79 3d 70 46 4b 65 79 2d 3e 70 4e 65 78  FKey=pFKey->pNex
9f30: 74 54 6f 29 7b 0a 20 20 20 20 49 6e 64 65 78 20  tTo){.    Index 
9f40: 2a 70 49 64 78 20 3d 20 30 3b 20 20 20 20 20 20  *pIdx = 0;      
9f50: 20 20 20 20 20 20 20 20 2f 2a 20 46 6f 72 65 69          /* Forei
9f60: 67 6e 20 6b 65 79 20 69 6e 64 65 78 20 66 6f 72  gn key index for
9f70: 20 70 46 4b 65 79 20 2a 2f 0a 20 20 20 20 53 72   pFKey */.    Sr
9f80: 63 4c 69 73 74 20 2a 70 53 72 63 3b 0a 20 20 20  cList *pSrc;.   
9f90: 20 69 6e 74 20 2a 61 69 43 6f 6c 20 3d 20 30 3b   int *aiCol = 0;
9fa0: 0a 0a 20 20 20 20 69 66 28 20 61 43 68 61 6e 67  ..    if( aChang
9fb0: 65 20 26 26 20 66 6b 50 61 72 65 6e 74 49 73 4d  e && fkParentIsM
9fc0: 6f 64 69 66 69 65 64 28 70 54 61 62 2c 20 70 46  odified(pTab, pF
9fd0: 4b 65 79 2c 20 61 43 68 61 6e 67 65 2c 20 62 43  Key, aChange, bC
9fe0: 68 6e 67 52 6f 77 69 64 29 3d 3d 30 20 29 7b 0a  hngRowid)==0 ){.
9ff0: 20 20 20 20 20 20 63 6f 6e 74 69 6e 75 65 3b 0a        continue;.
a000: 20 20 20 20 7d 0a 0a 20 20 20 20 69 66 28 20 21      }..    if( !
a010: 70 46 4b 65 79 2d 3e 69 73 44 65 66 65 72 72 65  pFKey->isDeferre
a020: 64 20 26 26 20 21 28 64 62 2d 3e 66 6c 61 67 73  d && !(db->flags
a030: 20 26 20 53 51 4c 49 54 45 5f 44 65 66 65 72 46   & SQLITE_DeferF
a040: 4b 73 29 20 0a 20 20 20 20 20 26 26 20 21 70 50  Ks) .     && !pP
a050: 61 72 73 65 2d 3e 70 54 6f 70 6c 65 76 65 6c 20  arse->pToplevel 
a060: 26 26 20 21 70 50 61 72 73 65 2d 3e 69 73 4d 75  && !pParse->isMu
a070: 6c 74 69 57 72 69 74 65 20 0a 20 20 20 20 29 7b  ltiWrite .    ){
a080: 0a 20 20 20 20 20 20 61 73 73 65 72 74 28 20 72  .      assert( r
a090: 65 67 4f 6c 64 3d 3d 30 20 26 26 20 72 65 67 4e  egOld==0 && regN
a0a0: 65 77 21 3d 30 20 29 3b 0a 20 20 20 20 20 20 2f  ew!=0 );.      /
a0b0: 2a 20 49 6e 73 65 72 74 69 6e 67 20 61 20 73 69  * Inserting a si
a0c0: 6e 67 6c 65 20 72 6f 77 20 69 6e 74 6f 20 61 20  ngle row into a 
a0d0: 70 61 72 65 6e 74 20 74 61 62 6c 65 20 63 61 6e  parent table can
a0e0: 6e 6f 74 20 63 61 75 73 65 20 28 6f 72 20 66 69  not cause (or fi
a0f0: 78 29 0a 20 20 20 20 20 20 2a 2a 20 61 6e 20 69  x).      ** an i
a100: 6d 6d 65 64 69 61 74 65 20 66 6f 72 65 69 67 6e  mmediate foreign
a110: 20 6b 65 79 20 76 69 6f 6c 61 74 69 6f 6e 2e 20   key violation. 
a120: 53 6f 20 64 6f 20 6e 6f 74 68 69 6e 67 20 69 6e  So do nothing in
a130: 20 74 68 69 73 20 63 61 73 65 2e 20 20 2a 2f 0a   this case.  */.
a140: 20 20 20 20 20 20 63 6f 6e 74 69 6e 75 65 3b 0a        continue;.
a150: 20 20 20 20 7d 0a 0a 20 20 20 20 69 66 28 20 73      }..    if( s
a160: 71 6c 69 74 65 33 46 6b 4c 6f 63 61 74 65 49 6e  qlite3FkLocateIn
a170: 64 65 78 28 70 50 61 72 73 65 2c 20 70 54 61 62  dex(pParse, pTab
a180: 2c 20 70 46 4b 65 79 2c 20 26 70 49 64 78 2c 20  , pFKey, &pIdx, 
a190: 26 61 69 43 6f 6c 29 20 29 7b 0a 20 20 20 20 20  &aiCol) ){.     
a1a0: 20 69 66 28 20 21 69 73 49 67 6e 6f 72 65 45 72   if( !isIgnoreEr
a1b0: 72 6f 72 73 20 7c 7c 20 64 62 2d 3e 6d 61 6c 6c  rors || db->mall
a1c0: 6f 63 46 61 69 6c 65 64 20 29 20 72 65 74 75 72  ocFailed ) retur
a1d0: 6e 3b 0a 20 20 20 20 20 20 63 6f 6e 74 69 6e 75  n;.      continu
a1e0: 65 3b 0a 20 20 20 20 7d 0a 20 20 20 20 61 73 73  e;.    }.    ass
a1f0: 65 72 74 28 20 61 69 43 6f 6c 20 7c 7c 20 70 46  ert( aiCol || pF
a200: 4b 65 79 2d 3e 6e 43 6f 6c 3d 3d 31 20 29 3b 0a  Key->nCol==1 );.
a210: 0a 20 20 20 20 2f 2a 20 43 72 65 61 74 65 20 61  .    /* Create a
a220: 20 53 72 63 4c 69 73 74 20 73 74 72 75 63 74 75   SrcList structu
a230: 72 65 20 63 6f 6e 74 61 69 6e 69 6e 67 20 74 68  re containing th
a240: 65 20 63 68 69 6c 64 20 74 61 62 6c 65 2e 20 20  e child table.  
a250: 57 65 20 6e 65 65 64 20 74 68 65 0a 20 20 20 20  We need the.    
a260: 2a 2a 20 63 68 69 6c 64 20 74 61 62 6c 65 20 61  ** child table a
a270: 73 20 61 20 53 72 63 4c 69 73 74 20 66 6f 72 20  s a SrcList for 
a280: 73 71 6c 69 74 65 33 57 68 65 72 65 42 65 67 69  sqlite3WhereBegi
a290: 6e 28 29 20 2a 2f 0a 20 20 20 20 70 53 72 63 20  n() */.    pSrc 
a2a0: 3d 20 73 71 6c 69 74 65 33 53 72 63 4c 69 73 74  = sqlite3SrcList
a2b0: 41 70 70 65 6e 64 28 70 50 61 72 73 65 2c 20 30  Append(pParse, 0
a2c0: 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 69 66 28  , 0, 0);.    if(
a2d0: 20 70 53 72 63 20 29 7b 0a 20 20 20 20 20 20 73   pSrc ){.      s
a2e0: 74 72 75 63 74 20 53 72 63 4c 69 73 74 5f 69 74  truct SrcList_it
a2f0: 65 6d 20 2a 70 49 74 65 6d 20 3d 20 70 53 72 63  em *pItem = pSrc
a300: 2d 3e 61 3b 0a 20 20 20 20 20 20 70 49 74 65 6d  ->a;.      pItem
a310: 2d 3e 70 54 61 62 20 3d 20 70 46 4b 65 79 2d 3e  ->pTab = pFKey->
a320: 70 46 72 6f 6d 3b 0a 20 20 20 20 20 20 70 49 74  pFrom;.      pIt
a330: 65 6d 2d 3e 7a 4e 61 6d 65 20 3d 20 70 46 4b 65  em->zName = pFKe
a340: 79 2d 3e 70 46 72 6f 6d 2d 3e 7a 4e 61 6d 65 3b  y->pFrom->zName;
a350: 0a 20 20 20 20 20 20 70 49 74 65 6d 2d 3e 70 54  .      pItem->pT
a360: 61 62 2d 3e 6e 54 61 62 52 65 66 2b 2b 3b 0a 20  ab->nTabRef++;. 
a370: 20 20 20 20 20 70 49 74 65 6d 2d 3e 69 43 75 72       pItem->iCur
a380: 73 6f 72 20 3d 20 70 50 61 72 73 65 2d 3e 6e 54  sor = pParse->nT
a390: 61 62 2b 2b 3b 0a 20 20 0a 20 20 20 20 20 20 69  ab++;.  .      i
a3a0: 66 28 20 72 65 67 4e 65 77 21 3d 30 20 29 7b 0a  f( regNew!=0 ){.
a3b0: 20 20 20 20 20 20 20 20 66 6b 53 63 61 6e 43 68          fkScanCh
a3c0: 69 6c 64 72 65 6e 28 70 50 61 72 73 65 2c 20 70  ildren(pParse, p
a3d0: 53 72 63 2c 20 70 54 61 62 2c 20 70 49 64 78 2c  Src, pTab, pIdx,
a3e0: 20 70 46 4b 65 79 2c 20 61 69 43 6f 6c 2c 20 72   pFKey, aiCol, r
a3f0: 65 67 4e 65 77 2c 20 2d 31 29 3b 0a 20 20 20 20  egNew, -1);.    
a400: 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20 72 65    }.      if( re
a410: 67 4f 6c 64 21 3d 30 20 29 7b 0a 20 20 20 20 20  gOld!=0 ){.     
a420: 20 20 20 69 6e 74 20 65 41 63 74 69 6f 6e 20 3d     int eAction =
a430: 20 70 46 4b 65 79 2d 3e 61 41 63 74 69 6f 6e 5b   pFKey->aAction[
a440: 61 43 68 61 6e 67 65 21 3d 30 5d 3b 0a 20 20 20  aChange!=0];.   
a450: 20 20 20 20 20 66 6b 53 63 61 6e 43 68 69 6c 64       fkScanChild
a460: 72 65 6e 28 70 50 61 72 73 65 2c 20 70 53 72 63  ren(pParse, pSrc
a470: 2c 20 70 54 61 62 2c 20 70 49 64 78 2c 20 70 46  , pTab, pIdx, pF
a480: 4b 65 79 2c 20 61 69 43 6f 6c 2c 20 72 65 67 4f  Key, aiCol, regO
a490: 6c 64 2c 20 31 29 3b 0a 20 20 20 20 20 20 20 20  ld, 1);.        
a4a0: 2f 2a 20 49 66 20 74 68 69 73 20 69 73 20 61 20  /* If this is a 
a4b0: 64 65 66 65 72 72 65 64 20 46 4b 20 63 6f 6e 73  deferred FK cons
a4c0: 74 72 61 69 6e 74 2c 20 6f 72 20 61 20 43 41 53  traint, or a CAS
a4d0: 43 41 44 45 20 6f 72 20 53 45 54 20 4e 55 4c 4c  CADE or SET NULL
a4e0: 0a 20 20 20 20 20 20 20 20 2a 2a 20 61 63 74 69  .        ** acti
a4f0: 6f 6e 20 61 70 70 6c 69 65 73 2c 20 74 68 65 6e  on applies, then
a500: 20 61 6e 79 20 66 6f 72 65 69 67 6e 20 6b 65 79   any foreign key
a510: 20 76 69 6f 6c 61 74 69 6f 6e 73 20 63 61 75 73   violations caus
a520: 65 64 20 62 79 0a 20 20 20 20 20 20 20 20 2a 2a  ed by.        **
a530: 20 72 65 6d 6f 76 69 6e 67 20 74 68 65 20 70 61   removing the pa
a540: 72 65 6e 74 20 6b 65 79 20 77 69 6c 6c 20 62 65  rent key will be
a550: 20 72 65 63 74 69 66 69 65 64 20 62 79 20 74 68   rectified by th
a560: 65 20 61 63 74 69 6f 6e 20 74 72 69 67 67 65 72  e action trigger
a570: 2e 0a 20 20 20 20 20 20 20 20 2a 2a 20 53 6f 20  ..        ** So 
a580: 64 6f 20 6e 6f 74 20 73 65 74 20 74 68 65 20 22  do not set the "
a590: 6d 61 79 2d 61 62 6f 72 74 22 20 66 6c 61 67 20  may-abort" flag 
a5a0: 69 6e 20 74 68 69 73 20 63 61 73 65 2e 0a 20 20  in this case..  
a5b0: 20 20 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 20        **.       
a5c0: 20 2a 2a 20 4e 6f 74 65 20 31 3a 20 49 66 20 74   ** Note 1: If t
a5d0: 68 65 20 46 4b 20 69 73 20 64 65 63 6c 61 72 65  he FK is declare
a5e0: 64 20 22 4f 4e 20 55 50 44 41 54 45 20 43 41 53  d "ON UPDATE CAS
a5f0: 43 41 44 45 22 2c 20 74 68 65 6e 20 74 68 65 0a  CADE", then the.
a600: 20 20 20 20 20 20 20 20 2a 2a 20 6d 61 79 2d 61          ** may-a
a610: 62 6f 72 74 20 66 6c 61 67 20 77 69 6c 6c 20 65  bort flag will e
a620: 76 65 6e 74 75 61 6c 6c 79 20 62 65 20 73 65 74  ventually be set
a630: 20 6f 6e 20 74 68 69 73 20 73 74 61 74 65 6d 65   on this stateme
a640: 6e 74 20 61 6e 79 77 61 79 0a 20 20 20 20 20 20  nt anyway.      
a650: 20 20 2a 2a 20 28 77 68 65 6e 20 74 68 69 73 20    ** (when this 
a660: 66 75 6e 63 74 69 6f 6e 20 69 73 20 63 61 6c 6c  function is call
a670: 65 64 20 61 73 20 70 61 72 74 20 6f 66 20 70 72  ed as part of pr
a680: 6f 63 65 73 73 69 6e 67 20 74 68 65 20 55 50 44  ocessing the UPD
a690: 41 54 45 0a 20 20 20 20 20 20 20 20 2a 2a 20 77  ATE.        ** w
a6a0: 69 74 68 69 6e 20 74 68 65 20 61 63 74 69 6f 6e  ithin the action
a6b0: 20 74 72 69 67 67 65 72 29 2e 0a 20 20 20 20 20   trigger)..     
a6c0: 20 20 20 2a 2a 0a 20 20 20 20 20 20 20 20 2a 2a     **.        **
a6d0: 20 4e 6f 74 65 20 32 3a 20 41 74 20 66 69 72 73   Note 2: At firs
a6e0: 74 20 67 6c 61 6e 63 65 20 69 74 20 6d 61 79 20  t glance it may 
a6f0: 73 65 65 6d 20 6c 69 6b 65 20 53 51 4c 69 74 65  seem like SQLite
a700: 20 63 6f 75 6c 64 20 73 69 6d 70 6c 79 20 6f 6d   could simply om
a710: 69 74 0a 20 20 20 20 20 20 20 20 2a 2a 20 61 6c  it.        ** al
a720: 6c 20 4f 50 5f 46 6b 43 6f 75 6e 74 65 72 20 72  l OP_FkCounter r
a730: 65 6c 61 74 65 64 20 73 63 61 6e 73 20 77 68 65  elated scans whe
a740: 6e 20 65 69 74 68 65 72 20 43 41 53 43 41 44 45  n either CASCADE
a750: 20 6f 72 20 53 45 54 20 4e 55 4c 4c 0a 20 20 20   or SET NULL.   
a760: 20 20 20 20 20 2a 2a 20 61 70 70 6c 69 65 73 2e       ** applies.
a770: 20 54 68 65 20 74 72 6f 75 62 6c 65 20 73 74 61   The trouble sta
a780: 72 74 73 20 69 66 20 74 68 65 20 43 41 53 43 41  rts if the CASCA
a790: 44 45 20 6f 72 20 53 45 54 20 4e 55 4c 4c 20 61  DE or SET NULL a
a7a0: 63 74 69 6f 6e 20 0a 20 20 20 20 20 20 20 20 2a  ction .        *
a7b0: 2a 20 74 72 69 67 67 65 72 20 63 61 75 73 65 73  * trigger causes
a7c0: 20 6f 74 68 65 72 20 74 72 69 67 67 65 72 73 20   other triggers 
a7d0: 6f 72 20 61 63 74 69 6f 6e 20 72 75 6c 65 73 20  or action rules 
a7e0: 61 74 74 61 63 68 65 64 20 74 6f 20 74 68 65 20  attached to the 
a7f0: 0a 20 20 20 20 20 20 20 20 2a 2a 20 63 68 69 6c  .        ** chil
a800: 64 20 74 61 62 6c 65 20 74 6f 20 66 69 72 65 2e  d table to fire.
a810: 20 49 6e 20 74 68 65 73 65 20 63 61 73 65 73 20   In these cases 
a820: 74 68 65 20 66 6b 20 63 6f 6e 73 74 72 61 69 6e  the fk constrain
a830: 74 20 63 6f 75 6e 74 65 72 73 0a 20 20 20 20 20  t counters.     
a840: 20 20 20 2a 2a 20 6d 69 67 68 74 20 62 65 20 73     ** might be s
a850: 65 74 20 69 6e 63 6f 72 72 65 63 74 6c 79 20 69  et incorrectly i
a860: 66 20 61 6e 79 20 4f 50 5f 46 6b 43 6f 75 6e 74  f any OP_FkCount
a870: 65 72 20 72 65 6c 61 74 65 64 20 73 63 61 6e 73  er related scans
a880: 20 61 72 65 20 0a 20 20 20 20 20 20 20 20 2a 2a   are .        **
a890: 20 6f 6d 69 74 74 65 64 2e 20 20 2a 2f 0a 20 20   omitted.  */.  
a8a0: 20 20 20 20 20 20 69 66 28 20 21 70 46 4b 65 79        if( !pFKey
a8b0: 2d 3e 69 73 44 65 66 65 72 72 65 64 20 26 26 20  ->isDeferred && 
a8c0: 65 41 63 74 69 6f 6e 21 3d 4f 45 5f 43 61 73 63  eAction!=OE_Casc
a8d0: 61 64 65 20 26 26 20 65 41 63 74 69 6f 6e 21 3d  ade && eAction!=
a8e0: 4f 45 5f 53 65 74 4e 75 6c 6c 20 29 7b 0a 20 20  OE_SetNull ){.  
a8f0: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 4d          sqlite3M
a900: 61 79 41 62 6f 72 74 28 70 50 61 72 73 65 29 3b  ayAbort(pParse);
a910: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
a920: 20 7d 0a 20 20 20 20 20 20 70 49 74 65 6d 2d 3e   }.      pItem->
a930: 7a 4e 61 6d 65 20 3d 20 30 3b 0a 20 20 20 20 20  zName = 0;.     
a940: 20 73 71 6c 69 74 65 33 53 72 63 4c 69 73 74 44   sqlite3SrcListD
a950: 65 6c 65 74 65 28 64 62 2c 20 70 53 72 63 29 3b  elete(db, pSrc);
a960: 0a 20 20 20 20 7d 0a 20 20 20 20 73 71 6c 69 74  .    }.    sqlit
a970: 65 33 44 62 46 72 65 65 28 64 62 2c 20 61 69 43  e3DbFree(db, aiC
a980: 6f 6c 29 3b 0a 20 20 7d 0a 7d 0a 0a 23 64 65 66  ol);.  }.}..#def
a990: 69 6e 65 20 43 4f 4c 55 4d 4e 5f 4d 41 53 4b 28  ine COLUMN_MASK(
a9a0: 78 29 20 28 28 28 78 29 3e 33 31 29 20 3f 20 30  x) (((x)>31) ? 0
a9b0: 78 66 66 66 66 66 66 66 66 20 3a 20 28 28 75 33  xffffffff : ((u3
a9c0: 32 29 31 3c 3c 28 78 29 29 29 0a 0a 2f 2a 0a 2a  2)1<<(x)))../*.*
a9d0: 2a 20 54 68 69 73 20 66 75 6e 63 74 69 6f 6e 20  * This function 
a9e0: 69 73 20 63 61 6c 6c 65 64 20 62 65 66 6f 72 65  is called before
a9f0: 20 67 65 6e 65 72 61 74 69 6e 67 20 63 6f 64 65   generating code
aa00: 20 74 6f 20 75 70 64 61 74 65 20 6f 72 20 64 65   to update or de
aa10: 6c 65 74 65 20 61 20 0a 2a 2a 20 72 6f 77 20 63  lete a .** row c
aa20: 6f 6e 74 61 69 6e 65 64 20 69 6e 20 74 61 62 6c  ontained in tabl
aa30: 65 20 70 54 61 62 2e 0a 2a 2f 0a 75 33 32 20 73  e pTab..*/.u32 s
aa40: 71 6c 69 74 65 33 46 6b 4f 6c 64 6d 61 73 6b 28  qlite3FkOldmask(
aa50: 0a 20 20 50 61 72 73 65 20 2a 70 50 61 72 73 65  .  Parse *pParse
aa60: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,               
aa70: 20 20 20 2f 2a 20 50 61 72 73 65 20 63 6f 6e 74     /* Parse cont
aa80: 65 78 74 20 2a 2f 0a 20 20 54 61 62 6c 65 20 2a  ext */.  Table *
aa90: 70 54 61 62 20 20 20 20 20 20 20 20 20 20 20 20  pTab            
aaa0: 20 20 20 20 20 20 20 20 20 2f 2a 20 54 61 62 6c           /* Tabl
aab0: 65 20 62 65 69 6e 67 20 6d 6f 64 69 66 69 65 64  e being modified
aac0: 20 2a 2f 0a 29 7b 0a 20 20 75 33 32 20 6d 61 73   */.){.  u32 mas
aad0: 6b 20 3d 20 30 3b 0a 20 20 69 66 28 20 70 50 61  k = 0;.  if( pPa
aae0: 72 73 65 2d 3e 64 62 2d 3e 66 6c 61 67 73 26 53  rse->db->flags&S
aaf0: 51 4c 49 54 45 5f 46 6f 72 65 69 67 6e 4b 65 79  QLITE_ForeignKey
ab00: 73 20 29 7b 0a 20 20 20 20 46 4b 65 79 20 2a 70  s ){.    FKey *p
ab10: 3b 0a 20 20 20 20 69 6e 74 20 69 3b 0a 20 20 20  ;.    int i;.   
ab20: 20 66 6f 72 28 70 3d 70 54 61 62 2d 3e 70 46 4b   for(p=pTab->pFK
ab30: 65 79 3b 20 70 3b 20 70 3d 70 2d 3e 70 4e 65 78  ey; p; p=p->pNex
ab40: 74 46 72 6f 6d 29 7b 0a 20 20 20 20 20 20 66 6f  tFrom){.      fo
ab50: 72 28 69 3d 30 3b 20 69 3c 70 2d 3e 6e 43 6f 6c  r(i=0; i<p->nCol
ab60: 3b 20 69 2b 2b 29 20 6d 61 73 6b 20 7c 3d 20 43  ; i++) mask |= C
ab70: 4f 4c 55 4d 4e 5f 4d 41 53 4b 28 70 2d 3e 61 43  OLUMN_MASK(p->aC
ab80: 6f 6c 5b 69 5d 2e 69 46 72 6f 6d 29 3b 0a 20 20  ol[i].iFrom);.  
ab90: 20 20 7d 0a 20 20 20 20 66 6f 72 28 70 3d 73 71    }.    for(p=sq
aba0: 6c 69 74 65 33 46 6b 52 65 66 65 72 65 6e 63 65  lite3FkReference
abb0: 73 28 70 54 61 62 29 3b 20 70 3b 20 70 3d 70 2d  s(pTab); p; p=p-
abc0: 3e 70 4e 65 78 74 54 6f 29 7b 0a 20 20 20 20 20  >pNextTo){.     
abd0: 20 49 6e 64 65 78 20 2a 70 49 64 78 20 3d 20 30   Index *pIdx = 0
abe0: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 46  ;.      sqlite3F
abf0: 6b 4c 6f 63 61 74 65 49 6e 64 65 78 28 70 50 61  kLocateIndex(pPa
ac00: 72 73 65 2c 20 70 54 61 62 2c 20 70 2c 20 26 70  rse, pTab, p, &p
ac10: 49 64 78 2c 20 30 29 3b 0a 20 20 20 20 20 20 69  Idx, 0);.      i
ac20: 66 28 20 70 49 64 78 20 29 7b 0a 20 20 20 20 20  f( pIdx ){.     
ac30: 20 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 49     for(i=0; i<pI
ac40: 64 78 2d 3e 6e 4b 65 79 43 6f 6c 3b 20 69 2b 2b  dx->nKeyCol; i++
ac50: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 61 73 73  ){.          ass
ac60: 65 72 74 28 20 70 49 64 78 2d 3e 61 69 43 6f 6c  ert( pIdx->aiCol
ac70: 75 6d 6e 5b 69 5d 3e 3d 30 20 29 3b 0a 20 20 20  umn[i]>=0 );.   
ac80: 20 20 20 20 20 20 20 6d 61 73 6b 20 7c 3d 20 43         mask |= C
ac90: 4f 4c 55 4d 4e 5f 4d 41 53 4b 28 70 49 64 78 2d  OLUMN_MASK(pIdx-
aca0: 3e 61 69 43 6f 6c 75 6d 6e 5b 69 5d 29 3b 0a 20  >aiColumn[i]);. 
acb0: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d         }.      }
acc0: 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 72 65 74  .    }.  }.  ret
acd0: 75 72 6e 20 6d 61 73 6b 3b 0a 7d 0a 0a 0a 2f 2a  urn mask;.}.../*
ace0: 0a 2a 2a 20 54 68 69 73 20 66 75 6e 63 74 69 6f  .** This functio
acf0: 6e 20 69 73 20 63 61 6c 6c 65 64 20 62 65 66 6f  n is called befo
ad00: 72 65 20 67 65 6e 65 72 61 74 69 6e 67 20 63 6f  re generating co
ad10: 64 65 20 74 6f 20 75 70 64 61 74 65 20 6f 72 20  de to update or 
ad20: 64 65 6c 65 74 65 20 61 20 0a 2a 2a 20 72 6f 77  delete a .** row
ad30: 20 63 6f 6e 74 61 69 6e 65 64 20 69 6e 20 74 61   contained in ta
ad40: 62 6c 65 20 70 54 61 62 2e 20 49 66 20 74 68 65  ble pTab. If the
ad50: 20 6f 70 65 72 61 74 69 6f 6e 20 69 73 20 61 20   operation is a 
ad60: 44 45 4c 45 54 45 2c 20 74 68 65 6e 0a 2a 2a 20  DELETE, then.** 
ad70: 70 61 72 61 6d 65 74 65 72 20 61 43 68 61 6e 67  parameter aChang
ad80: 65 20 69 73 20 70 61 73 73 65 64 20 61 20 4e 55  e is passed a NU
ad90: 4c 4c 20 76 61 6c 75 65 2e 20 46 6f 72 20 61 6e  LL value. For an
ada0: 20 55 50 44 41 54 45 2c 20 61 43 68 61 6e 67 65   UPDATE, aChange
adb0: 20 70 6f 69 6e 74 73 0a 2a 2a 20 74 6f 20 61 6e   points.** to an
adc0: 20 61 72 72 61 79 20 6f 66 20 73 69 7a 65 20 4e   array of size N
add0: 2c 20 77 68 65 72 65 20 4e 20 69 73 20 74 68 65  , where N is the
ade0: 20 6e 75 6d 62 65 72 20 6f 66 20 63 6f 6c 75 6d   number of colum
adf0: 6e 73 20 69 6e 20 74 61 62 6c 65 20 70 54 61 62  ns in table pTab
ae00: 2e 0a 2a 2a 20 49 66 20 74 68 65 20 69 27 74 68  ..** If the i'th
ae10: 20 63 6f 6c 75 6d 6e 20 69 73 20 6e 6f 74 20 6d   column is not m
ae20: 6f 64 69 66 69 65 64 20 62 79 20 74 68 65 20 55  odified by the U
ae30: 50 44 41 54 45 2c 20 74 68 65 6e 20 74 68 65 20  PDATE, then the 
ae40: 63 6f 72 72 65 73 70 6f 6e 64 69 6e 67 20 0a 2a  corresponding .*
ae50: 2a 20 65 6e 74 72 79 20 69 6e 20 74 68 65 20 61  * entry in the a
ae60: 43 68 61 6e 67 65 5b 5d 20 61 72 72 61 79 20 69  Change[] array i
ae70: 73 20 73 65 74 20 74 6f 20 2d 31 2e 20 49 66 20  s set to -1. If 
ae80: 74 68 65 20 63 6f 6c 75 6d 6e 20 69 73 20 6d 6f  the column is mo
ae90: 64 69 66 69 65 64 2c 0a 2a 2a 20 74 68 65 20 76  dified,.** the v
aea0: 61 6c 75 65 20 69 73 20 30 20 6f 72 20 67 72 65  alue is 0 or gre
aeb0: 61 74 65 72 2e 20 50 61 72 61 6d 65 74 65 72 20  ater. Parameter 
aec0: 63 68 6e 67 52 6f 77 69 64 20 69 73 20 73 65 74  chngRowid is set
aed0: 20 74 6f 20 74 72 75 65 20 69 66 20 74 68 65 0a   to true if the.
aee0: 2a 2a 20 55 50 44 41 54 45 20 73 74 61 74 65 6d  ** UPDATE statem
aef0: 65 6e 74 20 6d 6f 64 69 66 69 65 73 20 74 68 65  ent modifies the
af00: 20 72 6f 77 69 64 20 66 69 65 6c 64 73 20 6f 66   rowid fields of
af10: 20 74 68 65 20 74 61 62 6c 65 2e 0a 2a 2a 0a 2a   the table..**.*
af20: 2a 20 49 66 20 61 6e 79 20 66 6f 72 65 69 67 6e  * If any foreign
af30: 20 6b 65 79 20 70 72 6f 63 65 73 73 69 6e 67 20   key processing 
af40: 77 69 6c 6c 20 62 65 20 72 65 71 75 69 72 65 64  will be required
af50: 2c 20 74 68 69 73 20 66 75 6e 63 74 69 6f 6e 20  , this function 
af60: 72 65 74 75 72 6e 73 0a 2a 2a 20 6e 6f 6e 2d 7a  returns.** non-z
af70: 65 72 6f 2e 20 49 66 20 74 68 65 72 65 20 69 73  ero. If there is
af80: 20 6e 6f 20 66 6f 72 65 69 67 6e 20 6b 65 79 20   no foreign key 
af90: 72 65 6c 61 74 65 64 20 70 72 6f 63 65 73 73 69  related processi
afa0: 6e 67 2c 20 74 68 69 73 20 66 75 6e 63 74 69 6f  ng, this functio
afb0: 6e 20 0a 2a 2a 20 72 65 74 75 72 6e 73 20 7a 65  n .** returns ze
afc0: 72 6f 2e 0a 2a 2a 0a 2a 2a 20 46 6f 72 20 61 6e  ro..**.** For an
afd0: 20 55 50 44 41 54 45 2c 20 74 68 69 73 20 66 75   UPDATE, this fu
afe0: 6e 63 74 69 6f 6e 20 72 65 74 75 72 6e 73 20 32  nction returns 2
aff0: 20 69 66 3a 0a 2a 2a 0a 2a 2a 20 20 20 2a 20 54   if:.**.**   * T
b000: 68 65 72 65 20 61 72 65 20 61 6e 79 20 46 4b 73  here are any FKs
b010: 20 66 6f 72 20 77 68 69 63 68 20 70 54 61 62 20   for which pTab 
b020: 69 73 20 74 68 65 20 63 68 69 6c 64 20 61 6e 64  is the child and
b030: 20 74 68 65 20 70 61 72 65 6e 74 20 74 61 62 6c   the parent tabl
b040: 65 2c 20 6f 72 0a 2a 2a 20 20 20 2a 20 74 68 65  e, or.**   * the
b050: 20 55 50 44 41 54 45 20 6d 6f 64 69 66 69 65 73   UPDATE modifies
b060: 20 6f 6e 65 20 6f 72 20 6d 6f 72 65 20 70 61 72   one or more par
b070: 65 6e 74 20 6b 65 79 73 20 66 6f 72 20 77 68 69  ent keys for whi
b080: 63 68 20 74 68 65 20 61 63 74 69 6f 6e 20 69 73  ch the action is
b090: 0a 2a 2a 20 20 20 20 20 6e 6f 74 20 22 4e 4f 20  .**     not "NO 
b0a0: 41 43 54 49 4f 4e 22 20 28 69 2e 65 2e 20 69 73  ACTION" (i.e. is
b0b0: 20 43 41 53 43 41 44 45 2c 20 53 45 54 20 44 45   CASCADE, SET DE
b0c0: 46 41 55 4c 54 20 6f 72 20 53 45 54 20 4e 55 4c  FAULT or SET NUL
b0d0: 4c 29 2e 0a 2a 2a 0a 2a 2a 20 4f 72 2c 20 61 73  L)..**.** Or, as
b0e0: 73 75 6d 69 6e 67 20 73 6f 6d 65 20 6f 74 68 65  suming some othe
b0f0: 72 20 66 6f 72 65 69 67 6e 20 6b 65 79 20 70 72  r foreign key pr
b100: 6f 63 65 73 73 69 6e 67 20 69 73 20 72 65 71 75  ocessing is requ
b110: 69 72 65 64 2c 20 31 2e 0a 2a 2f 0a 69 6e 74 20  ired, 1..*/.int 
b120: 73 71 6c 69 74 65 33 46 6b 52 65 71 75 69 72 65  sqlite3FkRequire
b130: 64 28 0a 20 20 50 61 72 73 65 20 2a 70 50 61 72  d(.  Parse *pPar
b140: 73 65 2c 20 20 20 20 20 20 20 20 20 20 20 20 20  se,             
b150: 20 20 20 20 20 2f 2a 20 50 61 72 73 65 20 63 6f       /* Parse co
b160: 6e 74 65 78 74 20 2a 2f 0a 20 20 54 61 62 6c 65  ntext */.  Table
b170: 20 2a 70 54 61 62 2c 20 20 20 20 20 20 20 20 20   *pTab,         
b180: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 61             /* Ta
b190: 62 6c 65 20 62 65 69 6e 67 20 6d 6f 64 69 66 69  ble being modifi
b1a0: 65 64 20 2a 2f 0a 20 20 69 6e 74 20 2a 61 43 68  ed */.  int *aCh
b1b0: 61 6e 67 65 2c 20 20 20 20 20 20 20 20 20 20 20  ange,           
b1c0: 20 20 20 20 20 20 20 20 2f 2a 20 4e 6f 6e 2d 4e          /* Non-N
b1d0: 55 4c 4c 20 66 6f 72 20 55 50 44 41 54 45 20 6f  ULL for UPDATE o
b1e0: 70 65 72 61 74 69 6f 6e 73 20 2a 2f 0a 20 20 69  perations */.  i
b1f0: 6e 74 20 63 68 6e 67 52 6f 77 69 64 20 20 20 20  nt chngRowid    
b200: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
b210: 2a 20 54 72 75 65 20 66 6f 72 20 55 50 44 41 54  * True for UPDAT
b220: 45 20 74 68 61 74 20 61 66 66 65 63 74 73 20 72  E that affects r
b230: 6f 77 69 64 20 2a 2f 0a 29 7b 0a 20 20 69 6e 74  owid */.){.  int
b240: 20 65 52 65 74 20 3d 20 30 3b 0a 20 20 69 66 28   eRet = 0;.  if(
b250: 20 70 50 61 72 73 65 2d 3e 64 62 2d 3e 66 6c 61   pParse->db->fla
b260: 67 73 26 53 51 4c 49 54 45 5f 46 6f 72 65 69 67  gs&SQLITE_Foreig
b270: 6e 4b 65 79 73 20 29 7b 0a 20 20 20 20 69 66 28  nKeys ){.    if(
b280: 20 21 61 43 68 61 6e 67 65 20 29 7b 0a 20 20 20   !aChange ){.   
b290: 20 20 20 2f 2a 20 41 20 44 45 4c 45 54 45 20 6f     /* A DELETE o
b2a0: 70 65 72 61 74 69 6f 6e 2e 20 46 6f 72 65 69 67  peration. Foreig
b2b0: 6e 20 6b 65 79 20 70 72 6f 63 65 73 73 69 6e 67  n key processing
b2c0: 20 69 73 20 72 65 71 75 69 72 65 64 20 69 66 20   is required if 
b2d0: 74 68 65 20 0a 20 20 20 20 20 20 2a 2a 20 74 61  the .      ** ta
b2e0: 62 6c 65 20 69 6e 20 71 75 65 73 74 69 6f 6e 20  ble in question 
b2f0: 69 73 20 65 69 74 68 65 72 20 74 68 65 20 63 68  is either the ch
b300: 69 6c 64 20 6f 72 20 70 61 72 65 6e 74 20 74 61  ild or parent ta
b310: 62 6c 65 20 66 6f 72 20 61 6e 79 20 0a 20 20 20  ble for any .   
b320: 20 20 20 2a 2a 20 66 6f 72 65 69 67 6e 20 6b 65     ** foreign ke
b330: 79 20 63 6f 6e 73 74 72 61 69 6e 74 2e 20 20 2a  y constraint.  *
b340: 2f 0a 20 20 20 20 20 20 65 52 65 74 20 3d 20 28  /.      eRet = (
b350: 73 71 6c 69 74 65 33 46 6b 52 65 66 65 72 65 6e  sqlite3FkReferen
b360: 63 65 73 28 70 54 61 62 29 20 7c 7c 20 70 54 61  ces(pTab) || pTa
b370: 62 2d 3e 70 46 4b 65 79 29 3b 0a 20 20 20 20 7d  b->pFKey);.    }
b380: 65 6c 73 65 7b 0a 20 20 20 20 20 20 2f 2a 20 54  else{.      /* T
b390: 68 69 73 20 69 73 20 61 6e 20 55 50 44 41 54 45  his is an UPDATE
b3a0: 2e 20 46 6f 72 65 69 67 6e 20 6b 65 79 20 70 72  . Foreign key pr
b3b0: 6f 63 65 73 73 69 6e 67 20 69 73 20 6f 6e 6c 79  ocessing is only
b3c0: 20 72 65 71 75 69 72 65 64 20 69 66 20 74 68 65   required if the
b3d0: 0a 20 20 20 20 20 20 2a 2a 20 6f 70 65 72 61 74  .      ** operat
b3e0: 69 6f 6e 20 6d 6f 64 69 66 69 65 73 20 6f 6e 65  ion modifies one
b3f0: 20 6f 72 20 6d 6f 72 65 20 63 68 69 6c 64 20 6f   or more child o
b400: 72 20 70 61 72 65 6e 74 20 6b 65 79 20 63 6f 6c  r parent key col
b410: 75 6d 6e 73 2e 20 2a 2f 0a 20 20 20 20 20 20 46  umns. */.      F
b420: 4b 65 79 20 2a 70 3b 0a 0a 20 20 20 20 20 20 2f  Key *p;..      /
b430: 2a 20 43 68 65 63 6b 20 69 66 20 61 6e 79 20 63  * Check if any c
b440: 68 69 6c 64 20 6b 65 79 20 63 6f 6c 75 6d 6e 73  hild key columns
b450: 20 61 72 65 20 62 65 69 6e 67 20 6d 6f 64 69 66   are being modif
b460: 69 65 64 2e 20 2a 2f 0a 20 20 20 20 20 20 66 6f  ied. */.      fo
b470: 72 28 70 3d 70 54 61 62 2d 3e 70 46 4b 65 79 3b  r(p=pTab->pFKey;
b480: 20 70 3b 20 70 3d 70 2d 3e 70 4e 65 78 74 46 72   p; p=p->pNextFr
b490: 6f 6d 29 7b 0a 20 20 20 20 20 20 20 20 69 66 28  om){.        if(
b4a0: 20 30 3d 3d 73 71 6c 69 74 65 33 5f 73 74 72 69   0==sqlite3_stri
b4b0: 63 6d 70 28 70 54 61 62 2d 3e 7a 4e 61 6d 65 2c  cmp(pTab->zName,
b4c0: 20 70 2d 3e 7a 54 6f 29 20 29 20 72 65 74 75 72   p->zTo) ) retur
b4d0: 6e 20 32 3b 0a 20 20 20 20 20 20 20 20 69 66 28  n 2;.        if(
b4e0: 20 66 6b 43 68 69 6c 64 49 73 4d 6f 64 69 66 69   fkChildIsModifi
b4f0: 65 64 28 70 54 61 62 2c 20 70 2c 20 61 43 68 61  ed(pTab, p, aCha
b500: 6e 67 65 2c 20 63 68 6e 67 52 6f 77 69 64 29 20  nge, chngRowid) 
b510: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 65 52 65  ){.          eRe
b520: 74 20 3d 20 31 3b 0a 20 20 20 20 20 20 20 20 7d  t = 1;.        }
b530: 0a 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20  .      }..      
b540: 2f 2a 20 43 68 65 63 6b 20 69 66 20 61 6e 79 20  /* Check if any 
b550: 70 61 72 65 6e 74 20 6b 65 79 20 63 6f 6c 75 6d  parent key colum
b560: 6e 73 20 61 72 65 20 62 65 69 6e 67 20 6d 6f 64  ns are being mod
b570: 69 66 69 65 64 2e 20 2a 2f 0a 20 20 20 20 20 20  ified. */.      
b580: 66 6f 72 28 70 3d 73 71 6c 69 74 65 33 46 6b 52  for(p=sqlite3FkR
b590: 65 66 65 72 65 6e 63 65 73 28 70 54 61 62 29 3b  eferences(pTab);
b5a0: 20 70 3b 20 70 3d 70 2d 3e 70 4e 65 78 74 54 6f   p; p=p->pNextTo
b5b0: 29 7b 0a 20 20 20 20 20 20 20 20 69 66 28 20 66  ){.        if( f
b5c0: 6b 50 61 72 65 6e 74 49 73 4d 6f 64 69 66 69 65  kParentIsModifie
b5d0: 64 28 70 54 61 62 2c 20 70 2c 20 61 43 68 61 6e  d(pTab, p, aChan
b5e0: 67 65 2c 20 63 68 6e 67 52 6f 77 69 64 29 20 29  ge, chngRowid) )
b5f0: 7b 0a 20 20 20 20 20 20 20 20 20 20 69 66 28 20  {.          if( 
b600: 70 2d 3e 61 41 63 74 69 6f 6e 5b 31 5d 21 3d 4f  p->aAction[1]!=O
b610: 45 5f 4e 6f 6e 65 20 29 20 72 65 74 75 72 6e 20  E_None ) return 
b620: 32 3b 0a 20 20 20 20 20 20 20 20 20 20 65 52 65  2;.          eRe
b630: 74 20 3d 20 31 3b 0a 20 20 20 20 20 20 20 20 7d  t = 1;.        }
b640: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20  .      }.    }. 
b650: 20 7d 0a 20 20 72 65 74 75 72 6e 20 65 52 65 74   }.  return eRet
b660: 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 69 73 20  ;.}../*.** This 
b670: 66 75 6e 63 74 69 6f 6e 20 69 73 20 63 61 6c 6c  function is call
b680: 65 64 20 77 68 65 6e 20 61 6e 20 55 50 44 41 54  ed when an UPDAT
b690: 45 20 6f 72 20 44 45 4c 45 54 45 20 6f 70 65 72  E or DELETE oper
b6a0: 61 74 69 6f 6e 20 69 73 20 62 65 69 6e 67 20 0a  ation is being .
b6b0: 2a 2a 20 63 6f 6d 70 69 6c 65 64 20 6f 6e 20 74  ** compiled on t
b6c0: 61 62 6c 65 20 70 54 61 62 2c 20 77 68 69 63 68  able pTab, which
b6d0: 20 69 73 20 74 68 65 20 70 61 72 65 6e 74 20 74   is the parent t
b6e0: 61 62 6c 65 20 6f 66 20 66 6f 72 65 69 67 6e 2d  able of foreign-
b6f0: 6b 65 79 20 70 46 4b 65 79 2e 0a 2a 2a 20 49 66  key pFKey..** If
b700: 20 74 68 65 20 63 75 72 72 65 6e 74 20 6f 70 65   the current ope
b710: 72 61 74 69 6f 6e 20 69 73 20 61 6e 20 55 50 44  ration is an UPD
b720: 41 54 45 2c 20 74 68 65 6e 20 74 68 65 20 70 43  ATE, then the pC
b730: 68 61 6e 67 65 73 20 70 61 72 61 6d 65 74 65 72  hanges parameter
b740: 20 69 73 0a 2a 2a 20 70 61 73 73 65 64 20 61 20   is.** passed a 
b750: 70 6f 69 6e 74 65 72 20 74 6f 20 74 68 65 20 6c  pointer to the l
b760: 69 73 74 20 6f 66 20 63 6f 6c 75 6d 6e 73 20 62  ist of columns b
b770: 65 69 6e 67 20 6d 6f 64 69 66 69 65 64 2e 20 49  eing modified. I
b780: 66 20 69 74 20 69 73 20 61 0a 2a 2a 20 44 45 4c  f it is a.** DEL
b790: 45 54 45 2c 20 70 43 68 61 6e 67 65 73 20 69 73  ETE, pChanges is
b7a0: 20 70 61 73 73 65 64 20 61 20 4e 55 4c 4c 20 70   passed a NULL p
b7b0: 6f 69 6e 74 65 72 2e 0a 2a 2a 0a 2a 2a 20 49 74  ointer..**.** It
b7c0: 20 72 65 74 75 72 6e 73 20 61 20 70 6f 69 6e 74   returns a point
b7d0: 65 72 20 74 6f 20 61 20 54 72 69 67 67 65 72 20  er to a Trigger 
b7e0: 73 74 72 75 63 74 75 72 65 20 63 6f 6e 74 61 69  structure contai
b7f0: 6e 69 6e 67 20 61 20 74 72 69 67 67 65 72 0a 2a  ning a trigger.*
b800: 2a 20 65 71 75 69 76 61 6c 65 6e 74 20 74 6f 20  * equivalent to 
b810: 74 68 65 20 4f 4e 20 55 50 44 41 54 45 20 6f 72  the ON UPDATE or
b820: 20 4f 4e 20 44 45 4c 45 54 45 20 61 63 74 69 6f   ON DELETE actio
b830: 6e 20 73 70 65 63 69 66 69 65 64 20 62 79 20 70  n specified by p
b840: 46 4b 65 79 2e 0a 2a 2a 20 49 66 20 74 68 65 20  FKey..** If the 
b850: 61 63 74 69 6f 6e 20 69 73 20 22 4e 4f 20 41 43  action is "NO AC
b860: 54 49 4f 4e 22 20 6f 72 20 22 52 45 53 54 52 49  TION" or "RESTRI
b870: 43 54 22 2c 20 74 68 65 6e 20 61 20 4e 55 4c 4c  CT", then a NULL
b880: 20 70 6f 69 6e 74 65 72 20 69 73 0a 2a 2a 20 72   pointer is.** r
b890: 65 74 75 72 6e 65 64 20 28 74 68 65 73 65 20 61  eturned (these a
b8a0: 63 74 69 6f 6e 73 20 72 65 71 75 69 72 65 20 6e  ctions require n
b8b0: 6f 20 73 70 65 63 69 61 6c 20 68 61 6e 64 6c 69  o special handli
b8c0: 6e 67 20 62 79 20 74 68 65 20 74 72 69 67 67 65  ng by the trigge
b8d0: 72 73 0a 2a 2a 20 73 75 62 2d 73 79 73 74 65 6d  rs.** sub-system
b8e0: 2c 20 63 6f 64 65 20 66 6f 72 20 74 68 65 6d 20  , code for them 
b8f0: 69 73 20 63 72 65 61 74 65 64 20 62 79 20 66 6b  is created by fk
b900: 53 63 61 6e 43 68 69 6c 64 72 65 6e 28 29 29 2e  ScanChildren()).
b910: 0a 2a 2a 0a 2a 2a 20 46 6f 72 20 65 78 61 6d 70  .**.** For examp
b920: 6c 65 2c 20 69 66 20 70 46 4b 65 79 20 69 73 20  le, if pFKey is 
b930: 74 68 65 20 66 6f 72 65 69 67 6e 20 6b 65 79 20  the foreign key 
b940: 61 6e 64 20 70 54 61 62 20 69 73 20 74 61 62 6c  and pTab is tabl
b950: 65 20 22 70 22 20 69 6e 20 0a 2a 2a 20 74 68 65  e "p" in .** the
b960: 20 66 6f 6c 6c 6f 77 69 6e 67 20 73 63 68 65 6d   following schem
b970: 61 3a 0a 2a 2a 0a 2a 2a 20 20 20 43 52 45 41 54  a:.**.**   CREAT
b980: 45 20 54 41 42 4c 45 20 70 28 70 6b 20 50 52 49  E TABLE p(pk PRI
b990: 4d 41 52 59 20 4b 45 59 29 3b 0a 2a 2a 20 20 20  MARY KEY);.**   
b9a0: 43 52 45 41 54 45 20 54 41 42 4c 45 20 63 28 63  CREATE TABLE c(c
b9b0: 6b 20 52 45 46 45 52 45 4e 43 45 53 20 70 20 4f  k REFERENCES p O
b9c0: 4e 20 44 45 4c 45 54 45 20 43 41 53 43 41 44 45  N DELETE CASCADE
b9d0: 29 3b 0a 2a 2a 0a 2a 2a 20 74 68 65 6e 20 74 68  );.**.** then th
b9e0: 65 20 72 65 74 75 72 6e 65 64 20 74 72 69 67 67  e returned trigg
b9f0: 65 72 20 73 74 72 75 63 74 75 72 65 20 69 73 20  er structure is 
ba00: 65 71 75 69 76 61 6c 65 6e 74 20 74 6f 3a 0a 2a  equivalent to:.*
ba10: 2a 0a 2a 2a 20 20 20 43 52 45 41 54 45 20 54 52  *.**   CREATE TR
ba20: 49 47 47 45 52 20 2e 2e 2e 20 44 45 4c 45 54 45  IGGER ... DELETE
ba30: 20 4f 4e 20 70 20 42 45 47 49 4e 0a 2a 2a 20 20   ON p BEGIN.**  
ba40: 20 20 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 63     DELETE FROM c
ba50: 20 57 48 45 52 45 20 63 6b 20 3d 20 6f 6c 64 2e   WHERE ck = old.
ba60: 70 6b 3b 0a 2a 2a 20 20 20 45 4e 44 3b 0a 2a 2a  pk;.**   END;.**
ba70: 0a 2a 2a 20 54 68 65 20 72 65 74 75 72 6e 65 64  .** The returned
ba80: 20 70 6f 69 6e 74 65 72 20 69 73 20 63 61 63 68   pointer is cach
ba90: 65 64 20 61 73 20 70 61 72 74 20 6f 66 20 74 68  ed as part of th
baa0: 65 20 66 6f 72 65 69 67 6e 20 6b 65 79 20 6f 62  e foreign key ob
bab0: 6a 65 63 74 2e 20 49 74 0a 2a 2a 20 69 73 20 65  ject. It.** is e
bac0: 76 65 6e 74 75 61 6c 6c 79 20 66 72 65 65 64 20  ventually freed 
bad0: 61 6c 6f 6e 67 20 77 69 74 68 20 74 68 65 20 72  along with the r
bae0: 65 73 74 20 6f 66 20 74 68 65 20 66 6f 72 65 69  est of the forei
baf0: 67 6e 20 6b 65 79 20 6f 62 6a 65 63 74 20 62 79  gn key object by
bb00: 20 0a 2a 2a 20 73 71 6c 69 74 65 33 46 6b 44 65   .** sqlite3FkDe
bb10: 6c 65 74 65 28 29 2e 0a 2a 2f 0a 73 74 61 74 69  lete()..*/.stati
bb20: 63 20 54 72 69 67 67 65 72 20 2a 66 6b 41 63 74  c Trigger *fkAct
bb30: 69 6f 6e 54 72 69 67 67 65 72 28 0a 20 20 50 61  ionTrigger(.  Pa
bb40: 72 73 65 20 2a 70 50 61 72 73 65 2c 20 20 20 20  rse *pParse,    
bb50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
bb60: 20 50 61 72 73 65 20 63 6f 6e 74 65 78 74 20 2a   Parse context *
bb70: 2f 0a 20 20 54 61 62 6c 65 20 2a 70 54 61 62 2c  /.  Table *pTab,
bb80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
bb90: 20 20 20 20 2f 2a 20 54 61 62 6c 65 20 62 65 69      /* Table bei
bba0: 6e 67 20 75 70 64 61 74 65 64 20 6f 72 20 64 65  ng updated or de
bbb0: 6c 65 74 65 64 20 66 72 6f 6d 20 2a 2f 0a 20 20  leted from */.  
bbc0: 46 4b 65 79 20 2a 70 46 4b 65 79 2c 20 20 20 20  FKey *pFKey,    
bbd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
bbe0: 2f 2a 20 46 6f 72 65 69 67 6e 20 6b 65 79 20 74  /* Foreign key t
bbf0: 6f 20 67 65 74 20 61 63 74 69 6f 6e 20 66 6f 72  o get action for
bc00: 20 2a 2f 0a 20 20 45 78 70 72 4c 69 73 74 20 2a   */.  ExprList *
bc10: 70 43 68 61 6e 67 65 73 20 20 20 20 20 20 20 20  pChanges        
bc20: 20 20 20 20 20 20 2f 2a 20 43 68 61 6e 67 65 2d        /* Change-
bc30: 6c 69 73 74 20 66 6f 72 20 55 50 44 41 54 45 2c  list for UPDATE,
bc40: 20 4e 55 4c 4c 20 66 6f 72 20 44 45 4c 45 54 45   NULL for DELETE
bc50: 20 2a 2f 0a 29 7b 0a 20 20 73 71 6c 69 74 65 33   */.){.  sqlite3
bc60: 20 2a 64 62 20 3d 20 70 50 61 72 73 65 2d 3e 64   *db = pParse->d
bc70: 62 3b 20 20 20 20 20 20 20 2f 2a 20 44 61 74 61  b;       /* Data
bc80: 62 61 73 65 20 68 61 6e 64 6c 65 20 2a 2f 0a 20  base handle */. 
bc90: 20 69 6e 74 20 61 63 74 69 6f 6e 3b 20 20 20 20   int action;    
bca0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
bcb0: 20 2f 2a 20 4f 6e 65 20 6f 66 20 4f 45 5f 4e 6f   /* One of OE_No
bcc0: 6e 65 2c 20 4f 45 5f 43 61 73 63 61 64 65 20 65  ne, OE_Cascade e
bcd0: 74 63 2e 20 2a 2f 0a 20 20 54 72 69 67 67 65 72  tc. */.  Trigger
bce0: 20 2a 70 54 72 69 67 67 65 72 3b 20 20 20 20 20   *pTrigger;     
bcf0: 20 20 20 20 20 20 20 20 20 2f 2a 20 54 72 69 67           /* Trig
bd00: 67 65 72 20 64 65 66 69 6e 69 74 69 6f 6e 20 74  ger definition t
bd10: 6f 20 72 65 74 75 72 6e 20 2a 2f 0a 20 20 69 6e  o return */.  in
bd20: 74 20 69 41 63 74 69 6f 6e 20 3d 20 28 70 43 68  t iAction = (pCh
bd30: 61 6e 67 65 73 21 3d 30 29 3b 20 20 20 20 2f 2a  anges!=0);    /*
bd40: 20 31 20 66 6f 72 20 55 50 44 41 54 45 2c 20 30   1 for UPDATE, 0
bd50: 20 66 6f 72 20 44 45 4c 45 54 45 20 2a 2f 0a 0a   for DELETE */..
bd60: 20 20 61 63 74 69 6f 6e 20 3d 20 70 46 4b 65 79    action = pFKey
bd70: 2d 3e 61 41 63 74 69 6f 6e 5b 69 41 63 74 69 6f  ->aAction[iActio
bd80: 6e 5d 3b 0a 20 20 69 66 28 20 61 63 74 69 6f 6e  n];.  if( action
bd90: 3d 3d 4f 45 5f 52 65 73 74 72 69 63 74 20 26 26  ==OE_Restrict &&
bda0: 20 28 64 62 2d 3e 66 6c 61 67 73 20 26 20 53 51   (db->flags & SQ
bdb0: 4c 49 54 45 5f 44 65 66 65 72 46 4b 73 29 20 29  LITE_DeferFKs) )
bdc0: 7b 0a 20 20 20 20 72 65 74 75 72 6e 20 30 3b 0a  {.    return 0;.
bdd0: 20 20 7d 0a 20 20 70 54 72 69 67 67 65 72 20 3d    }.  pTrigger =
bde0: 20 70 46 4b 65 79 2d 3e 61 70 54 72 69 67 67 65   pFKey->apTrigge
bdf0: 72 5b 69 41 63 74 69 6f 6e 5d 3b 0a 0a 20 20 69  r[iAction];..  i
be00: 66 28 20 61 63 74 69 6f 6e 21 3d 4f 45 5f 4e 6f  f( action!=OE_No
be10: 6e 65 20 26 26 20 21 70 54 72 69 67 67 65 72 20  ne && !pTrigger 
be20: 29 7b 0a 20 20 20 20 63 68 61 72 20 63 6f 6e 73  ){.    char cons
be30: 74 20 2a 7a 46 72 6f 6d 3b 20 20 20 20 20 20 20  t *zFrom;       
be40: 20 20 20 20 20 2f 2a 20 4e 61 6d 65 20 6f 66 20       /* Name of 
be50: 63 68 69 6c 64 20 74 61 62 6c 65 20 2a 2f 0a 20  child table */. 
be60: 20 20 20 69 6e 74 20 6e 46 72 6f 6d 3b 20 20 20     int nFrom;   
be70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
be80: 20 2f 2a 20 4c 65 6e 67 74 68 20 69 6e 20 62 79   /* Length in by
be90: 74 65 73 20 6f 66 20 7a 46 72 6f 6d 20 2a 2f 0a  tes of zFrom */.
bea0: 20 20 20 20 49 6e 64 65 78 20 2a 70 49 64 78 20      Index *pIdx 
beb0: 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20 20 20  = 0;            
bec0: 20 20 2f 2a 20 50 61 72 65 6e 74 20 6b 65 79 20    /* Parent key 
bed0: 69 6e 64 65 78 20 66 6f 72 20 74 68 69 73 20 46  index for this F
bee0: 4b 20 2a 2f 0a 20 20 20 20 69 6e 74 20 2a 61 69  K */.    int *ai
bef0: 43 6f 6c 20 3d 20 30 3b 20 20 20 20 20 20 20 20  Col = 0;        
bf00: 20 20 20 20 20 20 20 2f 2a 20 63 68 69 6c 64 20         /* child 
bf10: 74 61 62 6c 65 20 63 6f 6c 73 20 2d 3e 20 70 61  table cols -> pa
bf20: 72 65 6e 74 20 6b 65 79 20 63 6f 6c 73 20 2a 2f  rent key cols */
bf30: 0a 20 20 20 20 54 72 69 67 67 65 72 53 74 65 70  .    TriggerStep
bf40: 20 2a 70 53 74 65 70 20 3d 20 30 3b 20 20 20 20   *pStep = 0;    
bf50: 20 20 20 20 2f 2a 20 46 69 72 73 74 20 28 6f 6e      /* First (on
bf60: 6c 79 29 20 73 74 65 70 20 6f 66 20 74 72 69 67  ly) step of trig
bf70: 67 65 72 20 70 72 6f 67 72 61 6d 20 2a 2f 0a 20  ger program */. 
bf80: 20 20 20 45 78 70 72 20 2a 70 57 68 65 72 65 20     Expr *pWhere 
bf90: 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20 20 20  = 0;            
bfa0: 20 2f 2a 20 57 48 45 52 45 20 63 6c 61 75 73 65   /* WHERE clause
bfb0: 20 6f 66 20 74 72 69 67 67 65 72 20 73 74 65 70   of trigger step
bfc0: 20 2a 2f 0a 20 20 20 20 45 78 70 72 4c 69 73 74   */.    ExprList
bfd0: 20 2a 70 4c 69 73 74 20 3d 20 30 3b 20 20 20 20   *pList = 0;    
bfe0: 20 20 20 20 20 20 2f 2a 20 43 68 61 6e 67 65 73        /* Changes
bff0: 20 6c 69 73 74 20 69 66 20 4f 4e 20 55 50 44 41   list if ON UPDA
c000: 54 45 20 43 41 53 43 41 44 45 20 2a 2f 0a 20 20  TE CASCADE */.  
c010: 20 20 53 65 6c 65 63 74 20 2a 70 53 65 6c 65 63    Select *pSelec
c020: 74 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20  t = 0;          
c030: 2f 2a 20 49 66 20 52 45 53 54 52 49 43 54 2c 20  /* If RESTRICT, 
c040: 22 53 45 4c 45 43 54 20 52 41 49 53 45 28 2e 2e  "SELECT RAISE(..
c050: 2e 29 22 20 2a 2f 0a 20 20 20 20 69 6e 74 20 69  .)" */.    int i
c060: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
c070: 20 20 20 20 20 20 20 20 20 2f 2a 20 49 74 65 72           /* Iter
c080: 61 74 6f 72 20 76 61 72 69 61 62 6c 65 20 2a 2f  ator variable */
c090: 0a 20 20 20 20 45 78 70 72 20 2a 70 57 68 65 6e  .    Expr *pWhen
c0a0: 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20 20   = 0;           
c0b0: 20 20 20 2f 2a 20 57 48 45 4e 20 63 6c 61 75 73     /* WHEN claus
c0c0: 65 20 66 6f 72 20 74 68 65 20 74 72 69 67 67 65  e for the trigge
c0d0: 72 20 2a 2f 0a 0a 20 20 20 20 69 66 28 20 73 71  r */..    if( sq
c0e0: 6c 69 74 65 33 46 6b 4c 6f 63 61 74 65 49 6e 64  lite3FkLocateInd
c0f0: 65 78 28 70 50 61 72 73 65 2c 20 70 54 61 62 2c  ex(pParse, pTab,
c100: 20 70 46 4b 65 79 2c 20 26 70 49 64 78 2c 20 26   pFKey, &pIdx, &
c110: 61 69 43 6f 6c 29 20 29 20 72 65 74 75 72 6e 20  aiCol) ) return 
c120: 30 3b 0a 20 20 20 20 61 73 73 65 72 74 28 20 61  0;.    assert( a
c130: 69 43 6f 6c 20 7c 7c 20 70 46 4b 65 79 2d 3e 6e  iCol || pFKey->n
c140: 43 6f 6c 3d 3d 31 20 29 3b 0a 0a 20 20 20 20 66  Col==1 );..    f
c150: 6f 72 28 69 3d 30 3b 20 69 3c 70 46 4b 65 79 2d  or(i=0; i<pFKey-
c160: 3e 6e 43 6f 6c 3b 20 69 2b 2b 29 7b 0a 20 20 20  >nCol; i++){.   
c170: 20 20 20 54 6f 6b 65 6e 20 74 4f 6c 64 20 3d 20     Token tOld = 
c180: 7b 20 22 6f 6c 64 22 2c 20 33 20 7d 3b 20 20 2f  { "old", 3 };  /
c190: 2a 20 4c 69 74 65 72 61 6c 20 22 6f 6c 64 22 20  * Literal "old" 
c1a0: 74 6f 6b 65 6e 20 2a 2f 0a 20 20 20 20 20 20 54  token */.      T
c1b0: 6f 6b 65 6e 20 74 4e 65 77 20 3d 20 7b 20 22 6e  oken tNew = { "n
c1c0: 65 77 22 2c 20 33 20 7d 3b 20 20 2f 2a 20 4c 69  ew", 3 };  /* Li
c1d0: 74 65 72 61 6c 20 22 6e 65 77 22 20 74 6f 6b 65  teral "new" toke
c1e0: 6e 20 2a 2f 0a 20 20 20 20 20 20 54 6f 6b 65 6e  n */.      Token
c1f0: 20 74 46 72 6f 6d 43 6f 6c 3b 20 20 20 20 20 20   tFromCol;      
c200: 20 20 20 20 20 20 20 2f 2a 20 4e 61 6d 65 20 6f         /* Name o
c210: 66 20 63 6f 6c 75 6d 6e 20 69 6e 20 63 68 69 6c  f column in chil
c220: 64 20 74 61 62 6c 65 20 2a 2f 0a 20 20 20 20 20  d table */.     
c230: 20 54 6f 6b 65 6e 20 74 54 6f 43 6f 6c 3b 20 20   Token tToCol;  
c240: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
c250: 4e 61 6d 65 20 6f 66 20 63 6f 6c 75 6d 6e 20 69  Name of column i
c260: 6e 20 70 61 72 65 6e 74 20 74 61 62 6c 65 20 2a  n parent table *
c270: 2f 0a 20 20 20 20 20 20 69 6e 74 20 69 46 72 6f  /.      int iFro
c280: 6d 43 6f 6c 3b 20 20 20 20 20 20 20 20 20 20 20  mCol;           
c290: 20 20 20 20 2f 2a 20 49 64 78 20 6f 66 20 63 6f      /* Idx of co
c2a0: 6c 75 6d 6e 20 69 6e 20 63 68 69 6c 64 20 74 61  lumn in child ta
c2b0: 62 6c 65 20 2a 2f 0a 20 20 20 20 20 20 45 78 70  ble */.      Exp
c2c0: 72 20 2a 70 45 71 3b 20 20 20 20 20 20 20 20 20  r *pEq;         
c2d0: 20 20 20 20 20 20 20 20 20 2f 2a 20 74 46 72 6f           /* tFro
c2e0: 6d 43 6f 6c 20 3d 20 4f 4c 44 2e 74 54 6f 43 6f  mCol = OLD.tToCo
c2f0: 6c 20 2a 2f 0a 0a 20 20 20 20 20 20 69 46 72 6f  l */..      iFro
c300: 6d 43 6f 6c 20 3d 20 61 69 43 6f 6c 20 3f 20 61  mCol = aiCol ? a
c310: 69 43 6f 6c 5b 69 5d 20 3a 20 70 46 4b 65 79 2d  iCol[i] : pFKey-
c320: 3e 61 43 6f 6c 5b 30 5d 2e 69 46 72 6f 6d 3b 0a  >aCol[0].iFrom;.
c330: 20 20 20 20 20 20 61 73 73 65 72 74 28 20 69 46        assert( iF
c340: 72 6f 6d 43 6f 6c 3e 3d 30 20 29 3b 0a 20 20 20  romCol>=0 );.   
c350: 20 20 20 61 73 73 65 72 74 28 20 70 49 64 78 21     assert( pIdx!
c360: 3d 30 20 7c 7c 20 28 70 54 61 62 2d 3e 69 50 4b  =0 || (pTab->iPK
c370: 65 79 3e 3d 30 20 26 26 20 70 54 61 62 2d 3e 69  ey>=0 && pTab->i
c380: 50 4b 65 79 3c 70 54 61 62 2d 3e 6e 43 6f 6c 29  PKey<pTab->nCol)
c390: 20 29 3b 0a 20 20 20 20 20 20 61 73 73 65 72 74   );.      assert
c3a0: 28 20 70 49 64 78 3d 3d 30 20 7c 7c 20 70 49 64  ( pIdx==0 || pId
c3b0: 78 2d 3e 61 69 43 6f 6c 75 6d 6e 5b 69 5d 3e 3d  x->aiColumn[i]>=
c3c0: 30 20 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  0 );.      sqlit
c3d0: 65 33 54 6f 6b 65 6e 49 6e 69 74 28 26 74 54 6f  e3TokenInit(&tTo
c3e0: 43 6f 6c 2c 0a 20 20 20 20 20 20 20 20 20 20 20  Col,.           
c3f0: 20 20 20 20 20 20 20 20 70 54 61 62 2d 3e 61 43          pTab->aC
c400: 6f 6c 5b 70 49 64 78 20 3f 20 70 49 64 78 2d 3e  ol[pIdx ? pIdx->
c410: 61 69 43 6f 6c 75 6d 6e 5b 69 5d 20 3a 20 70 54  aiColumn[i] : pT
c420: 61 62 2d 3e 69 50 4b 65 79 5d 2e 7a 4e 61 6d 65  ab->iPKey].zName
c430: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
c440: 54 6f 6b 65 6e 49 6e 69 74 28 26 74 46 72 6f 6d  TokenInit(&tFrom
c450: 43 6f 6c 2c 20 70 46 4b 65 79 2d 3e 70 46 72 6f  Col, pFKey->pFro
c460: 6d 2d 3e 61 43 6f 6c 5b 69 46 72 6f 6d 43 6f 6c  m->aCol[iFromCol
c470: 5d 2e 7a 4e 61 6d 65 29 3b 0a 0a 20 20 20 20 20  ].zName);..     
c480: 20 2f 2a 20 43 72 65 61 74 65 20 74 68 65 20 65   /* Create the e
c490: 78 70 72 65 73 73 69 6f 6e 20 22 4f 4c 44 2e 7a  xpression "OLD.z
c4a0: 54 6f 43 6f 6c 20 3d 20 7a 46 72 6f 6d 43 6f 6c  ToCol = zFromCol
c4b0: 22 2e 20 49 74 20 69 73 20 69 6d 70 6f 72 74 61  ". It is importa
c4c0: 6e 74 0a 20 20 20 20 20 20 2a 2a 20 74 68 61 74  nt.      ** that
c4d0: 20 74 68 65 20 22 4f 4c 44 2e 7a 54 6f 43 6f 6c   the "OLD.zToCol
c4e0: 22 20 74 65 72 6d 20 69 73 20 6f 6e 20 74 68 65  " term is on the
c4f0: 20 4c 48 53 20 6f 66 20 74 68 65 20 3d 20 6f 70   LHS of the = op
c500: 65 72 61 74 6f 72 2c 20 73 6f 0a 20 20 20 20 20  erator, so.     
c510: 20 2a 2a 20 74 68 61 74 20 74 68 65 20 61 66 66   ** that the aff
c520: 69 6e 69 74 79 20 61 6e 64 20 63 6f 6c 6c 61 74  inity and collat
c530: 69 6f 6e 20 73 65 71 75 65 6e 63 65 20 61 73 73  ion sequence ass
c540: 6f 63 69 61 74 65 64 20 77 69 74 68 20 74 68 65  ociated with the
c550: 0a 20 20 20 20 20 20 2a 2a 20 70 61 72 65 6e 74  .      ** parent
c560: 20 74 61 62 6c 65 20 61 72 65 20 75 73 65 64 20   table are used 
c570: 66 6f 72 20 74 68 65 20 63 6f 6d 70 61 72 69 73  for the comparis
c580: 6f 6e 2e 20 2a 2f 0a 20 20 20 20 20 20 70 45 71  on. */.      pEq
c590: 20 3d 20 73 71 6c 69 74 65 33 50 45 78 70 72 28   = sqlite3PExpr(
c5a0: 70 50 61 72 73 65 2c 20 54 4b 5f 45 51 2c 0a 20  pParse, TK_EQ,. 
c5b0: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
c5c0: 50 45 78 70 72 28 70 50 61 72 73 65 2c 20 54 4b  PExpr(pParse, TK
c5d0: 5f 44 4f 54 2c 20 0a 20 20 20 20 20 20 20 20 20  _DOT, .         
c5e0: 20 20 20 73 71 6c 69 74 65 33 45 78 70 72 41 6c     sqlite3ExprAl
c5f0: 6c 6f 63 28 64 62 2c 20 54 4b 5f 49 44 2c 20 26  loc(db, TK_ID, &
c600: 74 4f 6c 64 2c 20 30 29 2c 0a 20 20 20 20 20 20  tOld, 0),.      
c610: 20 20 20 20 20 20 73 71 6c 69 74 65 33 45 78 70        sqlite3Exp
c620: 72 41 6c 6c 6f 63 28 64 62 2c 20 54 4b 5f 49 44  rAlloc(db, TK_ID
c630: 2c 20 26 74 54 6f 43 6f 6c 2c 20 30 29 29 2c 0a  , &tToCol, 0)),.
c640: 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65            sqlite
c650: 33 45 78 70 72 41 6c 6c 6f 63 28 64 62 2c 20 54  3ExprAlloc(db, T
c660: 4b 5f 49 44 2c 20 26 74 46 72 6f 6d 43 6f 6c 2c  K_ID, &tFromCol,
c670: 20 30 29 0a 20 20 20 20 20 20 29 3b 0a 20 20 20   0).      );.   
c680: 20 20 20 70 57 68 65 72 65 20 3d 20 73 71 6c 69     pWhere = sqli
c690: 74 65 33 45 78 70 72 41 6e 64 28 70 50 61 72 73  te3ExprAnd(pPars
c6a0: 65 2c 20 70 57 68 65 72 65 2c 20 70 45 71 29 3b  e, pWhere, pEq);
c6b0: 0a 0a 20 20 20 20 20 20 2f 2a 20 46 6f 72 20 4f  ..      /* For O
c6c0: 4e 20 55 50 44 41 54 45 2c 20 63 6f 6e 73 74 72  N UPDATE, constr
c6d0: 75 63 74 20 74 68 65 20 6e 65 78 74 20 74 65 72  uct the next ter
c6e0: 6d 20 6f 66 20 74 68 65 20 57 48 45 4e 20 63 6c  m of the WHEN cl
c6f0: 61 75 73 65 2e 0a 20 20 20 20 20 20 2a 2a 20 54  ause..      ** T
c700: 68 65 20 66 69 6e 61 6c 20 57 48 45 4e 20 63 6c  he final WHEN cl
c710: 61 75 73 65 20 77 69 6c 6c 20 62 65 20 6c 69 6b  ause will be lik
c720: 65 20 74 68 69 73 3a 0a 20 20 20 20 20 20 2a 2a  e this:.      **
c730: 0a 20 20 20 20 20 20 2a 2a 20 20 20 20 57 48 45  .      **    WHE
c740: 4e 20 4e 4f 54 28 6f 6c 64 2e 63 6f 6c 31 20 49  N NOT(old.col1 I
c750: 53 20 6e 65 77 2e 63 6f 6c 31 20 41 4e 44 20 2e  S new.col1 AND .
c760: 2e 2e 20 41 4e 44 20 6f 6c 64 2e 63 6f 6c 4e 20  .. AND old.colN 
c770: 49 53 20 6e 65 77 2e 63 6f 6c 4e 29 0a 20 20 20  IS new.colN).   
c780: 20 20 20 2a 2f 0a 20 20 20 20 20 20 69 66 28 20     */.      if( 
c790: 70 43 68 61 6e 67 65 73 20 29 7b 0a 20 20 20 20  pChanges ){.    
c7a0: 20 20 20 20 70 45 71 20 3d 20 73 71 6c 69 74 65      pEq = sqlite
c7b0: 33 50 45 78 70 72 28 70 50 61 72 73 65 2c 20 54  3PExpr(pParse, T
c7c0: 4b 5f 49 53 2c 0a 20 20 20 20 20 20 20 20 20 20  K_IS,.          
c7d0: 20 20 73 71 6c 69 74 65 33 50 45 78 70 72 28 70    sqlite3PExpr(p
c7e0: 50 61 72 73 65 2c 20 54 4b 5f 44 4f 54 2c 20 0a  Parse, TK_DOT, .
c7f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73 71                sq
c800: 6c 69 74 65 33 45 78 70 72 41 6c 6c 6f 63 28 64  lite3ExprAlloc(d
c810: 62 2c 20 54 4b 5f 49 44 2c 20 26 74 4f 6c 64 2c  b, TK_ID, &tOld,
c820: 20 30 29 2c 0a 20 20 20 20 20 20 20 20 20 20 20   0),.           
c830: 20 20 20 73 71 6c 69 74 65 33 45 78 70 72 41 6c     sqlite3ExprAl
c840: 6c 6f 63 28 64 62 2c 20 54 4b 5f 49 44 2c 20 26  loc(db, TK_ID, &
c850: 74 54 6f 43 6f 6c 2c 20 30 29 29 2c 0a 20 20 20  tToCol, 0)),.   
c860: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
c870: 50 45 78 70 72 28 70 50 61 72 73 65 2c 20 54 4b  PExpr(pParse, TK
c880: 5f 44 4f 54 2c 20 0a 20 20 20 20 20 20 20 20 20  _DOT, .         
c890: 20 20 20 20 20 73 71 6c 69 74 65 33 45 78 70 72       sqlite3Expr
c8a0: 41 6c 6c 6f 63 28 64 62 2c 20 54 4b 5f 49 44 2c  Alloc(db, TK_ID,
c8b0: 20 26 74 4e 65 77 2c 20 30 29 2c 0a 20 20 20 20   &tNew, 0),.    
c8c0: 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65            sqlite
c8d0: 33 45 78 70 72 41 6c 6c 6f 63 28 64 62 2c 20 54  3ExprAlloc(db, T
c8e0: 4b 5f 49 44 2c 20 26 74 54 6f 43 6f 6c 2c 20 30  K_ID, &tToCol, 0
c8f0: 29 29 0a 20 20 20 20 20 20 20 20 20 20 20 20 29  )).            )
c900: 3b 0a 20 20 20 20 20 20 20 20 70 57 68 65 6e 20  ;.        pWhen 
c910: 3d 20 73 71 6c 69 74 65 33 45 78 70 72 41 6e 64  = sqlite3ExprAnd
c920: 28 70 50 61 72 73 65 2c 20 70 57 68 65 6e 2c 20  (pParse, pWhen, 
c930: 70 45 71 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20  pEq);.      }.  
c940: 0a 20 20 20 20 20 20 69 66 28 20 61 63 74 69 6f  .      if( actio
c950: 6e 21 3d 4f 45 5f 52 65 73 74 72 69 63 74 20 26  n!=OE_Restrict &
c960: 26 20 28 61 63 74 69 6f 6e 21 3d 4f 45 5f 43 61  & (action!=OE_Ca
c970: 73 63 61 64 65 20 7c 7c 20 70 43 68 61 6e 67 65  scade || pChange
c980: 73 29 20 29 7b 0a 20 20 20 20 20 20 20 20 45 78  s) ){.        Ex
c990: 70 72 20 2a 70 4e 65 77 3b 0a 20 20 20 20 20 20  pr *pNew;.      
c9a0: 20 20 69 66 28 20 61 63 74 69 6f 6e 3d 3d 4f 45    if( action==OE
c9b0: 5f 43 61 73 63 61 64 65 20 29 7b 0a 20 20 20 20  _Cascade ){.    
c9c0: 20 20 20 20 20 20 70 4e 65 77 20 3d 20 73 71 6c        pNew = sql
c9d0: 69 74 65 33 50 45 78 70 72 28 70 50 61 72 73 65  ite3PExpr(pParse
c9e0: 2c 20 54 4b 5f 44 4f 54 2c 20 0a 20 20 20 20 20  , TK_DOT, .     
c9f0: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 45 78         sqlite3Ex
ca00: 70 72 41 6c 6c 6f 63 28 64 62 2c 20 54 4b 5f 49  prAlloc(db, TK_I
ca10: 44 2c 20 26 74 4e 65 77 2c 20 30 29 2c 0a 20 20  D, &tNew, 0),.  
ca20: 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65            sqlite
ca30: 33 45 78 70 72 41 6c 6c 6f 63 28 64 62 2c 20 54  3ExprAlloc(db, T
ca40: 4b 5f 49 44 2c 20 26 74 54 6f 43 6f 6c 2c 20 30  K_ID, &tToCol, 0
ca50: 29 29 3b 0a 20 20 20 20 20 20 20 20 7d 65 6c 73  ));.        }els
ca60: 65 20 69 66 28 20 61 63 74 69 6f 6e 3d 3d 4f 45  e if( action==OE
ca70: 5f 53 65 74 44 66 6c 74 20 29 7b 0a 20 20 20 20  _SetDflt ){.    
ca80: 20 20 20 20 20 20 45 78 70 72 20 2a 70 44 66 6c        Expr *pDfl
ca90: 74 20 3d 20 70 46 4b 65 79 2d 3e 70 46 72 6f 6d  t = pFKey->pFrom
caa0: 2d 3e 61 43 6f 6c 5b 69 46 72 6f 6d 43 6f 6c 5d  ->aCol[iFromCol]
cab0: 2e 70 44 66 6c 74 3b 0a 20 20 20 20 20 20 20 20  .pDflt;.        
cac0: 20 20 69 66 28 20 70 44 66 6c 74 20 29 7b 0a 20    if( pDflt ){. 
cad0: 20 20 20 20 20 20 20 20 20 20 20 70 4e 65 77 20             pNew 
cae0: 3d 20 73 71 6c 69 74 65 33 45 78 70 72 44 75 70  = sqlite3ExprDup
caf0: 28 64 62 2c 20 70 44 66 6c 74 2c 20 30 29 3b 0a  (db, pDflt, 0);.
cb00: 20 20 20 20 20 20 20 20 20 20 7d 65 6c 73 65 7b            }else{
cb10: 0a 20 20 20 20 20 20 20 20 20 20 20 20 70 4e 65  .            pNe
cb20: 77 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72 41  w = sqlite3ExprA
cb30: 6c 6c 6f 63 28 64 62 2c 20 54 4b 5f 4e 55 4c 4c  lloc(db, TK_NULL
cb40: 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 20  , 0, 0);.       
cb50: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 7d 65 6c     }.        }el
cb60: 73 65 7b 0a 20 20 20 20 20 20 20 20 20 20 70 4e  se{.          pN
cb70: 65 77 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72  ew = sqlite3Expr
cb80: 41 6c 6c 6f 63 28 64 62 2c 20 54 4b 5f 4e 55 4c  Alloc(db, TK_NUL
cb90: 4c 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20  L, 0, 0);.      
cba0: 20 20 7d 0a 20 20 20 20 20 20 20 20 70 4c 69 73    }.        pLis
cbb0: 74 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72 4c  t = sqlite3ExprL
cbc0: 69 73 74 41 70 70 65 6e 64 28 70 50 61 72 73 65  istAppend(pParse
cbd0: 2c 20 70 4c 69 73 74 2c 20 70 4e 65 77 29 3b 0a  , pList, pNew);.
cbe0: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 45          sqlite3E
cbf0: 78 70 72 4c 69 73 74 53 65 74 4e 61 6d 65 28 70  xprListSetName(p
cc00: 50 61 72 73 65 2c 20 70 4c 69 73 74 2c 20 26 74  Parse, pList, &t
cc10: 46 72 6f 6d 43 6f 6c 2c 20 30 29 3b 0a 20 20 20  FromCol, 0);.   
cc20: 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 20 20 73     }.    }.    s
cc30: 71 6c 69 74 65 33 44 62 46 72 65 65 28 64 62 2c  qlite3DbFree(db,
cc40: 20 61 69 43 6f 6c 29 3b 0a 0a 20 20 20 20 7a 46   aiCol);..    zF
cc50: 72 6f 6d 20 3d 20 70 46 4b 65 79 2d 3e 70 46 72  rom = pFKey->pFr
cc60: 6f 6d 2d 3e 7a 4e 61 6d 65 3b 0a 20 20 20 20 6e  om->zName;.    n
cc70: 46 72 6f 6d 20 3d 20 73 71 6c 69 74 65 33 53 74  From = sqlite3St
cc80: 72 6c 65 6e 33 30 28 7a 46 72 6f 6d 29 3b 0a 0a  rlen30(zFrom);..
cc90: 20 20 20 20 69 66 28 20 61 63 74 69 6f 6e 3d 3d      if( action==
cca0: 4f 45 5f 52 65 73 74 72 69 63 74 20 29 7b 0a 20  OE_Restrict ){. 
ccb0: 20 20 20 20 20 54 6f 6b 65 6e 20 74 46 72 6f 6d       Token tFrom
ccc0: 3b 0a 20 20 20 20 20 20 45 78 70 72 20 2a 70 52  ;.      Expr *pR
ccd0: 61 69 73 65 3b 20 0a 0a 20 20 20 20 20 20 74 46  aise; ..      tF
cce0: 72 6f 6d 2e 7a 20 3d 20 7a 46 72 6f 6d 3b 0a 20  rom.z = zFrom;. 
ccf0: 20 20 20 20 20 74 46 72 6f 6d 2e 6e 20 3d 20 6e       tFrom.n = n
cd00: 46 72 6f 6d 3b 0a 20 20 20 20 20 20 70 52 61 69  From;.      pRai
cd10: 73 65 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72  se = sqlite3Expr
cd20: 28 64 62 2c 20 54 4b 5f 52 41 49 53 45 2c 20 22  (db, TK_RAISE, "
cd30: 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73  FOREIGN KEY cons
cd40: 74 72 61 69 6e 74 20 66 61 69 6c 65 64 22 29 3b  traint failed");
cd50: 0a 20 20 20 20 20 20 69 66 28 20 70 52 61 69 73  .      if( pRais
cd60: 65 20 29 7b 0a 20 20 20 20 20 20 20 20 70 52 61  e ){.        pRa
cd70: 69 73 65 2d 3e 61 66 66 45 78 70 72 20 3d 20 4f  ise->affExpr = O
cd80: 45 5f 41 62 6f 72 74 3b 0a 20 20 20 20 20 20 7d  E_Abort;.      }
cd90: 0a 20 20 20 20 20 20 70 53 65 6c 65 63 74 20 3d  .      pSelect =
cda0: 20 73 71 6c 69 74 65 33 53 65 6c 65 63 74 4e 65   sqlite3SelectNe
cdb0: 77 28 70 50 61 72 73 65 2c 20 0a 20 20 20 20 20  w(pParse, .     
cdc0: 20 20 20 20 20 73 71 6c 69 74 65 33 45 78 70 72       sqlite3Expr
cdd0: 4c 69 73 74 41 70 70 65 6e 64 28 70 50 61 72 73  ListAppend(pPars
cde0: 65 2c 20 30 2c 20 70 52 61 69 73 65 29 2c 0a 20  e, 0, pRaise),. 
cdf0: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
ce00: 53 72 63 4c 69 73 74 41 70 70 65 6e 64 28 70 50  SrcListAppend(pP
ce10: 61 72 73 65 2c 20 30 2c 20 26 74 46 72 6f 6d 2c  arse, 0, &tFrom,
ce20: 20 30 29 2c 0a 20 20 20 20 20 20 20 20 20 20 70   0),.          p
ce30: 57 68 65 72 65 2c 0a 20 20 20 20 20 20 20 20 20  Where,.         
ce40: 20 30 2c 20 30 2c 20 30 2c 20 30 2c 20 30 0a 20   0, 0, 0, 0, 0. 
ce50: 20 20 20 20 20 29 3b 0a 20 20 20 20 20 20 70 57       );.      pW
ce60: 68 65 72 65 20 3d 20 30 3b 0a 20 20 20 20 7d 0a  here = 0;.    }.
ce70: 0a 20 20 20 20 2f 2a 20 44 69 73 61 62 6c 65 20  .    /* Disable 
ce80: 6c 6f 6f 6b 61 73 69 64 65 20 6d 65 6d 6f 72 79  lookaside memory
ce90: 20 61 6c 6c 6f 63 61 74 69 6f 6e 20 2a 2f 0a 20   allocation */. 
cea0: 20 20 20 73 71 6c 69 74 65 33 4c 6f 6f 6b 61 73     sqlite3Lookas
ceb0: 69 64 65 44 69 73 61 62 6c 65 28 26 64 62 2d 3e  ideDisable(&db->
cec0: 6c 6f 6f 6b 61 73 69 64 65 29 3b 0a 0a 20 20 20  lookaside);..   
ced0: 20 70 54 72 69 67 67 65 72 20 3d 20 28 54 72 69   pTrigger = (Tri
cee0: 67 67 65 72 20 2a 29 73 71 6c 69 74 65 33 44 62  gger *)sqlite3Db
cef0: 4d 61 6c 6c 6f 63 5a 65 72 6f 28 64 62 2c 20 0a  MallocZero(db, .
cf00: 20 20 20 20 20 20 20 20 73 69 7a 65 6f 66 28 54          sizeof(T
cf10: 72 69 67 67 65 72 29 20 2b 20 20 20 20 20 20 20  rigger) +       
cf20: 20 20 2f 2a 20 73 74 72 75 63 74 20 54 72 69 67    /* struct Trig
cf30: 67 65 72 20 2a 2f 0a 20 20 20 20 20 20 20 20 73  ger */.        s
cf40: 69 7a 65 6f 66 28 54 72 69 67 67 65 72 53 74 65  izeof(TriggerSte
cf50: 70 29 20 2b 20 20 20 20 20 2f 2a 20 53 69 6e 67  p) +     /* Sing
cf60: 6c 65 20 73 74 65 70 20 69 6e 20 74 72 69 67 67  le step in trigg
cf70: 65 72 20 70 72 6f 67 72 61 6d 20 2a 2f 0a 20 20  er program */.  
cf80: 20 20 20 20 20 20 6e 46 72 6f 6d 20 2b 20 31 20        nFrom + 1 
cf90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
cfa0: 2f 2a 20 53 70 61 63 65 20 66 6f 72 20 70 53 74  /* Space for pSt
cfb0: 65 70 2d 3e 7a 54 61 72 67 65 74 20 2a 2f 0a 20  ep->zTarget */. 
cfc0: 20 20 20 29 3b 0a 20 20 20 20 69 66 28 20 70 54     );.    if( pT
cfd0: 72 69 67 67 65 72 20 29 7b 0a 20 20 20 20 20 20  rigger ){.      
cfe0: 70 53 74 65 70 20 3d 20 70 54 72 69 67 67 65 72  pStep = pTrigger
cff0: 2d 3e 73 74 65 70 5f 6c 69 73 74 20 3d 20 28 54  ->step_list = (T
d000: 72 69 67 67 65 72 53 74 65 70 20 2a 29 26 70 54  riggerStep *)&pT
d010: 72 69 67 67 65 72 5b 31 5d 3b 0a 20 20 20 20 20  rigger[1];.     
d020: 20 70 53 74 65 70 2d 3e 7a 54 61 72 67 65 74 20   pStep->zTarget 
d030: 3d 20 28 63 68 61 72 20 2a 29 26 70 53 74 65 70  = (char *)&pStep
d040: 5b 31 5d 3b 0a 20 20 20 20 20 20 6d 65 6d 63 70  [1];.      memcp
d050: 79 28 28 63 68 61 72 20 2a 29 70 53 74 65 70 2d  y((char *)pStep-
d060: 3e 7a 54 61 72 67 65 74 2c 20 7a 46 72 6f 6d 2c  >zTarget, zFrom,
d070: 20 6e 46 72 6f 6d 29 3b 0a 20 20 0a 20 20 20 20   nFrom);.  .    
d080: 20 20 70 53 74 65 70 2d 3e 70 57 68 65 72 65 20    pStep->pWhere 
d090: 3d 20 73 71 6c 69 74 65 33 45 78 70 72 44 75 70  = sqlite3ExprDup
d0a0: 28 64 62 2c 20 70 57 68 65 72 65 2c 20 45 58 50  (db, pWhere, EXP
d0b0: 52 44 55 50 5f 52 45 44 55 43 45 29 3b 0a 20 20  RDUP_REDUCE);.  
d0c0: 20 20 20 20 70 53 74 65 70 2d 3e 70 45 78 70 72      pStep->pExpr
d0d0: 4c 69 73 74 20 3d 20 73 71 6c 69 74 65 33 45 78  List = sqlite3Ex
d0e0: 70 72 4c 69 73 74 44 75 70 28 64 62 2c 20 70 4c  prListDup(db, pL
d0f0: 69 73 74 2c 20 45 58 50 52 44 55 50 5f 52 45 44  ist, EXPRDUP_RED
d100: 55 43 45 29 3b 0a 20 20 20 20 20 20 70 53 74 65  UCE);.      pSte
d110: 70 2d 3e 70 53 65 6c 65 63 74 20 3d 20 73 71 6c  p->pSelect = sql
d120: 69 74 65 33 53 65 6c 65 63 74 44 75 70 28 64 62  ite3SelectDup(db
d130: 2c 20 70 53 65 6c 65 63 74 2c 20 45 58 50 52 44  , pSelect, EXPRD
d140: 55 50 5f 52 45 44 55 43 45 29 3b 0a 20 20 20 20  UP_REDUCE);.    
d150: 20 20 69 66 28 20 70 57 68 65 6e 20 29 7b 0a 20    if( pWhen ){. 
d160: 20 20 20 20 20 20 20 70 57 68 65 6e 20 3d 20 73         pWhen = s
d170: 71 6c 69 74 65 33 50 45 78 70 72 28 70 50 61 72  qlite3PExpr(pPar
d180: 73 65 2c 20 54 4b 5f 4e 4f 54 2c 20 70 57 68 65  se, TK_NOT, pWhe
d190: 6e 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 70  n, 0);.        p
d1a0: 54 72 69 67 67 65 72 2d 3e 70 57 68 65 6e 20 3d  Trigger->pWhen =
d1b0: 20 73 71 6c 69 74 65 33 45 78 70 72 44 75 70 28   sqlite3ExprDup(
d1c0: 64 62 2c 20 70 57 68 65 6e 2c 20 45 58 50 52 44  db, pWhen, EXPRD
d1d0: 55 50 5f 52 45 44 55 43 45 29 3b 0a 20 20 20 20  UP_REDUCE);.    
d1e0: 20 20 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f    }.    }..    /
d1f0: 2a 20 52 65 2d 65 6e 61 62 6c 65 20 74 68 65 20  * Re-enable the 
d200: 6c 6f 6f 6b 61 73 69 64 65 20 62 75 66 66 65 72  lookaside buffer
d210: 2c 20 69 66 20 69 74 20 77 61 73 20 64 69 73 61  , if it was disa
d220: 62 6c 65 64 20 65 61 72 6c 69 65 72 2e 20 2a 2f  bled earlier. */
d230: 0a 20 20 20 20 73 71 6c 69 74 65 33 4c 6f 6f 6b  .    sqlite3Look
d240: 61 73 69 64 65 45 6e 61 62 6c 65 28 26 64 62 2d  asideEnable(&db-
d250: 3e 6c 6f 6f 6b 61 73 69 64 65 29 3b 0a 0a 20 20  >lookaside);..  
d260: 20 20 73 71 6c 69 74 65 33 45 78 70 72 44 65 6c    sqlite3ExprDel
d270: 65 74 65 28 64 62 2c 20 70 57 68 65 72 65 29 3b  ete(db, pWhere);
d280: 0a 20 20 20 20 73 71 6c 69 74 65 33 45 78 70 72  .    sqlite3Expr
d290: 44 65 6c 65 74 65 28 64 62 2c 20 70 57 68 65 6e  Delete(db, pWhen
d2a0: 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 45 78  );.    sqlite3Ex
d2b0: 70 72 4c 69 73 74 44 65 6c 65 74 65 28 64 62 2c  prListDelete(db,
d2c0: 20 70 4c 69 73 74 29 3b 0a 20 20 20 20 73 71 6c   pList);.    sql
d2d0: 69 74 65 33 53 65 6c 65 63 74 44 65 6c 65 74 65  ite3SelectDelete
d2e0: 28 64 62 2c 20 70 53 65 6c 65 63 74 29 3b 0a 20  (db, pSelect);. 
d2f0: 20 20 20 69 66 28 20 64 62 2d 3e 6d 61 6c 6c 6f     if( db->mallo
d300: 63 46 61 69 6c 65 64 3d 3d 31 20 29 7b 0a 20 20  cFailed==1 ){.  
d310: 20 20 20 20 66 6b 54 72 69 67 67 65 72 44 65 6c      fkTriggerDel
d320: 65 74 65 28 64 62 2c 20 70 54 72 69 67 67 65 72  ete(db, pTrigger
d330: 29 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  );.      return 
d340: 30 3b 0a 20 20 20 20 7d 0a 20 20 20 20 61 73 73  0;.    }.    ass
d350: 65 72 74 28 20 70 53 74 65 70 21 3d 30 20 29 3b  ert( pStep!=0 );
d360: 0a 20 20 20 20 61 73 73 65 72 74 28 20 70 54 72  .    assert( pTr
d370: 69 67 67 65 72 21 3d 30 20 29 3b 0a 0a 20 20 20  igger!=0 );..   
d380: 20 73 77 69 74 63 68 28 20 61 63 74 69 6f 6e 20   switch( action 
d390: 29 7b 0a 20 20 20 20 20 20 63 61 73 65 20 4f 45  ){.      case OE
d3a0: 5f 52 65 73 74 72 69 63 74 3a 0a 20 20 20 20 20  _Restrict:.     
d3b0: 20 20 20 70 53 74 65 70 2d 3e 6f 70 20 3d 20 54     pStep->op = T
d3c0: 4b 5f 53 45 4c 45 43 54 3b 20 0a 20 20 20 20 20  K_SELECT; .     
d3d0: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20     break;.      
d3e0: 63 61 73 65 20 4f 45 5f 43 61 73 63 61 64 65 3a  case OE_Cascade:
d3f0: 20 0a 20 20 20 20 20 20 20 20 69 66 28 20 21 70   .        if( !p
d400: 43 68 61 6e 67 65 73 20 29 7b 20 0a 20 20 20 20  Changes ){ .    
d410: 20 20 20 20 20 20 70 53 74 65 70 2d 3e 6f 70 20        pStep->op 
d420: 3d 20 54 4b 5f 44 45 4c 45 54 45 3b 20 0a 20 20  = TK_DELETE; .  
d430: 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 20 0a          break; .
d440: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
d450: 64 65 66 61 75 6c 74 3a 0a 20 20 20 20 20 20 20  default:.       
d460: 20 70 53 74 65 70 2d 3e 6f 70 20 3d 20 54 4b 5f   pStep->op = TK_
d470: 55 50 44 41 54 45 3b 0a 20 20 20 20 7d 0a 20 20  UPDATE;.    }.  
d480: 20 20 70 53 74 65 70 2d 3e 70 54 72 69 67 20 3d    pStep->pTrig =
d490: 20 70 54 72 69 67 67 65 72 3b 0a 20 20 20 20 70   pTrigger;.    p
d4a0: 54 72 69 67 67 65 72 2d 3e 70 53 63 68 65 6d 61  Trigger->pSchema
d4b0: 20 3d 20 70 54 61 62 2d 3e 70 53 63 68 65 6d 61   = pTab->pSchema
d4c0: 3b 0a 20 20 20 20 70 54 72 69 67 67 65 72 2d 3e  ;.    pTrigger->
d4d0: 70 54 61 62 53 63 68 65 6d 61 20 3d 20 70 54 61  pTabSchema = pTa
d4e0: 62 2d 3e 70 53 63 68 65 6d 61 3b 0a 20 20 20 20  b->pSchema;.    
d4f0: 70 46 4b 65 79 2d 3e 61 70 54 72 69 67 67 65 72  pFKey->apTrigger
d500: 5b 69 41 63 74 69 6f 6e 5d 20 3d 20 70 54 72 69  [iAction] = pTri
d510: 67 67 65 72 3b 0a 20 20 20 20 70 54 72 69 67 67  gger;.    pTrigg
d520: 65 72 2d 3e 6f 70 20 3d 20 28 70 43 68 61 6e 67  er->op = (pChang
d530: 65 73 20 3f 20 54 4b 5f 55 50 44 41 54 45 20 3a  es ? TK_UPDATE :
d540: 20 54 4b 5f 44 45 4c 45 54 45 29 3b 0a 20 20 7d   TK_DELETE);.  }
d550: 0a 0a 20 20 72 65 74 75 72 6e 20 70 54 72 69 67  ..  return pTrig
d560: 67 65 72 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68  ger;.}../*.** Th
d570: 69 73 20 66 75 6e 63 74 69 6f 6e 20 69 73 20 63  is function is c
d580: 61 6c 6c 65 64 20 77 68 65 6e 20 64 65 6c 65 74  alled when delet
d590: 69 6e 67 20 6f 72 20 75 70 64 61 74 69 6e 67 20  ing or updating 
d5a0: 61 20 72 6f 77 20 74 6f 20 69 6d 70 6c 65 6d 65  a row to impleme
d5b0: 6e 74 0a 2a 2a 20 61 6e 79 20 72 65 71 75 69 72  nt.** any requir
d5c0: 65 64 20 43 41 53 43 41 44 45 2c 20 53 45 54 20  ed CASCADE, SET 
d5d0: 4e 55 4c 4c 20 6f 72 20 53 45 54 20 44 45 46 41  NULL or SET DEFA
d5e0: 55 4c 54 20 61 63 74 69 6f 6e 73 2e 0a 2a 2f 0a  ULT actions..*/.
d5f0: 76 6f 69 64 20 73 71 6c 69 74 65 33 46 6b 41 63  void sqlite3FkAc
d600: 74 69 6f 6e 73 28 0a 20 20 50 61 72 73 65 20 2a  tions(.  Parse *
d610: 70 50 61 72 73 65 2c 20 20 20 20 20 20 20 20 20  pParse,         
d620: 20 20 20 20 20 20 20 20 20 2f 2a 20 50 61 72 73           /* Pars
d630: 65 20 63 6f 6e 74 65 78 74 20 2a 2f 0a 20 20 54  e context */.  T
d640: 61 62 6c 65 20 2a 70 54 61 62 2c 20 20 20 20 20  able *pTab,     
d650: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
d660: 2a 20 54 61 62 6c 65 20 62 65 69 6e 67 20 75 70  * Table being up
d670: 64 61 74 65 64 20 6f 72 20 64 65 6c 65 74 65 64  dated or deleted
d680: 20 66 72 6f 6d 20 2a 2f 0a 20 20 45 78 70 72 4c   from */.  ExprL
d690: 69 73 74 20 2a 70 43 68 61 6e 67 65 73 2c 20 20  ist *pChanges,  
d6a0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 43 68             /* Ch
d6b0: 61 6e 67 65 2d 6c 69 73 74 20 66 6f 72 20 55 50  ange-list for UP
d6c0: 44 41 54 45 2c 20 4e 55 4c 4c 20 66 6f 72 20 44  DATE, NULL for D
d6d0: 45 4c 45 54 45 20 2a 2f 0a 20 20 69 6e 74 20 72  ELETE */.  int r
d6e0: 65 67 4f 6c 64 2c 20 20 20 20 20 20 20 20 20 20  egOld,          
d6f0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 41 64             /* Ad
d700: 64 72 65 73 73 20 6f 66 20 61 72 72 61 79 20 63  dress of array c
d710: 6f 6e 74 61 69 6e 69 6e 67 20 6f 6c 64 20 72 6f  ontaining old ro
d720: 77 20 2a 2f 0a 20 20 69 6e 74 20 2a 61 43 68 61  w */.  int *aCha
d730: 6e 67 65 2c 20 20 20 20 20 20 20 20 20 20 20 20  nge,            
d740: 20 20 20 20 20 20 20 2f 2a 20 41 72 72 61 79 20         /* Array 
d750: 69 6e 64 69 63 61 74 69 6e 67 20 55 50 44 41 54  indicating UPDAT
d760: 45 64 20 63 6f 6c 75 6d 6e 73 20 28 6f 72 20 30  Ed columns (or 0
d770: 29 20 2a 2f 0a 20 20 69 6e 74 20 62 43 68 6e 67  ) */.  int bChng
d780: 52 6f 77 69 64 20 20 20 20 20 20 20 20 20 20 20  Rowid           
d790: 20 20 20 20 20 20 20 2f 2a 20 54 72 75 65 20 69         /* True i
d7a0: 66 20 72 6f 77 69 64 20 69 73 20 55 50 44 41 54  f rowid is UPDAT
d7b0: 45 64 20 2a 2f 0a 29 7b 0a 20 20 2f 2a 20 49 66  Ed */.){.  /* If
d7c0: 20 66 6f 72 65 69 67 6e 2d 6b 65 79 20 73 75 70   foreign-key sup
d7d0: 70 6f 72 74 20 69 73 20 65 6e 61 62 6c 65 64 2c  port is enabled,
d7e0: 20 69 74 65 72 61 74 65 20 74 68 72 6f 75 67 68   iterate through
d7f0: 20 61 6c 6c 20 46 4b 73 20 74 68 61 74 20 0a 20   all FKs that . 
d800: 20 2a 2a 20 72 65 66 65 72 20 74 6f 20 74 61 62   ** refer to tab
d810: 6c 65 20 70 54 61 62 2e 20 49 66 20 74 68 65 72  le pTab. If ther
d820: 65 20 69 73 20 61 6e 20 61 63 74 69 6f 6e 20 61  e is an action a
d830: 73 73 6f 63 69 61 74 65 64 20 77 69 74 68 20 74  ssociated with t
d840: 68 65 20 46 4b 20 0a 20 20 2a 2a 20 66 6f 72 20  he FK .  ** for 
d850: 74 68 69 73 20 6f 70 65 72 61 74 69 6f 6e 20 28  this operation (
d860: 65 69 74 68 65 72 20 75 70 64 61 74 65 20 6f 72  either update or
d870: 20 64 65 6c 65 74 65 29 2c 20 69 6e 76 6f 6b 65   delete), invoke
d880: 20 74 68 65 20 61 73 73 6f 63 69 61 74 65 64 20   the associated 
d890: 0a 20 20 2a 2a 20 74 72 69 67 67 65 72 20 73 75  .  ** trigger su
d8a0: 62 2d 70 72 6f 67 72 61 6d 2e 20 20 2a 2f 0a 20  b-program.  */. 
d8b0: 20 69 66 28 20 70 50 61 72 73 65 2d 3e 64 62 2d   if( pParse->db-
d8c0: 3e 66 6c 61 67 73 26 53 51 4c 49 54 45 5f 46 6f  >flags&SQLITE_Fo
d8d0: 72 65 69 67 6e 4b 65 79 73 20 29 7b 0a 20 20 20  reignKeys ){.   
d8e0: 20 46 4b 65 79 20 2a 70 46 4b 65 79 3b 20 20 20   FKey *pFKey;   
d8f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
d900: 2a 20 49 74 65 72 61 74 6f 72 20 76 61 72 69 61  * Iterator varia
d910: 62 6c 65 20 2a 2f 0a 20 20 20 20 66 6f 72 28 70  ble */.    for(p
d920: 46 4b 65 79 20 3d 20 73 71 6c 69 74 65 33 46 6b  FKey = sqlite3Fk
d930: 52 65 66 65 72 65 6e 63 65 73 28 70 54 61 62 29  References(pTab)
d940: 3b 20 70 46 4b 65 79 3b 20 70 46 4b 65 79 3d 70  ; pFKey; pFKey=p
d950: 46 4b 65 79 2d 3e 70 4e 65 78 74 54 6f 29 7b 0a  FKey->pNextTo){.
d960: 20 20 20 20 20 20 69 66 28 20 61 43 68 61 6e 67        if( aChang
d970: 65 3d 3d 30 20 7c 7c 20 66 6b 50 61 72 65 6e 74  e==0 || fkParent
d980: 49 73 4d 6f 64 69 66 69 65 64 28 70 54 61 62 2c  IsModified(pTab,
d990: 20 70 46 4b 65 79 2c 20 61 43 68 61 6e 67 65 2c   pFKey, aChange,
d9a0: 20 62 43 68 6e 67 52 6f 77 69 64 29 20 29 7b 0a   bChngRowid) ){.
d9b0: 20 20 20 20 20 20 20 20 54 72 69 67 67 65 72 20          Trigger 
d9c0: 2a 70 41 63 74 20 3d 20 66 6b 41 63 74 69 6f 6e  *pAct = fkAction
d9d0: 54 72 69 67 67 65 72 28 70 50 61 72 73 65 2c 20  Trigger(pParse, 
d9e0: 70 54 61 62 2c 20 70 46 4b 65 79 2c 20 70 43 68  pTab, pFKey, pCh
d9f0: 61 6e 67 65 73 29 3b 0a 20 20 20 20 20 20 20 20  anges);.        
da00: 69 66 28 20 70 41 63 74 20 29 7b 0a 20 20 20 20  if( pAct ){.    
da10: 20 20 20 20 20 20 73 71 6c 69 74 65 33 43 6f 64        sqlite3Cod
da20: 65 52 6f 77 54 72 69 67 67 65 72 44 69 72 65 63  eRowTriggerDirec
da30: 74 28 70 50 61 72 73 65 2c 20 70 41 63 74 2c 20  t(pParse, pAct, 
da40: 70 54 61 62 2c 20 72 65 67 4f 6c 64 2c 20 4f 45  pTab, regOld, OE
da50: 5f 41 62 6f 72 74 2c 20 30 29 3b 0a 20 20 20 20  _Abort, 0);.    
da60: 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20      }.      }.  
da70: 20 20 7d 0a 20 20 7d 0a 7d 0a 0a 23 65 6e 64 69    }.  }.}..#endi
da80: 66 20 2f 2a 20 69 66 6e 64 65 66 20 53 51 4c 49  f /* ifndef SQLI
da90: 54 45 5f 4f 4d 49 54 5f 54 52 49 47 47 45 52 20  TE_OMIT_TRIGGER 
daa0: 2a 2f 0a 0a 2f 2a 0a 2a 2a 20 46 72 65 65 20 61  */../*.** Free a
dab0: 6c 6c 20 6d 65 6d 6f 72 79 20 61 73 73 6f 63 69  ll memory associ
dac0: 61 74 65 64 20 77 69 74 68 20 66 6f 72 65 69 67  ated with foreig
dad0: 6e 20 6b 65 79 20 64 65 66 69 6e 69 74 69 6f 6e  n key definition
dae0: 73 20 61 74 74 61 63 68 65 64 20 74 6f 0a 2a 2a  s attached to.**
daf0: 20 74 61 62 6c 65 20 70 54 61 62 2e 20 52 65 6d   table pTab. Rem
db00: 6f 76 65 20 74 68 65 20 64 65 6c 65 74 65 64 20  ove the deleted 
db10: 66 6f 72 65 69 67 6e 20 6b 65 79 73 20 66 72 6f  foreign keys fro
db20: 6d 20 74 68 65 20 53 63 68 65 6d 61 2e 66 6b 65  m the Schema.fke
db30: 79 48 61 73 68 0a 2a 2a 20 68 61 73 68 20 74 61  yHash.** hash ta
db40: 62 6c 65 2e 0a 2a 2f 0a 76 6f 69 64 20 73 71 6c  ble..*/.void sql
db50: 69 74 65 33 46 6b 44 65 6c 65 74 65 28 73 71 6c  ite3FkDelete(sql
db60: 69 74 65 33 20 2a 64 62 2c 20 54 61 62 6c 65 20  ite3 *db, Table 
db70: 2a 70 54 61 62 29 7b 0a 20 20 46 4b 65 79 20 2a  *pTab){.  FKey *
db80: 70 46 4b 65 79 3b 20 20 20 20 20 20 20 20 20 20  pFKey;          
db90: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 49 74 65            /* Ite
dba0: 72 61 74 6f 72 20 76 61 72 69 61 62 6c 65 20 2a  rator variable *
dbb0: 2f 0a 20 20 46 4b 65 79 20 2a 70 4e 65 78 74 3b  /.  FKey *pNext;
dbc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
dbd0: 20 20 20 20 2f 2a 20 43 6f 70 79 20 6f 66 20 70      /* Copy of p
dbe0: 46 4b 65 79 2d 3e 70 4e 65 78 74 46 72 6f 6d 20  FKey->pNextFrom 
dbf0: 2a 2f 0a 0a 20 20 61 73 73 65 72 74 28 20 64 62  */..  assert( db
dc00: 3d 3d 30 20 7c 7c 20 49 73 56 69 72 74 75 61 6c  ==0 || IsVirtual
dc10: 28 70 54 61 62 29 0a 20 20 20 20 20 20 20 20 20  (pTab).         
dc20: 7c 7c 20 73 71 6c 69 74 65 33 53 63 68 65 6d 61  || sqlite3Schema
dc30: 4d 75 74 65 78 48 65 6c 64 28 64 62 2c 20 30 2c  MutexHeld(db, 0,
dc40: 20 70 54 61 62 2d 3e 70 53 63 68 65 6d 61 29 20   pTab->pSchema) 
dc50: 29 3b 0a 20 20 66 6f 72 28 70 46 4b 65 79 3d 70  );.  for(pFKey=p
dc60: 54 61 62 2d 3e 70 46 4b 65 79 3b 20 70 46 4b 65  Tab->pFKey; pFKe
dc70: 79 3b 20 70 46 4b 65 79 3d 70 4e 65 78 74 29 7b  y; pFKey=pNext){
dc80: 0a 0a 20 20 20 20 2f 2a 20 52 65 6d 6f 76 65 20  ..    /* Remove 
dc90: 74 68 65 20 46 4b 20 66 72 6f 6d 20 74 68 65 20  the FK from the 
dca0: 66 6b 65 79 48 61 73 68 20 68 61 73 68 20 74 61  fkeyHash hash ta
dcb0: 62 6c 65 2e 20 2a 2f 0a 20 20 20 20 69 66 28 20  ble. */.    if( 
dcc0: 21 64 62 20 7c 7c 20 64 62 2d 3e 70 6e 42 79 74  !db || db->pnByt
dcd0: 65 73 46 72 65 65 64 3d 3d 30 20 29 7b 0a 20 20  esFreed==0 ){.  
dce0: 20 20 20 20 69 66 28 20 70 46 4b 65 79 2d 3e 70      if( pFKey->p
dcf0: 50 72 65 76 54 6f 20 29 7b 0a 20 20 20 20 20 20  PrevTo ){.      
dd00: 20 20 70 46 4b 65 79 2d 3e 70 50 72 65 76 54 6f    pFKey->pPrevTo
dd10: 2d 3e 70 4e 65 78 74 54 6f 20 3d 20 70 46 4b 65  ->pNextTo = pFKe
dd20: 79 2d 3e 70 4e 65 78 74 54 6f 3b 0a 20 20 20 20  y->pNextTo;.    
dd30: 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20    }else{.       
dd40: 20 76 6f 69 64 20 2a 70 20 3d 20 28 76 6f 69 64   void *p = (void
dd50: 20 2a 29 70 46 4b 65 79 2d 3e 70 4e 65 78 74 54   *)pFKey->pNextT
dd60: 6f 3b 0a 20 20 20 20 20 20 20 20 63 6f 6e 73 74  o;.        const
dd70: 20 63 68 61 72 20 2a 7a 20 3d 20 28 70 20 3f 20   char *z = (p ? 
dd80: 70 46 4b 65 79 2d 3e 70 4e 65 78 74 54 6f 2d 3e  pFKey->pNextTo->
dd90: 7a 54 6f 20 3a 20 70 46 4b 65 79 2d 3e 7a 54 6f  zTo : pFKey->zTo
dda0: 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  );.        sqlit
ddb0: 65 33 48 61 73 68 49 6e 73 65 72 74 28 26 70 54  e3HashInsert(&pT
ddc0: 61 62 2d 3e 70 53 63 68 65 6d 61 2d 3e 66 6b 65  ab->pSchema->fke
ddd0: 79 48 61 73 68 2c 20 7a 2c 20 70 29 3b 0a 20 20  yHash, z, p);.  
dde0: 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20      }.      if( 
ddf0: 70 46 4b 65 79 2d 3e 70 4e 65 78 74 54 6f 20 29  pFKey->pNextTo )
de00: 7b 0a 20 20 20 20 20 20 20 20 70 46 4b 65 79 2d  {.        pFKey-
de10: 3e 70 4e 65 78 74 54 6f 2d 3e 70 50 72 65 76 54  >pNextTo->pPrevT
de20: 6f 20 3d 20 70 46 4b 65 79 2d 3e 70 50 72 65 76  o = pFKey->pPrev
de30: 54 6f 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  To;.      }.    
de40: 7d 0a 0a 20 20 20 20 2f 2a 20 45 56 3a 20 52 2d  }..    /* EV: R-
de50: 33 30 33 32 33 2d 32 31 39 31 37 20 45 61 63 68  30323-21917 Each
de60: 20 66 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e   foreign key con
de70: 73 74 72 61 69 6e 74 20 69 6e 20 53 51 4c 69 74  straint in SQLit
de80: 65 20 69 73 0a 20 20 20 20 2a 2a 20 63 6c 61 73  e is.    ** clas
de90: 73 69 66 69 65 64 20 61 73 20 65 69 74 68 65 72  sified as either
dea0: 20 69 6d 6d 65 64 69 61 74 65 20 6f 72 20 64 65   immediate or de
deb0: 66 65 72 72 65 64 2e 0a 20 20 20 20 2a 2f 0a 20  ferred..    */. 
dec0: 20 20 20 61 73 73 65 72 74 28 20 70 46 4b 65 79     assert( pFKey
ded0: 2d 3e 69 73 44 65 66 65 72 72 65 64 3d 3d 30 20  ->isDeferred==0 
dee0: 7c 7c 20 70 46 4b 65 79 2d 3e 69 73 44 65 66 65  || pFKey->isDefe
def0: 72 72 65 64 3d 3d 31 20 29 3b 0a 0a 20 20 20 20  rred==1 );..    
df00: 2f 2a 20 44 65 6c 65 74 65 20 61 6e 79 20 74 72  /* Delete any tr
df10: 69 67 67 65 72 73 20 63 72 65 61 74 65 64 20 74  iggers created t
df20: 6f 20 69 6d 70 6c 65 6d 65 6e 74 20 61 63 74 69  o implement acti
df30: 6f 6e 73 20 66 6f 72 20 74 68 69 73 20 46 4b 2e  ons for this FK.
df40: 20 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51 4c 49   */.#ifndef SQLI
df50: 54 45 5f 4f 4d 49 54 5f 54 52 49 47 47 45 52 0a  TE_OMIT_TRIGGER.
df60: 20 20 20 20 66 6b 54 72 69 67 67 65 72 44 65 6c      fkTriggerDel
df70: 65 74 65 28 64 62 2c 20 70 46 4b 65 79 2d 3e 61  ete(db, pFKey->a
df80: 70 54 72 69 67 67 65 72 5b 30 5d 29 3b 0a 20 20  pTrigger[0]);.  
df90: 20 20 66 6b 54 72 69 67 67 65 72 44 65 6c 65 74    fkTriggerDelet
dfa0: 65 28 64 62 2c 20 70 46 4b 65 79 2d 3e 61 70 54  e(db, pFKey->apT
dfb0: 72 69 67 67 65 72 5b 31 5d 29 3b 0a 23 65 6e 64  rigger[1]);.#end
dfc0: 69 66 0a 0a 20 20 20 20 70 4e 65 78 74 20 3d 20  if..    pNext = 
dfd0: 70 46 4b 65 79 2d 3e 70 4e 65 78 74 46 72 6f 6d  pFKey->pNextFrom
dfe0: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 44 62 46  ;.    sqlite3DbF
dff0: 72 65 65 28 64 62 2c 20 70 46 4b 65 79 29 3b 0a  ree(db, pFKey);.
e000: 20 20 7d 0a 7d 0a 23 65 6e 64 69 66 20 2f 2a 20    }.}.#endif /* 
e010: 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d  ifndef SQLITE_OM
e020: 49 54 5f 46 4f 52 45 49 47 4e 5f 4b 45 59 20 2a  IT_FOREIGN_KEY *
e030: 2f 0a                                            /.