/ Hex Artifact Content
Login

Artifact d35d1c81e7569bdd2b872e91750f7098117d2e8291369f70b7e3d50a0e523dc2:


0000: 23 20 32 30 30 39 20 53 65 70 74 65 6d 62 65 72  # 2009 September
0010: 20 31 35 0a 23 0a 23 20 54 68 65 20 61 75 74 68   15.#.# The auth
0020: 6f 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70  or disclaims cop
0030: 79 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73  yright to this s
0040: 6f 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20  ource code.  In 
0050: 70 6c 61 63 65 20 6f 66 0a 23 20 61 20 6c 65 67  place of.# a leg
0060: 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65 20  al notice, here 
0070: 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a 23  is a blessing:.#
0080: 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20 64 6f  .#    May you do
0090: 20 67 6f 6f 64 20 61 6e 64 20 6e 6f 74 20 65 76   good and not ev
00a0: 69 6c 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75  il..#    May you
00b0: 20 66 69 6e 64 20 66 6f 72 67 69 76 65 6e 65 73   find forgivenes
00c0: 73 20 66 6f 72 20 79 6f 75 72 73 65 6c 66 20 61  s for yourself a
00d0: 6e 64 20 66 6f 72 67 69 76 65 20 6f 74 68 65 72  nd forgive other
00e0: 73 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20  s..#    May you 
00f0: 73 68 61 72 65 20 66 72 65 65 6c 79 2c 20 6e 65  share freely, ne
0100: 76 65 72 20 74 61 6b 69 6e 67 20 6d 6f 72 65 20  ver taking more 
0110: 74 68 61 6e 20 79 6f 75 20 67 69 76 65 2e 0a 23  than you give..#
0120: 0a 23 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 2a 2a 2a 2a 2a 2a 2a 2a 0a 23 20 54 68 69 73  *********.# This
0170: 20 66 69 6c 65 20 69 6d 70 6c 65 6d 65 6e 74 73   file implements
0180: 20 72 65 67 72 65 73 73 69 6f 6e 20 74 65 73 74   regression test
0190: 73 20 66 6f 72 20 53 51 4c 69 74 65 20 6c 69 62  s for SQLite lib
01a0: 72 61 72 79 2e 0a 23 0a 23 20 54 68 69 73 20 66  rary..#.# This f
01b0: 69 6c 65 20 69 6d 70 6c 65 6d 65 6e 74 73 20 74  ile implements t
01c0: 65 73 74 73 20 66 6f 72 20 66 6f 72 65 69 67 6e  ests for foreign
01d0: 20 6b 65 79 73 2e 0a 23 0a 0a 73 65 74 20 74 65   keys..#..set te
01e0: 73 74 64 69 72 20 5b 66 69 6c 65 20 64 69 72 6e  stdir [file dirn
01f0: 61 6d 65 20 24 61 72 67 76 30 5d 0a 73 6f 75 72  ame $argv0].sour
0200: 63 65 20 24 74 65 73 74 64 69 72 2f 74 65 73 74  ce $testdir/test
0210: 65 72 2e 74 63 6c 0a 0a 69 66 63 61 70 61 62 6c  er.tcl..ifcapabl
0220: 65 20 7b 21 66 6f 72 65 69 67 6e 6b 65 79 7c 7c  e {!foreignkey||
0230: 21 74 72 69 67 67 65 72 7d 20 7b 0a 20 20 66 69  !trigger} {.  fi
0240: 6e 69 73 68 5f 74 65 73 74 0a 20 20 72 65 74 75  nish_test.  retu
0250: 72 6e 0a 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d  rn.}..#---------
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 2d 2d 2d 2d 2d 2d 2d  ----------------
0280: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0290: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
02a0: 0a 23 20 54 65 73 74 20 73 74 72 75 63 74 75 72  .# Test structur
02b0: 65 3a 0a 23 0a 23 20 66 6b 65 79 32 2d 31 2e 2a  e:.#.# fkey2-1.*
02c0: 3a 20 53 69 6d 70 6c 65 20 74 65 73 74 73 20 74  : Simple tests t
02d0: 6f 20 63 68 65 63 6b 20 74 68 61 74 20 69 6d 6d  o check that imm
02e0: 65 64 69 61 74 65 20 61 6e 64 20 64 65 66 65 72  ediate and defer
02f0: 72 65 64 20 66 6f 72 65 69 67 6e 20 6b 65 79 20  red foreign key 
0300: 0a 23 20 20 20 20 20 20 20 20 20 20 20 20 63 6f  .#            co
0310: 6e 73 74 72 61 69 6e 74 73 20 77 6f 72 6b 20 77  nstraints work w
0320: 68 65 6e 20 6e 6f 74 20 69 6e 73 69 64 65 20 61  hen not inside a
0330: 20 74 72 61 6e 73 61 63 74 69 6f 6e 2e 0a 23 20   transaction..# 
0340: 20 20 20 20 20 20 20 20 20 20 20 0a 23 20 66 6b             .# fk
0350: 65 79 32 2d 32 2e 2a 3a 20 54 65 73 74 73 20 74  ey2-2.*: Tests t
0360: 6f 20 76 65 72 69 66 79 20 74 68 61 74 20 64 65  o verify that de
0370: 66 65 72 72 65 64 20 66 6f 72 65 69 67 6e 20 6b  ferred foreign k
0380: 65 79 73 20 77 6f 72 6b 20 69 6e 73 69 64 65 0a  eys work inside.
0390: 23 20 20 20 20 20 20 20 20 20 20 20 20 65 78 70  #            exp
03a0: 6c 69 63 69 74 20 74 72 61 6e 73 61 63 74 69 6f  licit transactio
03b0: 6e 73 20 28 69 2e 65 20 74 68 61 74 20 70 72 6f  ns (i.e that pro
03c0: 63 65 73 73 69 6e 67 20 72 65 61 6c 6c 79 20 69  cessing really i
03d0: 73 20 64 65 66 65 72 72 65 64 29 2e 0a 23 0a 23  s deferred)..#.#
03e0: 20 66 6b 65 79 32 2d 33 2e 2a 3a 20 54 65 73 74   fkey2-3.*: Test
03f0: 73 20 74 68 61 74 20 61 20 73 74 61 74 65 6d 65  s that a stateme
0400: 6e 74 20 74 72 61 6e 73 61 63 74 69 6f 6e 20 69  nt transaction i
0410: 73 20 72 6f 6c 6c 65 64 20 62 61 63 6b 20 69 66  s rolled back if
0420: 20 61 6e 0a 23 20 20 20 20 20 20 20 20 20 20 20   an.#           
0430: 20 69 6d 6d 65 64 69 61 74 65 20 66 6f 72 65 69   immediate forei
0440: 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e  gn key constrain
0450: 74 20 69 73 20 76 69 6f 6c 61 74 65 64 2e 0a 23  t is violated..#
0460: 0a 23 20 66 6b 65 79 32 2d 34 2e 2a 3a 20 54 65  .# fkey2-4.*: Te
0470: 73 74 20 74 68 61 74 20 46 4b 20 61 63 74 69 6f  st that FK actio
0480: 6e 73 20 6d 61 79 20 72 65 63 75 72 73 65 20 65  ns may recurse e
0490: 76 65 6e 20 77 68 65 6e 20 72 65 63 75 72 73 69  ven when recursi
04a0: 76 65 20 74 72 69 67 67 65 72 73 0a 23 20 20 20  ve triggers.#   
04b0: 20 20 20 20 20 20 20 20 20 61 72 65 20 64 69 73           are dis
04c0: 61 62 6c 65 64 2e 0a 23 0a 23 20 66 6b 65 79 32  abled..#.# fkey2
04d0: 2d 35 2e 2a 3a 20 43 68 65 63 6b 20 74 68 61 74  -5.*: Check that
04e0: 20 69 66 20 66 6f 72 65 69 67 6e 2d 6b 65 79 73   if foreign-keys
04f0: 20 61 72 65 20 65 6e 61 62 6c 65 64 2c 20 69 74   are enabled, it
0500: 20 69 73 20 6e 6f 74 20 70 6f 73 73 69 62 6c 65   is not possible
0510: 0a 23 20 20 20 20 20 20 20 20 20 20 20 20 74 6f  .#            to
0520: 20 77 72 69 74 65 20 74 6f 20 61 6e 20 46 4b 20   write to an FK 
0530: 63 6f 6c 75 6d 6e 20 75 73 69 6e 67 20 74 68 65  column using the
0540: 20 69 6e 63 72 65 6d 65 6e 74 61 6c 20 62 6c 6f   incremental blo
0550: 62 20 41 50 49 2e 0a 23 0a 23 20 66 6b 65 79 32  b API..#.# fkey2
0560: 2d 36 2e 2a 3a 20 54 65 73 74 20 74 68 61 74 20  -6.*: Test that 
0570: 46 4b 20 70 72 6f 63 65 73 73 69 6e 67 20 69 73  FK processing is
0580: 20 61 75 74 6f 6d 61 74 69 63 61 6c 6c 79 20 64   automatically d
0590: 69 73 61 62 6c 65 64 20 77 68 65 6e 20 0a 23 20  isabled when .# 
05a0: 20 20 20 20 20 20 20 20 20 20 20 72 75 6e 6e 69             runni
05b0: 6e 67 20 56 41 43 55 55 4d 2e 0a 23 0a 23 20 66  ng VACUUM..#.# f
05c0: 6b 65 79 32 2d 37 2e 2a 3a 20 54 65 73 74 20 75  key2-7.*: Test u
05d0: 73 69 6e 67 20 61 6e 20 49 50 4b 20 61 73 20 74  sing an IPK as t
05e0: 68 65 20 6b 65 79 20 69 6e 20 74 68 65 20 63 68  he key in the ch
05f0: 69 6c 64 20 28 72 65 66 65 72 65 6e 63 69 6e 67  ild (referencing
0600: 29 20 74 61 62 6c 65 2e 0a 23 0a 23 20 66 6b 65  ) table..#.# fke
0610: 79 32 2d 38 2e 2a 3a 20 54 65 73 74 20 74 68 61  y2-8.*: Test tha
0620: 74 20 65 6e 61 62 6c 69 6e 67 2f 64 69 73 61 62  t enabling/disab
0630: 6c 69 6e 67 20 66 6f 72 65 69 67 6e 20 6b 65 79  ling foreign key
0640: 20 73 75 70 70 6f 72 74 20 77 68 69 6c 65 20 61   support while a
0650: 20 0a 23 20 20 20 20 20 20 20 20 20 20 20 20 74   .#            t
0660: 72 61 6e 73 61 63 74 69 6f 6e 20 69 73 20 61 63  ransaction is ac
0670: 74 69 76 65 20 69 73 20 6e 6f 74 20 70 6f 73 73  tive is not poss
0680: 69 62 6c 65 2e 0a 23 0a 23 20 66 6b 65 79 32 2d  ible..#.# fkey2-
0690: 39 2e 2a 3a 20 54 65 73 74 20 53 45 54 20 44 45  9.*: Test SET DE
06a0: 46 41 55 4c 54 20 61 63 74 69 6f 6e 73 2e 0a 23  FAULT actions..#
06b0: 0a 23 20 66 6b 65 79 32 2d 31 30 2e 2a 3a 20 54  .# fkey2-10.*: T
06c0: 65 73 74 20 65 72 72 6f 72 73 2e 0a 23 0a 23 20  est errors..#.# 
06d0: 66 6b 65 79 32 2d 31 31 2e 2a 3a 20 54 65 73 74  fkey2-11.*: Test
06e0: 20 43 41 53 43 41 44 45 20 61 63 74 69 6f 6e 73   CASCADE actions
06f0: 2e 0a 23 0a 23 20 66 6b 65 79 32 2d 31 32 2e 2a  ..#.# fkey2-12.*
0700: 3a 20 54 65 73 74 20 52 45 53 54 52 49 43 54 20  : Test RESTRICT 
0710: 61 63 74 69 6f 6e 73 2e 0a 23 0a 23 20 66 6b 65  actions..#.# fke
0720: 79 32 2d 31 33 2e 2a 3a 20 54 65 73 74 20 74 68  y2-13.*: Test th
0730: 61 74 20 46 4b 20 70 72 6f 63 65 73 73 69 6e 67  at FK processing
0740: 20 69 73 20 70 65 72 66 6f 72 6d 65 64 20 77 68   is performed wh
0750: 65 6e 20 61 20 72 6f 77 20 69 73 20 52 45 50 4c  en a row is REPL
0760: 41 43 45 44 20 62 79 0a 23 20 20 20 20 20 20 20  ACED by.#       
0770: 20 20 20 20 20 20 61 6e 20 55 50 44 41 54 45 20        an UPDATE 
0780: 6f 72 20 49 4e 53 45 52 54 20 73 74 61 74 65 6d  or INSERT statem
0790: 65 6e 74 2e 0a 23 0a 23 20 66 6b 65 79 32 2d 31  ent..#.# fkey2-1
07a0: 34 2e 2a 3a 20 54 65 73 74 20 74 68 65 20 41 4c  4.*: Test the AL
07b0: 54 45 52 20 54 41 42 4c 45 20 61 6e 64 20 44 52  TER TABLE and DR
07c0: 4f 50 20 54 41 42 4c 45 20 63 6f 6d 6d 61 6e 64  OP TABLE command
07d0: 73 2e 0a 23 0a 23 20 66 6b 65 79 32 2d 31 35 2e  s..#.# fkey2-15.
07e0: 2a 3a 20 54 65 73 74 20 74 68 61 74 20 69 66 20  *: Test that if 
07f0: 74 68 65 72 65 20 61 72 65 20 6e 6f 20 28 6b 6e  there are no (kn
0800: 6f 77 6e 29 20 6f 75 74 73 74 61 6e 64 69 6e 67  own) outstanding
0810: 20 66 6f 72 65 69 67 6e 20 6b 65 79 20 0a 23 20   foreign key .# 
0820: 20 20 20 20 20 20 20 20 20 20 20 20 63 6f 6e 73              cons
0830: 74 72 61 69 6e 74 20 76 69 6f 6c 61 74 69 6f 6e  traint violation
0840: 73 20 69 6e 20 74 68 65 20 64 61 74 61 62 61 73  s in the databas
0850: 65 2c 20 69 6e 73 65 72 74 69 6e 67 20 69 6e 74  e, inserting int
0860: 6f 20 61 20 70 61 72 65 6e 74 0a 23 20 20 20 20  o a parent.#    
0870: 20 20 20 20 20 20 20 20 20 74 61 62 6c 65 20 6f           table o
0880: 72 20 64 65 6c 65 74 69 6e 67 20 66 72 6f 6d 20  r deleting from 
0890: 61 20 63 68 69 6c 64 20 74 61 62 6c 65 20 64 6f  a child table do
08a0: 65 73 20 6e 6f 74 20 63 61 75 73 65 20 53 51 4c  es not cause SQL
08b0: 69 74 65 0a 23 20 20 20 20 20 20 20 20 20 20 20  ite.#           
08c0: 20 20 74 6f 20 63 68 65 63 6b 20 69 66 20 74 68    to check if th
08d0: 69 73 20 68 61 73 20 72 65 70 61 69 72 65 64 20  is has repaired 
08e0: 61 6e 20 6f 75 74 73 74 61 6e 64 69 6e 67 20 76  an outstanding v
08f0: 69 6f 6c 61 74 69 6f 6e 2e 0a 23 0a 23 20 66 6b  iolation..#.# fk
0900: 65 79 32 2d 31 36 2e 2a 3a 20 54 65 73 74 20 74  ey2-16.*: Test t
0910: 68 61 74 20 72 6f 77 73 20 74 68 61 74 20 72 65  hat rows that re
0920: 66 65 72 20 74 6f 20 74 68 65 6d 73 65 6c 76 65  fer to themselve
0930: 73 20 6d 61 79 20 62 65 20 69 6e 73 65 72 74 65  s may be inserte
0940: 64 2c 20 0a 23 20 20 20 20 20 20 20 20 20 20 20  d, .#           
0950: 20 20 75 70 64 61 74 65 64 20 61 6e 64 20 64 65    updated and de
0960: 6c 65 74 65 64 2e 0a 23 0a 23 20 66 6b 65 79 32  leted..#.# fkey2
0970: 2d 31 37 2e 2a 3a 20 54 65 73 74 20 74 68 61 74  -17.*: Test that
0980: 20 74 68 65 20 22 63 6f 75 6e 74 5f 63 68 61 6e   the "count_chan
0990: 67 65 73 22 20 70 72 61 67 6d 61 20 64 6f 65 73  ges" pragma does
09a0: 20 6e 6f 74 20 69 6e 74 65 72 66 65 72 65 20 77   not interfere w
09b0: 69 74 68 0a 23 20 20 20 20 20 20 20 20 20 20 20  ith.#           
09c0: 20 20 46 4b 20 63 6f 6e 73 74 72 61 69 6e 74 20    FK constraint 
09d0: 70 72 6f 63 65 73 73 69 6e 67 2e 0a 23 20 0a 23  processing..# .#
09e0: 20 66 6b 65 79 32 2d 31 38 2e 2a 3a 20 54 65 73   fkey2-18.*: Tes
09f0: 74 20 74 68 61 74 20 74 68 65 20 61 75 74 68 6f  t that the autho
0a00: 72 69 7a 61 74 69 6f 6e 20 63 61 6c 6c 62 61 63  rization callbac
0a10: 6b 20 69 73 20 69 6e 76 6f 6b 65 64 20 77 68 65  k is invoked whe
0a20: 6e 20 70 72 6f 63 65 73 73 69 6e 67 0a 23 20 20  n processing.#  
0a30: 20 20 20 20 20 20 20 20 20 20 20 46 4b 20 63 6f             FK co
0a40: 6e 73 74 72 61 69 6e 74 73 2e 0a 23 0a 23 20 66  nstraints..#.# f
0a50: 6b 65 79 32 2d 32 30 2e 2a 3a 20 54 65 73 74 20  key2-20.*: Test 
0a60: 74 68 61 74 20 4f 4e 20 43 4f 4e 46 4c 49 43 54  that ON CONFLICT
0a70: 20 63 6c 61 75 73 65 73 20 73 70 65 63 69 66 69   clauses specifi
0a80: 65 64 20 61 73 20 70 61 72 74 20 6f 66 20 73 74  ed as part of st
0a90: 61 74 65 6d 65 6e 74 73 0a 23 20 20 20 20 20 20  atements.#      
0aa0: 20 20 20 20 20 20 20 64 6f 20 6e 6f 74 20 61 66         do not af
0ab0: 66 65 63 74 20 74 68 65 20 6f 70 65 72 61 74 69  fect the operati
0ac0: 6f 6e 20 6f 66 20 46 4b 20 63 6f 6e 73 74 72 61  on of FK constra
0ad0: 69 6e 74 73 2e 0a 23 0a 23 20 66 6b 65 79 32 2d  ints..#.# fkey2-
0ae0: 67 65 6e 66 6b 65 79 2e 2a 3a 20 54 65 73 74 73  genfkey.*: Tests
0af0: 20 74 68 61 74 20 77 65 72 65 20 75 73 65 64 20   that were used 
0b00: 77 69 74 68 20 74 68 65 20 73 68 65 6c 6c 20 74  with the shell t
0b10: 6f 6f 6c 20 2e 67 65 6e 66 6b 65 79 0a 23 20 20  ool .genfkey.#  
0b20: 20 20 20 20 20 20 20 20 20 20 63 6f 6d 6d 61 6e            comman
0b30: 64 2e 20 52 65 63 79 63 6c 65 64 20 74 6f 20 74  d. Recycled to t
0b40: 65 73 74 20 74 68 65 20 62 75 69 6c 74 2d 69 6e  est the built-in
0b50: 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 2e   implementation.
0b60: 0a 23 0a 23 20 66 6b 65 79 32 2d 64 64 30 38 65  .#.# fkey2-dd08e
0b70: 35 2e 2a 3a 20 20 54 65 73 74 73 20 74 6f 20 76  5.*:  Tests to v
0b80: 65 72 69 66 79 20 74 68 61 74 20 74 69 63 6b 65  erify that ticke
0b90: 74 20 64 64 30 38 65 35 61 39 38 38 64 30 30 64  t dd08e5a988d00d
0ba0: 65 63 63 34 61 35 34 33 64 61 61 38 64 0a 23 20  ecc4a543daa8d.# 
0bb0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0bc0: 20 68 61 73 20 62 65 65 6e 20 66 69 78 65 64 2e   has been fixed.
0bd0: 0a 23 0a 0a 0a 65 78 65 63 73 71 6c 20 7b 20 50  .#...execsql { P
0be0: 52 41 47 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65  RAGMA foreign_ke
0bf0: 79 73 20 3d 20 6f 6e 20 7d 0a 0a 73 65 74 20 46  ys = on }..set F
0c00: 6b 65 79 53 69 6d 70 6c 65 53 63 68 65 6d 61 20  keySimpleSchema 
0c10: 7b 0a 20 20 50 52 41 47 4d 41 20 66 6f 72 65 69  {.  PRAGMA forei
0c20: 67 6e 5f 6b 65 79 73 20 3d 20 6f 6e 3b 0a 20 20  gn_keys = on;.  
0c30: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28  CREATE TABLE t1(
0c40: 61 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62  a PRIMARY KEY, b
0c50: 29 3b 0a 20 20 43 52 45 41 54 45 20 54 41 42 4c  );.  CREATE TABL
0c60: 45 20 74 32 28 63 20 52 45 46 45 52 45 4e 43 45  E t2(c REFERENCE
0c70: 53 20 74 31 28 61 29 20 2f 44 2f 20 2c 20 64 29  S t1(a) /D/ , d)
0c80: 3b 0a 0a 20 20 43 52 45 41 54 45 20 54 41 42 4c  ;..  CREATE TABL
0c90: 45 20 74 33 28 61 20 50 52 49 4d 41 52 59 20 4b  E t3(a PRIMARY K
0ca0: 45 59 2c 20 62 29 3b 0a 20 20 43 52 45 41 54 45  EY, b);.  CREATE
0cb0: 20 54 41 42 4c 45 20 74 34 28 63 20 52 45 46 45   TABLE t4(c REFE
0cc0: 52 45 4e 43 45 53 20 74 33 20 2f 44 2f 2c 20 64  RENCES t3 /D/, d
0cd0: 29 3b 0a 0a 20 20 43 52 45 41 54 45 20 54 41 42  );..  CREATE TAB
0ce0: 4c 45 20 74 37 28 61 2c 20 62 20 49 4e 54 45 47  LE t7(a, b INTEG
0cf0: 45 52 20 50 52 49 4d 41 52 59 20 4b 45 59 29 3b  ER PRIMARY KEY);
0d00: 0a 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20  .  CREATE TABLE 
0d10: 74 38 28 63 20 52 45 46 45 52 45 4e 43 45 53 20  t8(c REFERENCES 
0d20: 74 37 20 2f 44 2f 2c 20 64 29 3b 0a 0a 20 20 43  t7 /D/, d);..  C
0d30: 52 45 41 54 45 20 54 41 42 4c 45 20 74 39 28 61  REATE TABLE t9(a
0d40: 20 52 45 46 45 52 45 4e 43 45 53 20 6e 6f 73 75   REFERENCES nosu
0d50: 63 68 74 61 62 6c 65 2c 20 62 29 3b 0a 20 20 43  chtable, b);.  C
0d60: 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 30 28  REATE TABLE t10(
0d70: 61 20 52 45 46 45 52 45 4e 43 45 53 20 74 39 28  a REFERENCES t9(
0d80: 63 29 20 2f 44 2f 2c 20 62 29 3b 0a 7d 0a 0a 0a  c) /D/, b);.}...
0d90: 73 65 74 20 46 6b 65 79 53 69 6d 70 6c 65 54 65  set FkeySimpleTe
0da0: 73 74 73 20 7b 0a 20 20 31 2e 31 20 20 22 49 4e  sts {.  1.1  "IN
0db0: 53 45 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c  SERT INTO t2 VAL
0dc0: 55 45 53 28 31 2c 20 33 29 22 20 20 20 20 20 20  UES(1, 3)"      
0dd0: 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20  {1 {FOREIGN KEY 
0de0: 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65  constraint faile
0df0: 64 7d 7d 0a 20 20 31 2e 32 20 20 22 49 4e 53 45  d}}.  1.2  "INSE
0e00: 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45  RT INTO t1 VALUE
0e10: 53 28 31 2c 20 32 29 22 20 20 20 20 20 20 7b 30  S(1, 2)"      {0
0e20: 20 7b 7d 7d 0a 20 20 31 2e 33 20 20 22 49 4e 53   {}}.  1.3  "INS
0e30: 45 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55  ERT INTO t2 VALU
0e40: 45 53 28 31 2c 20 33 29 22 20 20 20 20 20 20 7b  ES(1, 3)"      {
0e50: 30 20 7b 7d 7d 0a 20 20 31 2e 34 20 20 22 49 4e  0 {}}.  1.4  "IN
0e60: 53 45 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c  SERT INTO t2 VAL
0e70: 55 45 53 28 32 2c 20 34 29 22 20 20 20 20 20 20  UES(2, 4)"      
0e80: 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20  {1 {FOREIGN KEY 
0e90: 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65  constraint faile
0ea0: 64 7d 7d 0a 20 20 31 2e 35 20 20 22 49 4e 53 45  d}}.  1.5  "INSE
0eb0: 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55 45  RT INTO t2 VALUE
0ec0: 53 28 4e 55 4c 4c 2c 20 34 29 22 20 20 20 7b 30  S(NULL, 4)"   {0
0ed0: 20 7b 7d 7d 0a 20 20 31 2e 36 20 20 22 55 50 44   {}}.  1.6  "UPD
0ee0: 41 54 45 20 74 32 20 53 45 54 20 63 3d 32 20 57  ATE t2 SET c=2 W
0ef0: 48 45 52 45 20 64 3d 34 22 20 20 20 20 20 20 7b  HERE d=4"      {
0f00: 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20 63  1 {FOREIGN KEY c
0f10: 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64  onstraint failed
0f20: 7d 7d 0a 20 20 31 2e 37 20 20 22 55 50 44 41 54  }}.  1.7  "UPDAT
0f30: 45 20 74 32 20 53 45 54 20 63 3d 31 20 57 48 45  E t2 SET c=1 WHE
0f40: 52 45 20 64 3d 34 22 20 20 20 20 20 20 7b 30 20  RE d=4"      {0 
0f50: 7b 7d 7d 0a 20 20 31 2e 39 20 20 22 55 50 44 41  {}}.  1.9  "UPDA
0f60: 54 45 20 74 32 20 53 45 54 20 63 3d 31 20 57 48  TE t2 SET c=1 WH
0f70: 45 52 45 20 64 3d 34 22 20 20 20 20 20 20 7b 30  ERE d=4"      {0
0f80: 20 7b 7d 7d 0a 20 20 31 2e 31 30 20 22 55 50 44   {}}.  1.10 "UPD
0f90: 41 54 45 20 74 32 20 53 45 54 20 63 3d 4e 55 4c  ATE t2 SET c=NUL
0fa0: 4c 20 57 48 45 52 45 20 64 3d 34 22 20 20 20 7b  L WHERE d=4"   {
0fb0: 30 20 7b 7d 7d 0a 20 20 31 2e 31 31 20 22 44 45  0 {}}.  1.11 "DE
0fc0: 4c 45 54 45 20 46 52 4f 4d 20 74 31 20 57 48 45  LETE FROM t1 WHE
0fd0: 52 45 20 61 3d 31 22 20 20 20 20 20 20 20 20 20  RE a=1"         
0fe0: 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20  {1 {FOREIGN KEY 
0ff0: 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65  constraint faile
1000: 64 7d 7d 0a 20 20 31 2e 31 32 20 22 55 50 44 41  d}}.  1.12 "UPDA
1010: 54 45 20 74 31 20 53 45 54 20 61 20 3d 20 32 22  TE t1 SET a = 2"
1020: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 31                {1
1030: 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f   {FOREIGN KEY co
1040: 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d  nstraint failed}
1050: 7d 0a 20 20 31 2e 31 33 20 22 55 50 44 41 54 45  }.  1.13 "UPDATE
1060: 20 74 31 20 53 45 54 20 61 20 3d 20 31 22 20 20   t1 SET a = 1"  
1070: 20 20 20 20 20 20 20 20 20 20 20 20 7b 30 20 7b              {0 {
1080: 7d 7d 0a 0a 20 20 32 2e 31 20 20 22 49 4e 53 45  }}..  2.1  "INSE
1090: 52 54 20 49 4e 54 4f 20 74 34 20 56 41 4c 55 45  RT INTO t4 VALUE
10a0: 53 28 31 2c 20 33 29 22 20 20 20 20 20 20 7b 31  S(1, 3)"      {1
10b0: 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f   {FOREIGN KEY co
10c0: 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d  nstraint failed}
10d0: 7d 0a 20 20 32 2e 32 20 20 22 49 4e 53 45 52 54  }.  2.2  "INSERT
10e0: 20 49 4e 54 4f 20 74 33 20 56 41 4c 55 45 53 28   INTO t3 VALUES(
10f0: 31 2c 20 32 29 22 20 20 20 20 20 20 7b 30 20 7b  1, 2)"      {0 {
1100: 7d 7d 0a 20 20 32 2e 33 20 20 22 49 4e 53 45 52  }}.  2.3  "INSER
1110: 54 20 49 4e 54 4f 20 74 34 20 56 41 4c 55 45 53  T INTO t4 VALUES
1120: 28 31 2c 20 33 29 22 20 20 20 20 20 20 7b 30 20  (1, 3)"      {0 
1130: 7b 7d 7d 0a 0a 20 20 34 2e 31 20 20 22 49 4e 53  {}}..  4.1  "INS
1140: 45 52 54 20 49 4e 54 4f 20 74 38 20 56 41 4c 55  ERT INTO t8 VALU
1150: 45 53 28 31 2c 20 33 29 22 20 20 20 20 20 20 7b  ES(1, 3)"      {
1160: 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20 63  1 {FOREIGN KEY c
1170: 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64  onstraint failed
1180: 7d 7d 0a 20 20 34 2e 32 20 20 22 49 4e 53 45 52  }}.  4.2  "INSER
1190: 54 20 49 4e 54 4f 20 74 37 20 56 41 4c 55 45 53  T INTO t7 VALUES
11a0: 28 32 2c 20 31 29 22 20 20 20 20 20 20 7b 30 20  (2, 1)"      {0 
11b0: 7b 7d 7d 0a 20 20 34 2e 33 20 20 22 49 4e 53 45  {}}.  4.3  "INSE
11c0: 52 54 20 49 4e 54 4f 20 74 38 20 56 41 4c 55 45  RT INTO t8 VALUE
11d0: 53 28 31 2c 20 33 29 22 20 20 20 20 20 20 7b 30  S(1, 3)"      {0
11e0: 20 7b 7d 7d 0a 20 20 34 2e 34 20 20 22 49 4e 53   {}}.  4.4  "INS
11f0: 45 52 54 20 49 4e 54 4f 20 74 38 20 56 41 4c 55  ERT INTO t8 VALU
1200: 45 53 28 32 2c 20 34 29 22 20 20 20 20 20 20 7b  ES(2, 4)"      {
1210: 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20 63  1 {FOREIGN KEY c
1220: 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64  onstraint failed
1230: 7d 7d 0a 20 20 34 2e 35 20 20 22 49 4e 53 45 52  }}.  4.5  "INSER
1240: 54 20 49 4e 54 4f 20 74 38 20 56 41 4c 55 45 53  T INTO t8 VALUES
1250: 28 4e 55 4c 4c 2c 20 34 29 22 20 20 20 7b 30 20  (NULL, 4)"   {0 
1260: 7b 7d 7d 0a 20 20 34 2e 36 20 20 22 55 50 44 41  {}}.  4.6  "UPDA
1270: 54 45 20 74 38 20 53 45 54 20 63 3d 32 20 57 48  TE t8 SET c=2 WH
1280: 45 52 45 20 64 3d 34 22 20 20 20 20 20 20 7b 31  ERE d=4"      {1
1290: 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f   {FOREIGN KEY co
12a0: 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d  nstraint failed}
12b0: 7d 0a 20 20 34 2e 37 20 20 22 55 50 44 41 54 45  }.  4.7  "UPDATE
12c0: 20 74 38 20 53 45 54 20 63 3d 31 20 57 48 45 52   t8 SET c=1 WHER
12d0: 45 20 64 3d 34 22 20 20 20 20 20 20 7b 30 20 7b  E d=4"      {0 {
12e0: 7d 7d 0a 20 20 34 2e 39 20 20 22 55 50 44 41 54  }}.  4.9  "UPDAT
12f0: 45 20 74 38 20 53 45 54 20 63 3d 31 20 57 48 45  E t8 SET c=1 WHE
1300: 52 45 20 64 3d 34 22 20 20 20 20 20 20 7b 30 20  RE d=4"      {0 
1310: 7b 7d 7d 0a 20 20 34 2e 31 30 20 22 55 50 44 41  {}}.  4.10 "UPDA
1320: 54 45 20 74 38 20 53 45 54 20 63 3d 4e 55 4c 4c  TE t8 SET c=NULL
1330: 20 57 48 45 52 45 20 64 3d 34 22 20 20 20 7b 30   WHERE d=4"   {0
1340: 20 7b 7d 7d 0a 20 20 34 2e 31 31 20 22 44 45 4c   {}}.  4.11 "DEL
1350: 45 54 45 20 46 52 4f 4d 20 74 37 20 57 48 45 52  ETE FROM t7 WHER
1360: 45 20 62 3d 31 22 20 20 20 20 20 20 20 20 20 7b  E b=1"         {
1370: 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20 63  1 {FOREIGN KEY c
1380: 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64  onstraint failed
1390: 7d 7d 0a 20 20 34 2e 31 32 20 22 55 50 44 41 54  }}.  4.12 "UPDAT
13a0: 45 20 74 37 20 53 45 54 20 62 20 3d 20 32 22 20  E t7 SET b = 2" 
13b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 31 20               {1 
13c0: 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f 6e  {FOREIGN KEY con
13d0: 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d  straint failed}}
13e0: 0a 20 20 34 2e 31 33 20 22 55 50 44 41 54 45 20  .  4.13 "UPDATE 
13f0: 74 37 20 53 45 54 20 62 20 3d 20 31 22 20 20 20  t7 SET b = 1"   
1400: 20 20 20 20 20 20 20 20 20 20 20 7b 30 20 7b 7d             {0 {}
1410: 7d 0a 20 20 34 2e 31 34 20 22 49 4e 53 45 52 54  }.  4.14 "INSERT
1420: 20 49 4e 54 4f 20 74 38 20 56 41 4c 55 45 53 28   INTO t8 VALUES(
1430: 27 61 27 2c 20 27 62 27 29 22 20 20 7b 31 20 7b  'a', 'b')"  {1 {
1440: 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73  FOREIGN KEY cons
1450: 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a  traint failed}}.
1460: 20 20 34 2e 31 35 20 22 55 50 44 41 54 45 20 74    4.15 "UPDATE t
1470: 37 20 53 45 54 20 62 20 3d 20 35 22 20 20 20 20  7 SET b = 5"    
1480: 20 20 20 20 20 20 20 20 20 20 7b 31 20 7b 46 4f            {1 {FO
1490: 52 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73 74 72  REIGN KEY constr
14a0: 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 20 20  aint failed}}.  
14b0: 34 2e 31 36 20 22 55 50 44 41 54 45 20 74 37 20  4.16 "UPDATE t7 
14c0: 53 45 54 20 72 6f 77 69 64 20 3d 20 35 22 20 20  SET rowid = 5"  
14d0: 20 20 20 20 20 20 20 20 7b 31 20 7b 46 4f 52 45          {1 {FORE
14e0: 49 47 4e 20 4b 45 59 20 63 6f 6e 73 74 72 61 69  IGN KEY constrai
14f0: 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 20 20 34 2e  nt failed}}.  4.
1500: 31 37 20 22 55 50 44 41 54 45 20 74 37 20 53 45  17 "UPDATE t7 SE
1510: 54 20 61 20 3d 20 31 30 22 20 20 20 20 20 20 20  T a = 10"       
1520: 20 20 20 20 20 20 7b 30 20 7b 7d 7d 0a 0a 20 20        {0 {}}..  
1530: 35 2e 31 20 20 22 49 4e 53 45 52 54 20 49 4e 54  5.1  "INSERT INT
1540: 4f 20 74 39 20 56 41 4c 55 45 53 28 31 2c 20 33  O t9 VALUES(1, 3
1550: 29 22 20 20 20 20 20 20 7b 31 20 7b 6e 6f 20 73  )"      {1 {no s
1560: 75 63 68 20 74 61 62 6c 65 3a 20 6d 61 69 6e 2e  uch table: main.
1570: 6e 6f 73 75 63 68 74 61 62 6c 65 7d 7d 0a 20 20  nosuchtable}}.  
1580: 35 2e 32 20 20 22 49 4e 53 45 52 54 20 49 4e 54  5.2  "INSERT INT
1590: 4f 20 74 31 30 20 56 41 4c 55 45 53 28 31 2c 20  O t10 VALUES(1, 
15a0: 33 29 22 20 20 0a 20 20 20 20 20 20 20 20 20 20  3)"  .          
15b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
15c0: 20 20 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65    {1 {foreign ke
15d0: 79 20 6d 69 73 6d 61 74 63 68 20 2d 20 22 74 31  y mismatch - "t1
15e0: 30 22 20 72 65 66 65 72 65 6e 63 69 6e 67 20 22  0" referencing "
15f0: 74 39 22 7d 7d 0a 7d 0a 0a 64 6f 5f 74 65 73 74  t9"}}.}..do_test
1600: 20 66 6b 65 79 32 2d 31 2e 31 2e 30 20 7b 0a 20   fkey2-1.1.0 {. 
1610: 20 65 78 65 63 73 71 6c 20 5b 73 74 72 69 6e 67   execsql [string
1620: 20 6d 61 70 20 7b 2f 44 2f 20 7b 7d 7d 20 24 46   map {/D/ {}} $F
1630: 6b 65 79 53 69 6d 70 6c 65 53 63 68 65 6d 61 5d  keySimpleSchema]
1640: 0a 7d 20 7b 7d 0a 66 6f 72 65 61 63 68 20 7b 74  .} {}.foreach {t
1650: 6e 20 7a 53 71 6c 20 72 65 73 7d 20 24 46 6b 65  n zSql res} $Fke
1660: 79 53 69 6d 70 6c 65 54 65 73 74 73 20 7b 0a 20  ySimpleTests {. 
1670: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31   do_test fkey2-1
1680: 2e 31 2e 24 74 6e 2e 31 20 7b 20 63 61 74 63 68  .1.$tn.1 { catch
1690: 73 71 6c 20 24 7a 53 71 6c 20 7d 20 24 72 65 73  sql $zSql } $res
16a0: 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  .  do_test fkey2
16b0: 2d 31 2e 31 2e 24 74 6e 2e 32 20 7b 20 65 78 65  -1.1.$tn.2 { exe
16c0: 63 73 71 6c 20 7b 50 52 41 47 4d 41 20 66 6f 72  csql {PRAGMA for
16d0: 65 69 67 6e 5f 6b 65 79 5f 63 68 65 63 6b 28 74  eign_key_check(t
16e0: 31 29 7d 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74 65  1)} } {}.  do_te
16f0: 73 74 20 66 6b 65 79 32 2d 31 2e 31 2e 24 74 6e  st fkey2-1.1.$tn
1700: 2e 33 20 7b 20 65 78 65 63 73 71 6c 20 7b 50 52  .3 { execsql {PR
1710: 41 47 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79  AGMA foreign_key
1720: 5f 63 68 65 63 6b 28 74 32 29 7d 20 7d 20 7b 7d  _check(t2)} } {}
1730: 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  .  do_test fkey2
1740: 2d 31 2e 31 2e 24 74 6e 2e 34 20 7b 20 65 78 65  -1.1.$tn.4 { exe
1750: 63 73 71 6c 20 7b 50 52 41 47 4d 41 20 66 6f 72  csql {PRAGMA for
1760: 65 69 67 6e 5f 6b 65 79 5f 63 68 65 63 6b 28 74  eign_key_check(t
1770: 33 29 7d 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74 65  3)} } {}.  do_te
1780: 73 74 20 66 6b 65 79 32 2d 31 2e 31 2e 24 74 6e  st fkey2-1.1.$tn
1790: 2e 35 20 7b 20 65 78 65 63 73 71 6c 20 7b 50 52  .5 { execsql {PR
17a0: 41 47 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79  AGMA foreign_key
17b0: 5f 63 68 65 63 6b 28 74 34 29 7d 20 7d 20 7b 7d  _check(t4)} } {}
17c0: 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  .  do_test fkey2
17d0: 2d 31 2e 31 2e 24 74 6e 2e 36 20 7b 20 65 78 65  -1.1.$tn.6 { exe
17e0: 63 73 71 6c 20 7b 50 52 41 47 4d 41 20 66 6f 72  csql {PRAGMA for
17f0: 65 69 67 6e 5f 6b 65 79 5f 63 68 65 63 6b 28 74  eign_key_check(t
1800: 37 29 7d 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74 65  7)} } {}.  do_te
1810: 73 74 20 66 6b 65 79 32 2d 31 2e 31 2e 24 74 6e  st fkey2-1.1.$tn
1820: 2e 37 20 7b 20 65 78 65 63 73 71 6c 20 7b 50 52  .7 { execsql {PR
1830: 41 47 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79  AGMA foreign_key
1840: 5f 63 68 65 63 6b 28 74 38 29 7d 20 7d 20 7b 7d  _check(t8)} } {}
1850: 0a 7d 0a 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c  .}.drop_all_tabl
1860: 65 73 0a 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79  es..do_test fkey
1870: 32 2d 31 2e 32 2e 30 20 7b 0a 20 20 65 78 65 63  2-1.2.0 {.  exec
1880: 73 71 6c 20 5b 73 74 72 69 6e 67 20 6d 61 70 20  sql [string map 
1890: 7b 2f 44 2f 20 7b 44 45 46 45 52 52 41 42 4c 45  {/D/ {DEFERRABLE
18a0: 20 49 4e 49 54 49 41 4c 4c 59 20 44 45 46 45 52   INITIALLY DEFER
18b0: 52 45 44 7d 7d 20 24 46 6b 65 79 53 69 6d 70 6c  RED}} $FkeySimpl
18c0: 65 53 63 68 65 6d 61 5d 0a 7d 20 7b 7d 0a 66 6f  eSchema].} {}.fo
18d0: 72 65 61 63 68 20 7b 74 6e 20 7a 53 71 6c 20 72  reach {tn zSql r
18e0: 65 73 7d 20 24 46 6b 65 79 53 69 6d 70 6c 65 54  es} $FkeySimpleT
18f0: 65 73 74 73 20 7b 0a 20 20 64 6f 5f 74 65 73 74  ests {.  do_test
1900: 20 66 6b 65 79 32 2d 31 2e 32 2e 24 74 6e 20 7b   fkey2-1.2.$tn {
1910: 20 63 61 74 63 68 73 71 6c 20 24 7a 53 71 6c 20   catchsql $zSql 
1920: 7d 20 24 72 65 73 0a 20 20 64 6f 5f 74 65 73 74  } $res.  do_test
1930: 20 66 6b 65 79 32 2d 31 2e 32 2e 24 74 6e 2e 32   fkey2-1.2.$tn.2
1940: 20 7b 20 65 78 65 63 73 71 6c 20 7b 50 52 41 47   { execsql {PRAG
1950: 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79 5f 63  MA foreign_key_c
1960: 68 65 63 6b 28 74 31 29 7d 20 7d 20 7b 7d 0a 20  heck(t1)} } {}. 
1970: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31   do_test fkey2-1
1980: 2e 32 2e 24 74 6e 2e 33 20 7b 20 65 78 65 63 73  .2.$tn.3 { execs
1990: 71 6c 20 7b 50 52 41 47 4d 41 20 66 6f 72 65 69  ql {PRAGMA forei
19a0: 67 6e 5f 6b 65 79 5f 63 68 65 63 6b 28 74 32 29  gn_key_check(t2)
19b0: 7d 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74 65 73 74  } } {}.  do_test
19c0: 20 66 6b 65 79 32 2d 31 2e 32 2e 24 74 6e 2e 34   fkey2-1.2.$tn.4
19d0: 20 7b 20 65 78 65 63 73 71 6c 20 7b 50 52 41 47   { execsql {PRAG
19e0: 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79 5f 63  MA foreign_key_c
19f0: 68 65 63 6b 28 74 33 29 7d 20 7d 20 7b 7d 0a 20  heck(t3)} } {}. 
1a00: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31   do_test fkey2-1
1a10: 2e 32 2e 24 74 6e 2e 35 20 7b 20 65 78 65 63 73  .2.$tn.5 { execs
1a20: 71 6c 20 7b 50 52 41 47 4d 41 20 66 6f 72 65 69  ql {PRAGMA forei
1a30: 67 6e 5f 6b 65 79 5f 63 68 65 63 6b 28 74 34 29  gn_key_check(t4)
1a40: 7d 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74 65 73 74  } } {}.  do_test
1a50: 20 66 6b 65 79 32 2d 31 2e 32 2e 24 74 6e 2e 36   fkey2-1.2.$tn.6
1a60: 20 7b 20 65 78 65 63 73 71 6c 20 7b 50 52 41 47   { execsql {PRAG
1a70: 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79 5f 63  MA foreign_key_c
1a80: 68 65 63 6b 28 74 37 29 7d 20 7d 20 7b 7d 0a 20  heck(t7)} } {}. 
1a90: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31   do_test fkey2-1
1aa0: 2e 32 2e 24 74 6e 2e 37 20 7b 20 65 78 65 63 73  .2.$tn.7 { execs
1ab0: 71 6c 20 7b 50 52 41 47 4d 41 20 66 6f 72 65 69  ql {PRAGMA forei
1ac0: 67 6e 5f 6b 65 79 5f 63 68 65 63 6b 28 74 38 29  gn_key_check(t8)
1ad0: 7d 20 7d 20 7b 7d 0a 7d 0a 64 72 6f 70 5f 61 6c  } } {}.}.drop_al
1ae0: 6c 5f 74 61 62 6c 65 73 0a 0a 64 6f 5f 74 65 73  l_tables..do_tes
1af0: 74 20 66 6b 65 79 32 2d 31 2e 33 2e 30 20 7b 0a  t fkey2-1.3.0 {.
1b00: 20 20 65 78 65 63 73 71 6c 20 5b 73 74 72 69 6e    execsql [strin
1b10: 67 20 6d 61 70 20 7b 2f 44 2f 20 7b 7d 7d 20 24  g map {/D/ {}} $
1b20: 46 6b 65 79 53 69 6d 70 6c 65 53 63 68 65 6d 61  FkeySimpleSchema
1b30: 5d 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 50 52  ].  execsql { PR
1b40: 41 47 4d 41 20 63 6f 75 6e 74 5f 63 68 61 6e 67  AGMA count_chang
1b50: 65 73 20 3d 20 31 20 7d 0a 7d 20 7b 7d 0a 66 6f  es = 1 }.} {}.fo
1b60: 72 65 61 63 68 20 7b 74 6e 20 7a 53 71 6c 20 72  reach {tn zSql r
1b70: 65 73 7d 20 24 46 6b 65 79 53 69 6d 70 6c 65 54  es} $FkeySimpleT
1b80: 65 73 74 73 20 7b 0a 20 20 69 66 20 7b 24 72 65  ests {.  if {$re
1b90: 73 20 3d 3d 20 22 30 20 7b 7d 22 7d 20 7b 20 73  s == "0 {}"} { s
1ba0: 65 74 20 72 65 73 20 7b 30 20 31 7d 20 7d 0a 20  et res {0 1} }. 
1bb0: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31   do_test fkey2-1
1bc0: 2e 33 2e 24 74 6e 20 7b 20 63 61 74 63 68 73 71  .3.$tn { catchsq
1bd0: 6c 20 24 7a 53 71 6c 20 7d 20 24 72 65 73 0a 20  l $zSql } $res. 
1be0: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31   do_test fkey2-1
1bf0: 2e 33 2e 24 74 6e 2e 32 20 7b 20 65 78 65 63 73  .3.$tn.2 { execs
1c00: 71 6c 20 7b 50 52 41 47 4d 41 20 66 6f 72 65 69  ql {PRAGMA forei
1c10: 67 6e 5f 6b 65 79 5f 63 68 65 63 6b 28 74 31 29  gn_key_check(t1)
1c20: 7d 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74 65 73 74  } } {}.  do_test
1c30: 20 66 6b 65 79 32 2d 31 2e 33 2e 24 74 6e 2e 33   fkey2-1.3.$tn.3
1c40: 20 7b 20 65 78 65 63 73 71 6c 20 7b 50 52 41 47   { execsql {PRAG
1c50: 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79 5f 63  MA foreign_key_c
1c60: 68 65 63 6b 28 74 32 29 7d 20 7d 20 7b 7d 0a 20  heck(t2)} } {}. 
1c70: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31   do_test fkey2-1
1c80: 2e 33 2e 24 74 6e 2e 34 20 7b 20 65 78 65 63 73  .3.$tn.4 { execs
1c90: 71 6c 20 7b 50 52 41 47 4d 41 20 66 6f 72 65 69  ql {PRAGMA forei
1ca0: 67 6e 5f 6b 65 79 5f 63 68 65 63 6b 28 74 33 29  gn_key_check(t3)
1cb0: 7d 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74 65 73 74  } } {}.  do_test
1cc0: 20 66 6b 65 79 32 2d 31 2e 33 2e 24 74 6e 2e 35   fkey2-1.3.$tn.5
1cd0: 20 7b 20 65 78 65 63 73 71 6c 20 7b 50 52 41 47   { execsql {PRAG
1ce0: 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79 5f 63  MA foreign_key_c
1cf0: 68 65 63 6b 28 74 34 29 7d 20 7d 20 7b 7d 0a 20  heck(t4)} } {}. 
1d00: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31   do_test fkey2-1
1d10: 2e 33 2e 24 74 6e 2e 36 20 7b 20 65 78 65 63 73  .3.$tn.6 { execs
1d20: 71 6c 20 7b 50 52 41 47 4d 41 20 66 6f 72 65 69  ql {PRAGMA forei
1d30: 67 6e 5f 6b 65 79 5f 63 68 65 63 6b 28 74 37 29  gn_key_check(t7)
1d40: 7d 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74 65 73 74  } } {}.  do_test
1d50: 20 66 6b 65 79 32 2d 31 2e 33 2e 24 74 6e 2e 37   fkey2-1.3.$tn.7
1d60: 20 7b 20 65 78 65 63 73 71 6c 20 7b 50 52 41 47   { execsql {PRAG
1d70: 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79 5f 63  MA foreign_key_c
1d80: 68 65 63 6b 28 74 38 29 7d 20 7d 20 7b 7d 0a 7d  heck(t8)} } {}.}
1d90: 0a 65 78 65 63 73 71 6c 20 7b 20 50 52 41 47 4d  .execsql { PRAGM
1da0: 41 20 63 6f 75 6e 74 5f 63 68 61 6e 67 65 73 20  A count_changes 
1db0: 3d 20 30 20 7d 0a 64 72 6f 70 5f 61 6c 6c 5f 74  = 0 }.drop_all_t
1dc0: 61 62 6c 65 73 0a 0a 64 6f 5f 74 65 73 74 20 66  ables..do_test f
1dd0: 6b 65 79 32 2d 31 2e 34 2e 30 20 7b 0a 20 20 65  key2-1.4.0 {.  e
1de0: 78 65 63 73 71 6c 20 5b 73 74 72 69 6e 67 20 6d  xecsql [string m
1df0: 61 70 20 7b 2f 44 2f 20 7b 7d 7d 20 24 46 6b 65  ap {/D/ {}} $Fke
1e00: 79 53 69 6d 70 6c 65 53 63 68 65 6d 61 5d 0a 20  ySimpleSchema]. 
1e10: 20 65 78 65 63 73 71 6c 20 7b 20 50 52 41 47 4d   execsql { PRAGM
1e20: 41 20 63 6f 75 6e 74 5f 63 68 61 6e 67 65 73 20  A count_changes 
1e30: 3d 20 31 20 7d 0a 7d 20 7b 7d 0a 66 6f 72 65 61  = 1 }.} {}.forea
1e40: 63 68 20 7b 74 6e 20 7a 53 71 6c 20 72 65 73 7d  ch {tn zSql res}
1e50: 20 24 46 6b 65 79 53 69 6d 70 6c 65 54 65 73 74   $FkeySimpleTest
1e60: 73 20 7b 0a 20 20 69 66 20 7b 24 72 65 73 20 3d  s {.  if {$res =
1e70: 3d 20 22 30 20 7b 7d 22 7d 20 7b 20 73 65 74 20  = "0 {}"} { set 
1e80: 72 65 73 20 7b 30 20 31 7d 20 7d 0a 20 20 65 78  res {0 1} }.  ex
1e90: 65 63 73 71 6c 20 42 45 47 49 4e 0a 20 20 64 6f  ecsql BEGIN.  do
1ea0: 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 2e 34 2e  _test fkey2-1.4.
1eb0: 24 74 6e 20 7b 20 63 61 74 63 68 73 71 6c 20 24  $tn { catchsql $
1ec0: 7a 53 71 6c 20 7d 20 24 72 65 73 0a 20 20 65 78  zSql } $res.  ex
1ed0: 65 63 73 71 6c 20 43 4f 4d 4d 49 54 0a 7d 0a 65  ecsql COMMIT.}.e
1ee0: 78 65 63 73 71 6c 20 7b 20 50 52 41 47 4d 41 20  xecsql { PRAGMA 
1ef0: 63 6f 75 6e 74 5f 63 68 61 6e 67 65 73 20 3d 20  count_changes = 
1f00: 30 20 7d 0a 64 72 6f 70 5f 61 6c 6c 5f 74 61 62  0 }.drop_all_tab
1f10: 6c 65 73 0a 0a 23 20 53 70 65 63 69 61 6c 20 74  les..# Special t
1f20: 65 73 74 3a 20 57 68 65 6e 20 74 68 65 20 70 61  est: When the pa
1f30: 72 65 6e 74 20 6b 65 79 20 69 73 20 61 6e 20 49  rent key is an I
1f40: 50 4b 2c 20 6d 61 6b 65 20 73 75 72 65 20 74 68  PK, make sure th
1f50: 65 20 61 66 66 69 6e 69 74 79 20 6f 66 0a 23 20  e affinity of.# 
1f60: 74 68 65 20 49 50 4b 20 69 73 20 6e 6f 74 20 61  the IPK is not a
1f70: 70 70 6c 69 65 64 20 74 6f 20 74 68 65 20 63 68  pplied to the ch
1f80: 69 6c 64 20 6b 65 79 20 76 61 6c 75 65 20 62 65  ild key value be
1f90: 66 6f 72 65 20 69 74 20 69 73 20 69 6e 73 65 72  fore it is inser
1fa0: 74 65 64 0a 23 20 69 6e 74 6f 20 74 68 65 20 63  ted.# into the c
1fb0: 68 69 6c 64 20 74 61 62 6c 65 2e 0a 64 6f 5f 74  hild table..do_t
1fc0: 65 73 74 20 66 6b 65 79 32 2d 31 2e 35 2e 31 20  est fkey2-1.5.1 
1fd0: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
1fe0: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 69    CREATE TABLE i
1ff0: 28 69 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41  (i INTEGER PRIMA
2000: 52 59 20 4b 45 59 29 3b 0a 20 20 20 20 43 52 45  RY KEY);.    CRE
2010: 41 54 45 20 54 41 42 4c 45 20 6a 28 6a 20 52 45  ATE TABLE j(j RE
2020: 46 45 52 45 4e 43 45 53 20 69 29 3b 0a 20 20 20  FERENCES i);.   
2030: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 69 20 56   INSERT INTO i V
2040: 41 4c 55 45 53 28 33 35 29 3b 0a 20 20 20 20 49  ALUES(35);.    I
2050: 4e 53 45 52 54 20 49 4e 54 4f 20 6a 20 56 41 4c  NSERT INTO j VAL
2060: 55 45 53 28 27 33 35 2e 30 27 29 3b 0a 20 20 20  UES('35.0');.   
2070: 20 53 45 4c 45 43 54 20 6a 2c 20 74 79 70 65 6f   SELECT j, typeo
2080: 66 28 6a 29 20 46 52 4f 4d 20 6a 3b 0a 20 20 7d  f(j) FROM j;.  }
2090: 0a 7d 20 7b 33 35 2e 30 20 74 65 78 74 7d 0a 64  .} {35.0 text}.d
20a0: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 2e 35  o_test fkey2-1.5
20b0: 2e 32 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20  .2 {.  catchsql 
20c0: 7b 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 69 20  { DELETE FROM i 
20d0: 7d 0a 7d 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20  }.} {1 {FOREIGN 
20e0: 4b 45 59 20 63 6f 6e 73 74 72 61 69 6e 74 20 66  KEY constraint f
20f0: 61 69 6c 65 64 7d 7d 0a 0a 23 20 53 61 6d 65 20  ailed}}..# Same 
2100: 74 65 73 74 20 75 73 69 6e 67 20 61 20 72 65 67  test using a reg
2110: 75 6c 61 72 20 70 72 69 6d 61 72 79 20 6b 65 79  ular primary key
2120: 20 77 69 74 68 20 69 6e 74 65 67 65 72 20 61 66   with integer af
2130: 66 69 6e 69 74 79 2e 0a 64 72 6f 70 5f 61 6c 6c  finity..drop_all
2140: 5f 74 61 62 6c 65 73 0a 64 6f 5f 74 65 73 74 20  _tables.do_test 
2150: 66 6b 65 79 32 2d 31 2e 36 2e 31 20 7b 0a 20 20  fkey2-1.6.1 {.  
2160: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52  execsql {.    CR
2170: 45 41 54 45 20 54 41 42 4c 45 20 69 28 69 20 49  EATE TABLE i(i I
2180: 4e 54 20 55 4e 49 51 55 45 29 3b 0a 20 20 20 20  NT UNIQUE);.    
2190: 43 52 45 41 54 45 20 54 41 42 4c 45 20 6a 28 6a  CREATE TABLE j(j
21a0: 20 52 45 46 45 52 45 4e 43 45 53 20 69 28 69 29   REFERENCES i(i)
21b0: 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  );.    INSERT IN
21c0: 54 4f 20 69 20 56 41 4c 55 45 53 28 27 33 35 2e  TO i VALUES('35.
21d0: 30 27 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  0');.    INSERT 
21e0: 49 4e 54 4f 20 6a 20 56 41 4c 55 45 53 28 27 33  INTO j VALUES('3
21f0: 35 2e 30 27 29 3b 0a 20 20 20 20 53 45 4c 45 43  5.0');.    SELEC
2200: 54 20 6a 2c 20 74 79 70 65 6f 66 28 6a 29 20 46  T j, typeof(j) F
2210: 52 4f 4d 20 6a 3b 0a 20 20 20 20 53 45 4c 45 43  ROM j;.    SELEC
2220: 54 20 69 2c 20 74 79 70 65 6f 66 28 69 29 20 46  T i, typeof(i) F
2230: 52 4f 4d 20 69 3b 0a 20 20 7d 0a 7d 20 7b 33 35  ROM i;.  }.} {35
2240: 2e 30 20 74 65 78 74 20 33 35 20 69 6e 74 65 67  .0 text 35 integ
2250: 65 72 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79  er}.do_test fkey
2260: 32 2d 31 2e 36 2e 32 20 7b 0a 20 20 63 61 74 63  2-1.6.2 {.  catc
2270: 68 73 71 6c 20 7b 20 44 45 4c 45 54 45 20 46 52  hsql { DELETE FR
2280: 4f 4d 20 69 20 7d 0a 7d 20 7b 31 20 7b 46 4f 52  OM i }.} {1 {FOR
2290: 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73 74 72 61  EIGN KEY constra
22a0: 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 0a 23 20  int failed}}..# 
22b0: 55 73 65 20 61 20 63 6f 6c 6c 61 74 69 6f 6e 20  Use a collation 
22c0: 73 65 71 75 65 6e 63 65 20 6f 6e 20 74 68 65 20  sequence on the 
22d0: 70 61 72 65 6e 74 20 6b 65 79 2e 0a 64 72 6f 70  parent key..drop
22e0: 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a 64 6f 5f 74  _all_tables.do_t
22f0: 65 73 74 20 66 6b 65 79 32 2d 31 2e 37 2e 31 20  est fkey2-1.7.1 
2300: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
2310: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 69    CREATE TABLE i
2320: 28 69 20 54 45 58 54 20 43 4f 4c 4c 41 54 45 20  (i TEXT COLLATE 
2330: 6e 6f 63 61 73 65 20 50 52 49 4d 41 52 59 20 4b  nocase PRIMARY K
2340: 45 59 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20  EY);.    CREATE 
2350: 54 41 42 4c 45 20 6a 28 6a 20 54 45 58 54 20 43  TABLE j(j TEXT C
2360: 4f 4c 4c 41 54 45 20 62 69 6e 61 72 79 20 52 45  OLLATE binary RE
2370: 46 45 52 45 4e 43 45 53 20 69 28 69 29 29 3b 0a  FERENCES i(i));.
2380: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
2390: 69 20 56 41 4c 55 45 53 28 27 53 51 4c 69 74 65  i VALUES('SQLite
23a0: 27 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  ');.    INSERT I
23b0: 4e 54 4f 20 6a 20 56 41 4c 55 45 53 28 27 73 71  NTO j VALUES('sq
23c0: 6c 69 74 65 27 29 3b 0a 20 20 7d 0a 20 20 63 61  lite');.  }.  ca
23d0: 74 63 68 73 71 6c 20 7b 20 44 45 4c 45 54 45 20  tchsql { DELETE 
23e0: 46 52 4f 4d 20 69 20 7d 0a 7d 20 7b 31 20 7b 46  FROM i }.} {1 {F
23f0: 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73 74  OREIGN KEY const
2400: 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 0a  raint failed}}..
2410: 23 20 55 73 65 20 74 68 65 20 70 61 72 65 6e 74  # Use the parent
2420: 20 6b 65 79 20 63 6f 6c 6c 61 74 69 6f 6e 20 65   key collation e
2430: 76 65 6e 20 69 66 20 69 74 20 69 73 20 64 65 66  ven if it is def
2440: 61 75 6c 74 20 61 6e 64 20 74 68 65 20 63 68 69  ault and the chi
2450: 6c 64 20 6b 65 79 0a 23 20 68 61 73 20 61 6e 20  ld key.# has an 
2460: 65 78 70 6c 69 63 69 74 20 76 61 6c 75 65 2e 0a  explicit value..
2470: 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a  drop_all_tables.
2480: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 2e  do_test fkey2-1.
2490: 37 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  7.2 {.  execsql 
24a0: 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42  {.    CREATE TAB
24b0: 4c 45 20 69 28 69 20 54 45 58 54 20 50 52 49 4d  LE i(i TEXT PRIM
24c0: 41 52 59 20 4b 45 59 29 3b 20 20 20 20 20 20 20  ARY KEY);       
24d0: 20 2d 2d 20 43 6f 6c 73 65 71 20 69 73 20 22 42   -- Colseq is "B
24e0: 49 4e 41 52 59 22 0a 20 20 20 20 43 52 45 41 54  INARY".    CREAT
24f0: 45 20 54 41 42 4c 45 20 6a 28 6a 20 54 45 58 54  E TABLE j(j TEXT
2500: 20 43 4f 4c 4c 41 54 45 20 6e 6f 63 61 73 65 20   COLLATE nocase 
2510: 52 45 46 45 52 45 4e 43 45 53 20 69 28 69 29 29  REFERENCES i(i))
2520: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
2530: 4f 20 69 20 56 41 4c 55 45 53 28 27 53 51 4c 69  O i VALUES('SQLi
2540: 74 65 27 29 3b 0a 20 20 7d 0a 20 20 63 61 74 63  te');.  }.  catc
2550: 68 73 71 6c 20 7b 20 49 4e 53 45 52 54 20 49 4e  hsql { INSERT IN
2560: 54 4f 20 6a 20 56 41 4c 55 45 53 28 27 73 71 6c  TO j VALUES('sql
2570: 69 74 65 27 29 20 7d 0a 7d 20 7b 31 20 7b 46 4f  ite') }.} {1 {FO
2580: 52 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73 74 72  REIGN KEY constr
2590: 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 64 6f  aint failed}}.do
25a0: 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 2e 37 2e  _test fkey2-1.7.
25b0: 33 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  3 {.  execsql {.
25c0: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
25d0: 69 20 56 41 4c 55 45 53 28 27 73 71 6c 69 74 65  i VALUES('sqlite
25e0: 27 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  ');.    INSERT I
25f0: 4e 54 4f 20 6a 20 56 41 4c 55 45 53 28 27 73 71  NTO j VALUES('sq
2600: 6c 69 74 65 27 29 3b 0a 20 20 20 20 44 45 4c 45  lite');.    DELE
2610: 54 45 20 46 52 4f 4d 20 69 20 57 48 45 52 45 20  TE FROM i WHERE 
2620: 69 20 3d 20 27 53 51 4c 69 74 65 27 3b 0a 20 20  i = 'SQLite';.  
2630: 7d 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 20 44  }.  catchsql { D
2640: 45 4c 45 54 45 20 46 52 4f 4d 20 69 20 57 48 45  ELETE FROM i WHE
2650: 52 45 20 69 20 3d 20 27 73 71 6c 69 74 65 27 20  RE i = 'sqlite' 
2660: 7d 0a 7d 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20  }.} {1 {FOREIGN 
2670: 4b 45 59 20 63 6f 6e 73 74 72 61 69 6e 74 20 66  KEY constraint f
2680: 61 69 6c 65 64 7d 7d 0a 0a 23 2d 2d 2d 2d 2d 2d  ailed}}..#------
2690: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
26a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
26b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
26c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
26d0: 2d 2d 2d 0a 23 20 54 68 69 73 20 73 65 63 74 69  ---.# This secti
26e0: 6f 6e 20 28 74 65 73 74 20 63 61 73 65 73 20 66  on (test cases f
26f0: 6b 65 79 32 2d 32 2e 2a 29 20 63 6f 6e 74 61 69  key2-2.*) contai
2700: 6e 73 20 74 65 73 74 73 20 74 6f 20 63 68 65 63  ns tests to chec
2710: 6b 20 74 68 61 74 20 74 68 65 0a 23 20 64 65 66  k that the.# def
2720: 65 72 72 65 64 20 66 6f 72 65 69 67 6e 20 6b 65  erred foreign ke
2730: 79 20 63 6f 6e 73 74 72 61 69 6e 74 20 6c 6f 67  y constraint log
2740: 69 63 20 77 6f 72 6b 73 2e 0a 23 0a 70 72 6f 63  ic works..#.proc
2750: 20 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 7b 74   fkey2-2-test {t
2760: 6e 20 6e 6f 63 6f 6d 6d 69 74 20 73 71 6c 20 7b  n nocommit sql {
2770: 72 65 73 20 7b 7d 7d 7d 20 7b 0a 20 20 69 66 20  res {}}} {.  if 
2780: 7b 24 72 65 73 20 65 71 20 22 46 4b 56 22 7d 20  {$res eq "FKV"} 
2790: 7b 0a 20 20 20 20 73 65 74 20 65 78 70 65 63 74  {.    set expect
27a0: 65 64 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b  ed {1 {FOREIGN K
27b0: 45 59 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61  EY constraint fa
27c0: 69 6c 65 64 7d 7d 0a 20 20 7d 20 65 6c 73 65 20  iled}}.  } else 
27d0: 7b 0a 20 20 20 20 73 65 74 20 65 78 70 65 63 74  {.    set expect
27e0: 65 64 20 5b 6c 69 73 74 20 30 20 24 72 65 73 5d  ed [list 0 $res]
27f0: 0a 20 20 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66  .  }.  do_test f
2800: 6b 65 79 32 2d 32 2e 24 74 6e 20 5b 6c 69 73 74  key2-2.$tn [list
2810: 20 63 61 74 63 68 73 71 6c 20 24 73 71 6c 5d 20   catchsql $sql] 
2820: 24 65 78 70 65 63 74 65 64 0a 20 20 69 66 20 7b  $expected.  if {
2830: 24 6e 6f 63 6f 6d 6d 69 74 7d 20 7b 0a 20 20 20  $nocommit} {.   
2840: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 32   do_test fkey2-2
2850: 2e 24 7b 74 6e 7d 63 20 7b 0a 20 20 20 20 20 20  .${tn}c {.      
2860: 63 61 74 63 68 73 71 6c 20 43 4f 4d 4d 49 54 0a  catchsql COMMIT.
2870: 20 20 20 20 7d 20 7b 31 20 7b 46 4f 52 45 49 47      } {1 {FOREIG
2880: 4e 20 4b 45 59 20 63 6f 6e 73 74 72 61 69 6e 74  N KEY constraint
2890: 20 66 61 69 6c 65 64 7d 7d 0a 20 20 7d 0a 7d 0a   failed}}.  }.}.
28a0: 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 31 20  .fkey2-2-test 1 
28b0: 30 20 7b 0a 20 20 43 52 45 41 54 45 20 54 41 42  0 {.  CREATE TAB
28c0: 4c 45 20 6e 6f 64 65 28 0a 20 20 20 20 6e 6f 64  LE node(.    nod
28d0: 65 69 64 20 50 52 49 4d 41 52 59 20 4b 45 59 2c  eid PRIMARY KEY,
28e0: 0a 20 20 20 20 70 61 72 65 6e 74 20 52 45 46 45  .    parent REFE
28f0: 52 45 4e 43 45 53 20 6e 6f 64 65 20 44 45 46 45  RENCES node DEFE
2900: 52 52 41 42 4c 45 20 49 4e 49 54 49 41 4c 4c 59  RRABLE INITIALLY
2910: 20 44 45 46 45 52 52 45 44 0a 20 20 29 3b 0a 20   DEFERRED.  );. 
2920: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 6c 65   CREATE TABLE le
2930: 61 66 28 0a 20 20 20 20 63 65 6c 6c 69 64 20 50  af(.    cellid P
2940: 52 49 4d 41 52 59 20 4b 45 59 2c 0a 20 20 20 20  RIMARY KEY,.    
2950: 70 61 72 65 6e 74 20 52 45 46 45 52 45 4e 43 45  parent REFERENCE
2960: 53 20 6e 6f 64 65 20 44 45 46 45 52 52 41 42 4c  S node DEFERRABL
2970: 45 20 49 4e 49 54 49 41 4c 4c 59 20 44 45 46 45  E INITIALLY DEFE
2980: 52 52 45 44 0a 20 20 29 3b 0a 7d 0a 0a 66 6b 65  RRED.  );.}..fke
2990: 79 32 2d 32 2d 74 65 73 74 20 31 20 20 30 20 22  y2-2-test 1  0 "
29a0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 6e 6f 64 65  INSERT INTO node
29b0: 20 56 41 4c 55 45 53 28 31 2c 20 30 29 22 20 20   VALUES(1, 0)"  
29c0: 20 20 20 20 20 46 4b 56 0a 66 6b 65 79 32 2d 32       FKV.fkey2-2
29d0: 2d 74 65 73 74 20 32 20 20 30 20 22 42 45 47 49  -test 2  0 "BEGI
29e0: 4e 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20  N".fkey2-2-test 
29f0: 33 20 20 31 20 20 20 22 49 4e 53 45 52 54 20 49  3  1   "INSERT I
2a00: 4e 54 4f 20 6e 6f 64 65 20 56 41 4c 55 45 53 28  NTO node VALUES(
2a10: 31 2c 20 30 29 22 0a 66 6b 65 79 32 2d 32 2d 74  1, 0)".fkey2-2-t
2a20: 65 73 74 20 34 20 20 30 20 20 20 22 55 50 44 41  est 4  0   "UPDA
2a30: 54 45 20 6e 6f 64 65 20 53 45 54 20 70 61 72 65  TE node SET pare
2a40: 6e 74 20 3d 20 4e 55 4c 4c 22 0a 66 6b 65 79 32  nt = NULL".fkey2
2a50: 2d 32 2d 74 65 73 74 20 35 20 20 30 20 22 43 4f  -2-test 5  0 "CO
2a60: 4d 4d 49 54 22 0a 66 6b 65 79 32 2d 32 2d 74 65  MMIT".fkey2-2-te
2a70: 73 74 20 36 20 20 30 20 22 53 45 4c 45 43 54 20  st 6  0 "SELECT 
2a80: 2a 20 46 52 4f 4d 20 6e 6f 64 65 22 20 7b 31 20  * FROM node" {1 
2a90: 7b 7d 7d 0a 0a 66 6b 65 79 32 2d 32 2d 74 65 73  {}}..fkey2-2-tes
2aa0: 74 20 37 20 20 30 20 22 42 45 47 49 4e 22 0a 66  t 7  0 "BEGIN".f
2ab0: 6b 65 79 32 2d 32 2d 74 65 73 74 20 38 20 20 31  key2-2-test 8  1
2ac0: 20 20 20 22 49 4e 53 45 52 54 20 49 4e 54 4f 20     "INSERT INTO 
2ad0: 6c 65 61 66 20 56 41 4c 55 45 53 28 27 61 27 2c  leaf VALUES('a',
2ae0: 20 32 29 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73   2)".fkey2-2-tes
2af0: 74 20 39 20 20 31 20 20 20 22 49 4e 53 45 52 54  t 9  1   "INSERT
2b00: 20 49 4e 54 4f 20 6e 6f 64 65 20 56 41 4c 55 45   INTO node VALUE
2b10: 53 28 32 2c 20 30 29 22 0a 66 6b 65 79 32 2d 32  S(2, 0)".fkey2-2
2b20: 2d 74 65 73 74 20 31 30 20 30 20 20 20 22 55 50  -test 10 0   "UP
2b30: 44 41 54 45 20 6e 6f 64 65 20 53 45 54 20 70 61  DATE node SET pa
2b40: 72 65 6e 74 20 3d 20 31 20 57 48 45 52 45 20 6e  rent = 1 WHERE n
2b50: 6f 64 65 69 64 20 3d 20 32 22 0a 66 6b 65 79 32  odeid = 2".fkey2
2b60: 2d 32 2d 74 65 73 74 20 31 31 20 30 20 22 43 4f  -2-test 11 0 "CO
2b70: 4d 4d 49 54 22 0a 66 6b 65 79 32 2d 32 2d 74 65  MMIT".fkey2-2-te
2b80: 73 74 20 31 32 20 30 20 22 53 45 4c 45 43 54 20  st 12 0 "SELECT 
2b90: 2a 20 46 52 4f 4d 20 6e 6f 64 65 22 20 7b 31 20  * FROM node" {1 
2ba0: 7b 7d 20 32 20 31 7d 0a 66 6b 65 79 32 2d 32 2d  {} 2 1}.fkey2-2-
2bb0: 74 65 73 74 20 31 33 20 30 20 22 53 45 4c 45 43  test 13 0 "SELEC
2bc0: 54 20 2a 20 46 52 4f 4d 20 6c 65 61 66 22 20 7b  T * FROM leaf" {
2bd0: 61 20 32 7d 0a 0a 66 6b 65 79 32 2d 32 2d 74 65  a 2}..fkey2-2-te
2be0: 73 74 20 31 34 20 30 20 22 42 45 47 49 4e 22 0a  st 14 0 "BEGIN".
2bf0: 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 31 35 20  fkey2-2-test 15 
2c00: 31 20 20 20 22 44 45 4c 45 54 45 20 46 52 4f 4d  1   "DELETE FROM
2c10: 20 6e 6f 64 65 20 57 48 45 52 45 20 6e 6f 64 65   node WHERE node
2c20: 69 64 20 3d 20 32 22 0a 66 6b 65 79 32 2d 32 2d  id = 2".fkey2-2-
2c30: 74 65 73 74 20 31 36 20 30 20 20 20 22 49 4e 53  test 16 0   "INS
2c40: 45 52 54 20 49 4e 54 4f 20 6e 6f 64 65 20 56 41  ERT INTO node VA
2c50: 4c 55 45 53 28 32 2c 20 4e 55 4c 4c 29 22 0a 66  LUES(2, NULL)".f
2c60: 6b 65 79 32 2d 32 2d 74 65 73 74 20 31 37 20 30  key2-2-test 17 0
2c70: 20 22 43 4f 4d 4d 49 54 22 0a 66 6b 65 79 32 2d   "COMMIT".fkey2-
2c80: 32 2d 74 65 73 74 20 31 38 20 30 20 22 53 45 4c  2-test 18 0 "SEL
2c90: 45 43 54 20 2a 20 46 52 4f 4d 20 6e 6f 64 65 22  ECT * FROM node"
2ca0: 20 7b 31 20 7b 7d 20 32 20 7b 7d 7d 0a 66 6b 65   {1 {} 2 {}}.fke
2cb0: 79 32 2d 32 2d 74 65 73 74 20 31 39 20 30 20 22  y2-2-test 19 0 "
2cc0: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 6c 65  SELECT * FROM le
2cd0: 61 66 22 20 7b 61 20 32 7d 0a 0a 66 6b 65 79 32  af" {a 2}..fkey2
2ce0: 2d 32 2d 74 65 73 74 20 32 30 20 30 20 22 42 45  -2-test 20 0 "BE
2cf0: 47 49 4e 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73  GIN".fkey2-2-tes
2d00: 74 20 32 31 20 30 20 20 20 22 49 4e 53 45 52 54  t 21 0   "INSERT
2d10: 20 49 4e 54 4f 20 6c 65 61 66 20 56 41 4c 55 45   INTO leaf VALUE
2d20: 53 28 27 62 27 2c 20 31 29 22 0a 66 6b 65 79 32  S('b', 1)".fkey2
2d30: 2d 32 2d 74 65 73 74 20 32 32 20 30 20 20 20 22  -2-test 22 0   "
2d40: 53 41 56 45 50 4f 49 4e 54 20 73 61 76 65 22 0a  SAVEPOINT save".
2d50: 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 32 33 20  fkey2-2-test 23 
2d60: 30 20 20 20 20 20 22 44 45 4c 45 54 45 20 46 52  0     "DELETE FR
2d70: 4f 4d 20 6e 6f 64 65 20 57 48 45 52 45 20 6e 6f  OM node WHERE no
2d80: 64 65 69 64 20 3d 20 31 22 0a 66 6b 65 79 32 2d  deid = 1".fkey2-
2d90: 32 2d 74 65 73 74 20 32 34 20 30 20 20 20 22 52  2-test 24 0   "R
2da0: 4f 4c 4c 42 41 43 4b 20 54 4f 20 73 61 76 65 22  OLLBACK TO save"
2db0: 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 32 35  .fkey2-2-test 25
2dc0: 20 30 20 22 43 4f 4d 4d 49 54 22 0a 66 6b 65 79   0 "COMMIT".fkey
2dd0: 32 2d 32 2d 74 65 73 74 20 32 36 20 30 20 22 53  2-2-test 26 0 "S
2de0: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 6e 6f 64  ELECT * FROM nod
2df0: 65 22 20 7b 31 20 7b 7d 20 32 20 7b 7d 7d 0a 66  e" {1 {} 2 {}}.f
2e00: 6b 65 79 32 2d 32 2d 74 65 73 74 20 32 37 20 30  key2-2-test 27 0
2e10: 20 22 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20   "SELECT * FROM 
2e20: 6c 65 61 66 22 20 7b 61 20 32 20 62 20 31 7d 0a  leaf" {a 2 b 1}.
2e30: 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 32 38  .fkey2-2-test 28
2e40: 20 30 20 22 42 45 47 49 4e 22 0a 66 6b 65 79 32   0 "BEGIN".fkey2
2e50: 2d 32 2d 74 65 73 74 20 32 39 20 30 20 20 20 22  -2-test 29 0   "
2e60: 49 4e 53 45 52 54 20 49 4e 54 4f 20 6c 65 61 66  INSERT INTO leaf
2e70: 20 56 41 4c 55 45 53 28 27 63 27 2c 20 31 29 22   VALUES('c', 1)"
2e80: 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 33 30  .fkey2-2-test 30
2e90: 20 30 20 20 20 22 53 41 56 45 50 4f 49 4e 54 20   0   "SAVEPOINT 
2ea0: 73 61 76 65 22 0a 66 6b 65 79 32 2d 32 2d 74 65  save".fkey2-2-te
2eb0: 73 74 20 33 31 20 30 20 20 20 20 20 22 44 45 4c  st 31 0     "DEL
2ec0: 45 54 45 20 46 52 4f 4d 20 6e 6f 64 65 20 57 48  ETE FROM node WH
2ed0: 45 52 45 20 6e 6f 64 65 69 64 20 3d 20 31 22 0a  ERE nodeid = 1".
2ee0: 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 33 32 20  fkey2-2-test 32 
2ef0: 31 20 20 20 22 52 45 4c 45 41 53 45 20 73 61 76  1   "RELEASE sav
2f00: 65 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20  e".fkey2-2-test 
2f10: 33 33 20 31 20 20 20 22 44 45 4c 45 54 45 20 46  33 1   "DELETE F
2f20: 52 4f 4d 20 6c 65 61 66 20 57 48 45 52 45 20 63  ROM leaf WHERE c
2f30: 65 6c 6c 69 64 20 3d 20 27 62 27 22 0a 66 6b 65  ellid = 'b'".fke
2f40: 79 32 2d 32 2d 74 65 73 74 20 33 34 20 30 20 20  y2-2-test 34 0  
2f50: 20 22 44 45 4c 45 54 45 20 46 52 4f 4d 20 6c 65   "DELETE FROM le
2f60: 61 66 20 57 48 45 52 45 20 63 65 6c 6c 69 64 20  af WHERE cellid 
2f70: 3d 20 27 63 27 22 0a 66 6b 65 79 32 2d 32 2d 74  = 'c'".fkey2-2-t
2f80: 65 73 74 20 33 35 20 30 20 22 43 4f 4d 4d 49 54  est 35 0 "COMMIT
2f90: 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 33  ".fkey2-2-test 3
2fa0: 36 20 30 20 22 53 45 4c 45 43 54 20 2a 20 46 52  6 0 "SELECT * FR
2fb0: 4f 4d 20 6e 6f 64 65 22 20 7b 32 20 7b 7d 7d 20  OM node" {2 {}} 
2fc0: 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 33 37  .fkey2-2-test 37
2fd0: 20 30 20 22 53 45 4c 45 43 54 20 2a 20 46 52 4f   0 "SELECT * FRO
2fe0: 4d 20 6c 65 61 66 22 20 7b 61 20 32 7d 0a 0a 66  M leaf" {a 2}..f
2ff0: 6b 65 79 32 2d 32 2d 74 65 73 74 20 33 38 20 30  key2-2-test 38 0
3000: 20 22 53 41 56 45 50 4f 49 4e 54 20 6f 75 74 65   "SAVEPOINT oute
3010: 72 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20  r".fkey2-2-test 
3020: 33 39 20 31 20 20 20 22 49 4e 53 45 52 54 20 49  39 1   "INSERT I
3030: 4e 54 4f 20 6c 65 61 66 20 56 41 4c 55 45 53 28  NTO leaf VALUES(
3040: 27 64 27 2c 20 33 29 22 0a 66 6b 65 79 32 2d 32  'd', 3)".fkey2-2
3050: 2d 74 65 73 74 20 34 30 20 31 20 22 52 45 4c 45  -test 40 1 "RELE
3060: 41 53 45 20 6f 75 74 65 72 22 20 20 20 20 46 4b  ASE outer"    FK
3070: 56 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 34  V.fkey2-2-test 4
3080: 31 20 31 20 20 20 22 49 4e 53 45 52 54 20 49 4e  1 1   "INSERT IN
3090: 54 4f 20 6c 65 61 66 20 56 41 4c 55 45 53 28 27  TO leaf VALUES('
30a0: 65 27 2c 20 33 29 22 0a 66 6b 65 79 32 2d 32 2d  e', 3)".fkey2-2-
30b0: 74 65 73 74 20 34 32 20 30 20 20 20 22 49 4e 53  test 42 0   "INS
30c0: 45 52 54 20 49 4e 54 4f 20 6e 6f 64 65 20 56 41  ERT INTO node VA
30d0: 4c 55 45 53 28 33 2c 20 32 29 22 0a 66 6b 65 79  LUES(3, 2)".fkey
30e0: 32 2d 32 2d 74 65 73 74 20 34 33 20 30 20 22 52  2-2-test 43 0 "R
30f0: 45 4c 45 41 53 45 20 6f 75 74 65 72 22 0a 0a 66  ELEASE outer"..f
3100: 6b 65 79 32 2d 32 2d 74 65 73 74 20 34 34 20 30  key2-2-test 44 0
3110: 20 22 53 41 56 45 50 4f 49 4e 54 20 6f 75 74 65   "SAVEPOINT oute
3120: 72 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20  r".fkey2-2-test 
3130: 34 35 20 31 20 20 20 22 44 45 4c 45 54 45 20 46  45 1   "DELETE F
3140: 52 4f 4d 20 6e 6f 64 65 20 57 48 45 52 45 20 6e  ROM node WHERE n
3150: 6f 64 65 69 64 3d 33 22 0a 66 6b 65 79 32 2d 32  odeid=3".fkey2-2
3160: 2d 74 65 73 74 20 34 37 20 30 20 20 20 22 49 4e  -test 47 0   "IN
3170: 53 45 52 54 20 49 4e 54 4f 20 6e 6f 64 65 20 56  SERT INTO node V
3180: 41 4c 55 45 53 28 33 2c 20 32 29 22 0a 66 6b 65  ALUES(3, 2)".fke
3190: 79 32 2d 32 2d 74 65 73 74 20 34 38 20 30 20 22  y2-2-test 48 0 "
31a0: 52 4f 4c 4c 42 41 43 4b 20 54 4f 20 6f 75 74 65  ROLLBACK TO oute
31b0: 72 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20  r".fkey2-2-test 
31c0: 34 39 20 30 20 22 52 45 4c 45 41 53 45 20 6f 75  49 0 "RELEASE ou
31d0: 74 65 72 22 0a 0a 66 6b 65 79 32 2d 32 2d 74 65  ter"..fkey2-2-te
31e0: 73 74 20 35 30 20 30 20 22 53 41 56 45 50 4f 49  st 50 0 "SAVEPOI
31f0: 4e 54 20 6f 75 74 65 72 22 0a 66 6b 65 79 32 2d  NT outer".fkey2-
3200: 32 2d 74 65 73 74 20 35 31 20 31 20 20 20 22 49  2-test 51 1   "I
3210: 4e 53 45 52 54 20 49 4e 54 4f 20 6c 65 61 66 20  NSERT INTO leaf 
3220: 56 41 4c 55 45 53 28 27 66 27 2c 20 34 29 22 0a  VALUES('f', 4)".
3230: 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 35 32 20  fkey2-2-test 52 
3240: 31 20 20 20 22 53 41 56 45 50 4f 49 4e 54 20 69  1   "SAVEPOINT i
3250: 6e 6e 65 72 22 0a 66 6b 65 79 32 2d 32 2d 74 65  nner".fkey2-2-te
3260: 73 74 20 35 33 20 31 20 20 20 20 20 22 49 4e 53  st 53 1     "INS
3270: 45 52 54 20 49 4e 54 4f 20 6c 65 61 66 20 56 41  ERT INTO leaf VA
3280: 4c 55 45 53 28 27 67 27 2c 20 34 29 22 0a 66 6b  LUES('g', 4)".fk
3290: 65 79 32 2d 32 2d 74 65 73 74 20 35 34 20 31 20  ey2-2-test 54 1 
32a0: 20 22 52 45 4c 45 41 53 45 20 6f 75 74 65 72 22   "RELEASE outer"
32b0: 20 20 20 46 4b 56 0a 66 6b 65 79 32 2d 32 2d 74     FKV.fkey2-2-t
32c0: 65 73 74 20 35 35 20 31 20 20 20 22 52 4f 4c 4c  est 55 1   "ROLL
32d0: 42 41 43 4b 20 54 4f 20 69 6e 6e 65 72 22 0a 66  BACK TO inner".f
32e0: 6b 65 79 32 2d 32 2d 74 65 73 74 20 35 36 20 30  key2-2-test 56 0
32f0: 20 20 22 43 4f 4d 4d 49 54 22 20 20 20 20 20 20    "COMMIT"      
3300: 20 20 20 20 46 4b 56 0a 66 6b 65 79 32 2d 32 2d      FKV.fkey2-2-
3310: 74 65 73 74 20 35 37 20 30 20 20 20 22 49 4e 53  test 57 0   "INS
3320: 45 52 54 20 49 4e 54 4f 20 6e 6f 64 65 20 56 41  ERT INTO node VA
3330: 4c 55 45 53 28 34 2c 20 4e 55 4c 4c 29 22 0a 66  LUES(4, NULL)".f
3340: 6b 65 79 32 2d 32 2d 74 65 73 74 20 35 38 20 30  key2-2-test 58 0
3350: 20 22 52 45 4c 45 41 53 45 20 6f 75 74 65 72 22   "RELEASE outer"
3360: 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 35 39  .fkey2-2-test 59
3370: 20 30 20 22 53 45 4c 45 43 54 20 2a 20 46 52 4f   0 "SELECT * FRO
3380: 4d 20 6e 6f 64 65 22 20 7b 32 20 7b 7d 20 33 20  M node" {2 {} 3 
3390: 32 20 34 20 7b 7d 7d 0a 66 6b 65 79 32 2d 32 2d  2 4 {}}.fkey2-2-
33a0: 74 65 73 74 20 36 30 20 30 20 22 53 45 4c 45 43  test 60 0 "SELEC
33b0: 54 20 2a 20 46 52 4f 4d 20 6c 65 61 66 22 20 7b  T * FROM leaf" {
33c0: 61 20 32 20 64 20 33 20 65 20 33 20 66 20 34 7d  a 2 d 3 e 3 f 4}
33d0: 0a 0a 23 20 54 68 65 20 66 6f 6c 6c 6f 77 69 6e  ..# The followin
33e0: 67 20 73 65 74 20 6f 66 20 74 65 73 74 73 20 63  g set of tests c
33f0: 68 65 63 6b 20 74 68 61 74 20 69 66 20 61 20 73  heck that if a s
3400: 74 61 74 65 6d 65 6e 74 20 74 68 61 74 20 61 66  tatement that af
3410: 66 65 63 74 73 20 0a 23 20 6d 75 6c 74 69 70 6c  fects .# multipl
3420: 65 20 72 6f 77 73 20 76 69 6f 6c 61 74 65 73 20  e rows violates 
3430: 73 6f 6d 65 20 66 6f 72 65 69 67 6e 20 6b 65 79  some foreign key
3440: 20 63 6f 6e 73 74 72 61 69 6e 74 73 2c 20 74 68   constraints, th
3450: 65 6e 20 73 74 72 69 6b 65 73 20 61 20 0a 23 20  en strikes a .# 
3460: 63 6f 6e 73 74 72 61 69 6e 74 20 74 68 61 74 20  constraint that 
3470: 63 61 75 73 65 73 20 74 68 65 20 73 74 61 74 65  causes the state
3480: 6d 65 6e 74 2d 74 72 61 6e 73 61 63 74 69 6f 6e  ment-transaction
3490: 20 74 6f 20 62 65 20 72 6f 6c 6c 65 64 20 62 61   to be rolled ba
34a0: 63 6b 2c 20 0a 23 20 74 68 65 20 64 65 66 65 72  ck, .# the defer
34b0: 72 65 64 20 63 6f 6e 73 74 72 61 69 6e 74 20 63  red constraint c
34c0: 6f 75 6e 74 65 72 20 69 73 20 63 6f 72 72 65 63  ounter is correc
34d0: 74 6c 79 20 72 65 73 65 74 20 74 6f 20 74 68 65  tly reset to the
34e0: 20 76 61 6c 75 65 20 69 74 20 0a 23 20 68 61 64   value it .# had
34f0: 20 62 65 66 6f 72 65 20 74 68 65 20 73 74 61 74   before the stat
3500: 65 6d 65 6e 74 2d 74 72 61 6e 73 61 63 74 69 6f  ement-transactio
3510: 6e 20 77 61 73 20 6f 70 65 6e 65 64 2e 0a 23 0a  n was opened..#.
3520: 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 36 31 20  fkey2-2-test 61 
3530: 30 20 22 42 45 47 49 4e 22 0a 66 6b 65 79 32 2d  0 "BEGIN".fkey2-
3540: 32 2d 74 65 73 74 20 36 32 20 30 20 20 20 22 44  2-test 62 0   "D
3550: 45 4c 45 54 45 20 46 52 4f 4d 20 6c 65 61 66 22  ELETE FROM leaf"
3560: 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 36 33  .fkey2-2-test 63
3570: 20 30 20 20 20 22 44 45 4c 45 54 45 20 46 52 4f   0   "DELETE FRO
3580: 4d 20 6e 6f 64 65 22 0a 66 6b 65 79 32 2d 32 2d  M node".fkey2-2-
3590: 74 65 73 74 20 36 34 20 31 20 20 20 22 49 4e 53  test 64 1   "INS
35a0: 45 52 54 20 49 4e 54 4f 20 6c 65 61 66 20 56 41  ERT INTO leaf VA
35b0: 4c 55 45 53 28 27 61 27 2c 20 31 29 22 0a 66 6b  LUES('a', 1)".fk
35c0: 65 79 32 2d 32 2d 74 65 73 74 20 36 35 20 31 20  ey2-2-test 65 1 
35d0: 20 20 22 49 4e 53 45 52 54 20 49 4e 54 4f 20 6c    "INSERT INTO l
35e0: 65 61 66 20 56 41 4c 55 45 53 28 27 62 27 2c 20  eaf VALUES('b', 
35f0: 32 29 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74  2)".fkey2-2-test
3600: 20 36 36 20 31 20 20 20 22 49 4e 53 45 52 54 20   66 1   "INSERT 
3610: 49 4e 54 4f 20 6c 65 61 66 20 56 41 4c 55 45 53  INTO leaf VALUES
3620: 28 27 63 27 2c 20 31 29 22 0a 64 6f 5f 74 65 73  ('c', 1)".do_tes
3630: 74 20 66 6b 65 79 32 2d 32 2d 74 65 73 74 2d 36  t fkey2-2-test-6
3640: 37 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 20  7 {.  catchsql  
3650: 20 20 20 20 20 20 20 20 22 49 4e 53 45 52 54 20          "INSERT 
3660: 49 4e 54 4f 20 6e 6f 64 65 20 53 45 4c 45 43 54  INTO node SELECT
3670: 20 70 61 72 65 6e 74 2c 20 33 20 46 52 4f 4d 20   parent, 3 FROM 
3680: 6c 65 61 66 22 0a 7d 20 7b 31 20 7b 55 4e 49 51  leaf".} {1 {UNIQ
3690: 55 45 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61  UE constraint fa
36a0: 69 6c 65 64 3a 20 6e 6f 64 65 2e 6e 6f 64 65 69  iled: node.nodei
36b0: 64 7d 7d 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74  d}}.fkey2-2-test
36c0: 20 36 38 20 30 20 22 43 4f 4d 4d 49 54 22 20 20   68 0 "COMMIT"  
36d0: 20 20 20 20 20 20 20 20 20 46 4b 56 0a 66 6b 65           FKV.fke
36e0: 79 32 2d 32 2d 74 65 73 74 20 36 39 20 31 20 20  y2-2-test 69 1  
36f0: 20 22 49 4e 53 45 52 54 20 49 4e 54 4f 20 6e 6f   "INSERT INTO no
3700: 64 65 20 56 41 4c 55 45 53 28 31 2c 20 4e 55 4c  de VALUES(1, NUL
3710: 4c 29 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74  L)".fkey2-2-test
3720: 20 37 30 20 30 20 20 20 22 49 4e 53 45 52 54 20   70 0   "INSERT 
3730: 49 4e 54 4f 20 6e 6f 64 65 20 56 41 4c 55 45 53  INTO node VALUES
3740: 28 32 2c 20 4e 55 4c 4c 29 22 0a 66 6b 65 79 32  (2, NULL)".fkey2
3750: 2d 32 2d 74 65 73 74 20 37 31 20 30 20 22 43 4f  -2-test 71 0 "CO
3760: 4d 4d 49 54 22 0a 0a 66 6b 65 79 32 2d 32 2d 74  MMIT"..fkey2-2-t
3770: 65 73 74 20 37 32 20 30 20 22 42 45 47 49 4e 22  est 72 0 "BEGIN"
3780: 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 37 33  .fkey2-2-test 73
3790: 20 31 20 20 20 22 44 45 4c 45 54 45 20 46 52 4f   1   "DELETE FRO
37a0: 4d 20 6e 6f 64 65 22 0a 66 6b 65 79 32 2d 32 2d  M node".fkey2-2-
37b0: 74 65 73 74 20 37 34 20 30 20 20 20 22 49 4e 53  test 74 0   "INS
37c0: 45 52 54 20 49 4e 54 4f 20 6e 6f 64 65 28 6e 6f  ERT INTO node(no
37d0: 64 65 69 64 29 20 53 45 4c 45 43 54 20 44 49 53  deid) SELECT DIS
37e0: 54 49 4e 43 54 20 70 61 72 65 6e 74 20 46 52 4f  TINCT parent FRO
37f0: 4d 20 6c 65 61 66 22 0a 66 6b 65 79 32 2d 32 2d  M leaf".fkey2-2-
3800: 74 65 73 74 20 37 35 20 30 20 22 43 4f 4d 4d 49  test 75 0 "COMMI
3810: 54 22 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  T"..#-----------
3820: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3830: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3840: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3850: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23  --------------.#
3860: 20 54 65 73 74 20 63 61 73 65 73 20 66 6b 65 79   Test cases fkey
3870: 32 2d 33 2e 2a 20 74 65 73 74 20 74 68 61 74 20  2-3.* test that 
3880: 61 20 70 72 6f 67 72 61 6d 20 74 68 61 74 20 65  a program that e
3890: 78 65 63 75 74 65 73 20 66 6f 72 65 69 67 6e 20  xecutes foreign 
38a0: 6b 65 79 0a 23 20 61 63 74 69 6f 6e 73 20 28 43  key.# actions (C
38b0: 41 53 43 41 44 45 2c 20 53 45 54 20 44 45 46 41  ASCADE, SET DEFA
38c0: 55 4c 54 2c 20 53 45 54 20 4e 55 4c 4c 20 65 74  ULT, SET NULL et
38d0: 63 2e 29 20 6f 72 20 74 65 73 74 73 20 46 4b 20  c.) or tests FK 
38e0: 63 6f 6e 73 74 72 61 69 6e 74 73 0a 23 20 6f 70  constraints.# op
38f0: 65 6e 73 20 61 20 73 74 61 74 65 6d 65 6e 74 20  ens a statement 
3900: 74 72 61 6e 73 61 63 74 69 6f 6e 20 69 66 20 72  transaction if r
3910: 65 71 75 69 72 65 64 2e 0a 23 0a 23 20 66 6b 65  equired..#.# fke
3920: 79 32 2d 33 2e 31 2e 2a 3a 20 54 65 73 74 20 55  y2-3.1.*: Test U
3930: 50 44 41 54 45 20 73 74 61 74 65 6d 65 6e 74 73  PDATE statements
3940: 2e 0a 23 20 66 6b 65 79 32 2d 33 2e 32 2e 2a 3a  ..# fkey2-3.2.*:
3950: 20 54 65 73 74 20 44 45 4c 45 54 45 20 73 74 61   Test DELETE sta
3960: 74 65 6d 65 6e 74 73 2e 0a 23 0a 64 72 6f 70 5f  tements..#.drop_
3970: 61 6c 6c 5f 74 61 62 6c 65 73 0a 64 6f 5f 74 65  all_tables.do_te
3980: 73 74 20 66 6b 65 79 32 2d 33 2e 31 2e 31 20 7b  st fkey2-3.1.1 {
3990: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
39a0: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 61 62   CREATE TABLE ab
39b0: 28 61 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20  (a PRIMARY KEY, 
39c0: 62 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54  b);.    CREATE T
39d0: 41 42 4c 45 20 63 64 28 0a 20 20 20 20 20 20 63  ABLE cd(.      c
39e0: 20 50 52 49 4d 41 52 59 20 4b 45 59 20 52 45 46   PRIMARY KEY REF
39f0: 45 52 45 4e 43 45 53 20 61 62 20 4f 4e 20 55 50  ERENCES ab ON UP
3a00: 44 41 54 45 20 43 41 53 43 41 44 45 20 4f 4e 20  DATE CASCADE ON 
3a10: 44 45 4c 45 54 45 20 43 41 53 43 41 44 45 2c 20  DELETE CASCADE, 
3a20: 0a 20 20 20 20 20 20 64 0a 20 20 20 20 29 3b 0a  .      d.    );.
3a30: 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45      CREATE TABLE
3a40: 20 65 66 28 0a 20 20 20 20 20 20 65 20 52 45 46   ef(.      e REF
3a50: 45 52 45 4e 43 45 53 20 63 64 20 4f 4e 20 55 50  ERENCES cd ON UP
3a60: 44 41 54 45 20 43 41 53 43 41 44 45 2c 20 0a 20  DATE CASCADE, . 
3a70: 20 20 20 20 20 66 2c 20 43 48 45 43 4b 20 28 65       f, CHECK (e
3a80: 21 3d 35 29 0a 20 20 20 20 29 3b 0a 20 20 7d 0a  !=5).    );.  }.
3a90: 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65  } {}.do_test fke
3aa0: 79 32 2d 33 2e 31 2e 32 20 7b 0a 20 20 65 78 65  y2-3.1.2 {.  exe
3ab0: 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52  csql {.    INSER
3ac0: 54 20 49 4e 54 4f 20 61 62 20 56 41 4c 55 45 53  T INTO ab VALUES
3ad0: 28 31 2c 20 27 62 27 29 3b 0a 20 20 20 20 49 4e  (1, 'b');.    IN
3ae0: 53 45 52 54 20 49 4e 54 4f 20 63 64 20 56 41 4c  SERT INTO cd VAL
3af0: 55 45 53 28 31 2c 20 27 64 27 29 3b 0a 20 20 20  UES(1, 'd');.   
3b00: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 65 66 20   INSERT INTO ef 
3b10: 56 41 4c 55 45 53 28 31 2c 20 27 65 27 29 3b 0a  VALUES(1, 'e');.
3b20: 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74    }.} {}.do_test
3b30: 20 66 6b 65 79 32 2d 33 2e 31 2e 33 20 7b 0a 20   fkey2-3.1.3 {. 
3b40: 20 63 61 74 63 68 73 71 6c 20 7b 20 55 50 44 41   catchsql { UPDA
3b50: 54 45 20 61 62 20 53 45 54 20 61 20 3d 20 35 20  TE ab SET a = 5 
3b60: 7d 0a 7d 20 7b 31 20 7b 43 48 45 43 4b 20 63 6f  }.} {1 {CHECK co
3b70: 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64 3a  nstraint failed:
3b80: 20 65 66 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b   ef}}.do_test fk
3b90: 65 79 32 2d 33 2e 31 2e 34 20 7b 0a 20 20 65 78  ey2-3.1.4 {.  ex
3ba0: 65 63 73 71 6c 20 7b 20 53 45 4c 45 43 54 20 2a  ecsql { SELECT *
3bb0: 20 46 52 4f 4d 20 61 62 20 7d 0a 7d 20 7b 31 20   FROM ab }.} {1 
3bc0: 62 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  b}.do_test fkey2
3bd0: 2d 33 2e 31 2e 34 20 7b 0a 20 20 65 78 65 63 73  -3.1.4 {.  execs
3be0: 71 6c 20 42 45 47 49 4e 3b 0a 20 20 63 61 74 63  ql BEGIN;.  catc
3bf0: 68 73 71 6c 20 7b 20 55 50 44 41 54 45 20 61 62  hsql { UPDATE ab
3c00: 20 53 45 54 20 61 20 3d 20 35 20 7d 0a 7d 20 7b   SET a = 5 }.} {
3c10: 31 20 7b 43 48 45 43 4b 20 63 6f 6e 73 74 72 61  1 {CHECK constra
3c20: 69 6e 74 20 66 61 69 6c 65 64 3a 20 65 66 7d 7d  int failed: ef}}
3c30: 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 33  .do_test fkey2-3
3c40: 2e 31 2e 35 20 7b 0a 20 20 65 78 65 63 73 71 6c  .1.5 {.  execsql
3c50: 20 43 4f 4d 4d 49 54 3b 0a 20 20 65 78 65 63 73   COMMIT;.  execs
3c60: 71 6c 20 7b 20 53 45 4c 45 43 54 20 2a 20 46 52  ql { SELECT * FR
3c70: 4f 4d 20 61 62 3b 20 53 45 4c 45 43 54 20 2a 20  OM ab; SELECT * 
3c80: 46 52 4f 4d 20 63 64 3b 20 53 45 4c 45 43 54 20  FROM cd; SELECT 
3c90: 2a 20 46 52 4f 4d 20 65 66 20 7d 0a 7d 20 7b 31  * FROM ef }.} {1
3ca0: 20 62 20 31 20 64 20 31 20 65 7d 0a 0a 64 6f 5f   b 1 d 1 e}..do_
3cb0: 74 65 73 74 20 66 6b 65 79 32 2d 33 2e 32 2e 31  test fkey2-3.2.1
3cc0: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 42 45 47   {.  execsql BEG
3cd0: 49 4e 3b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b  IN;.  catchsql {
3ce0: 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 61 62 20   DELETE FROM ab 
3cf0: 7d 0a 7d 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20  }.} {1 {FOREIGN 
3d00: 4b 45 59 20 63 6f 6e 73 74 72 61 69 6e 74 20 66  KEY constraint f
3d10: 61 69 6c 65 64 7d 7d 0a 64 6f 5f 74 65 73 74 20  ailed}}.do_test 
3d20: 66 6b 65 79 32 2d 33 2e 32 2e 32 20 7b 0a 20 20  fkey2-3.2.2 {.  
3d30: 65 78 65 63 73 71 6c 20 43 4f 4d 4d 49 54 0a 20  execsql COMMIT. 
3d40: 20 65 78 65 63 73 71 6c 20 7b 20 53 45 4c 45 43   execsql { SELEC
3d50: 54 20 2a 20 46 52 4f 4d 20 61 62 3b 20 53 45 4c  T * FROM ab; SEL
3d60: 45 43 54 20 2a 20 46 52 4f 4d 20 63 64 3b 20 53  ECT * FROM cd; S
3d70: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 65 66 20  ELECT * FROM ef 
3d80: 7d 0a 7d 20 7b 31 20 62 20 31 20 64 20 31 20 65  }.} {1 b 1 d 1 e
3d90: 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  }..#------------
3da0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3db0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3dc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3dd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20  -------------.# 
3de0: 54 65 73 74 20 63 61 73 65 73 20 66 6b 65 79 32  Test cases fkey2
3df0: 2d 34 2e 2a 20 74 65 73 74 20 74 68 61 74 20 72  -4.* test that r
3e00: 65 63 75 72 73 69 76 65 20 66 6f 72 65 69 67 6e  ecursive foreign
3e10: 20 6b 65 79 20 61 63 74 69 6f 6e 73 20 0a 23 20   key actions .# 
3e20: 28 69 2e 65 2e 20 43 41 53 43 41 44 45 29 20 61  (i.e. CASCADE) a
3e30: 72 65 20 61 6c 6c 6f 77 65 64 20 65 76 65 6e 20  re allowed even 
3e40: 69 66 20 72 65 63 75 72 73 69 76 65 20 74 72 69  if recursive tri
3e50: 67 67 65 72 73 20 61 72 65 20 64 69 73 61 62 6c  ggers are disabl
3e60: 65 64 2e 0a 23 0a 64 72 6f 70 5f 61 6c 6c 5f 74  ed..#.drop_all_t
3e70: 61 62 6c 65 73 0a 64 6f 5f 74 65 73 74 20 66 6b  ables.do_test fk
3e80: 65 79 32 2d 34 2e 31 20 7b 0a 20 20 65 78 65 63  ey2-4.1 {.  exec
3e90: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
3ea0: 20 54 41 42 4c 45 20 74 31 28 0a 20 20 20 20 20   TABLE t1(.     
3eb0: 20 6e 6f 64 65 20 50 52 49 4d 41 52 59 20 4b 45   node PRIMARY KE
3ec0: 59 2c 20 0a 20 20 20 20 20 20 70 61 72 65 6e 74  Y, .      parent
3ed0: 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 20 4f   REFERENCES t1 O
3ee0: 4e 20 44 45 4c 45 54 45 20 43 41 53 43 41 44 45  N DELETE CASCADE
3ef0: 0a 20 20 20 20 29 3b 0a 20 20 20 20 43 52 45 41  .    );.    CREA
3f00: 54 45 20 54 41 42 4c 45 20 74 32 28 6e 6f 64 65  TE TABLE t2(node
3f10: 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 70 61   PRIMARY KEY, pa
3f20: 72 65 6e 74 29 3b 0a 20 20 20 20 43 52 45 41 54  rent);.    CREAT
3f30: 45 20 54 52 49 47 47 45 52 20 74 32 74 20 41 46  E TRIGGER t2t AF
3f40: 54 45 52 20 44 45 4c 45 54 45 20 4f 4e 20 74 32  TER DELETE ON t2
3f50: 20 42 45 47 49 4e 0a 20 20 20 20 20 20 44 45 4c   BEGIN.      DEL
3f60: 45 54 45 20 46 52 4f 4d 20 74 32 20 57 48 45 52  ETE FROM t2 WHER
3f70: 45 20 70 61 72 65 6e 74 20 3d 20 6f 6c 64 2e 6e  E parent = old.n
3f80: 6f 64 65 3b 0a 20 20 20 20 45 4e 44 3b 0a 20 20  ode;.    END;.  
3f90: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31    INSERT INTO t1
3fa0: 20 56 41 4c 55 45 53 28 31 2c 20 4e 55 4c 4c 29   VALUES(1, NULL)
3fb0: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
3fc0: 4f 20 74 31 20 56 41 4c 55 45 53 28 32 2c 20 31  O t1 VALUES(2, 1
3fd0: 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  );.    INSERT IN
3fe0: 54 4f 20 74 31 20 56 41 4c 55 45 53 28 33 2c 20  TO t1 VALUES(3, 
3ff0: 31 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  1);.    INSERT I
4000: 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 34 2c  NTO t1 VALUES(4,
4010: 20 32 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20   2);.    INSERT 
4020: 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 35  INTO t1 VALUES(5
4030: 2c 20 32 29 3b 0a 20 20 20 20 49 4e 53 45 52 54  , 2);.    INSERT
4040: 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28   INTO t1 VALUES(
4050: 36 2c 20 33 29 3b 0a 20 20 20 20 49 4e 53 45 52  6, 3);.    INSER
4060: 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53  T INTO t1 VALUES
4070: 28 37 2c 20 33 29 3b 0a 20 20 20 20 49 4e 53 45  (7, 3);.    INSE
4080: 52 54 20 49 4e 54 4f 20 74 32 20 53 45 4c 45 43  RT INTO t2 SELEC
4090: 54 20 2a 20 46 52 4f 4d 20 74 31 3b 0a 20 20 7d  T * FROM t1;.  }
40a0: 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b  .} {}.do_test fk
40b0: 65 79 32 2d 34 2e 32 20 7b 0a 20 20 65 78 65 63  ey2-4.2 {.  exec
40c0: 73 71 6c 20 7b 20 50 52 41 47 4d 41 20 72 65 63  sql { PRAGMA rec
40d0: 75 72 73 69 76 65 5f 74 72 69 67 67 65 72 73 20  ursive_triggers 
40e0: 3d 20 6f 66 66 20 7d 0a 20 20 65 78 65 63 73 71  = off }.  execsq
40f0: 6c 20 7b 20 0a 20 20 20 20 42 45 47 49 4e 3b 0a  l { .    BEGIN;.
4100: 20 20 20 20 20 20 44 45 4c 45 54 45 20 46 52 4f        DELETE FRO
4110: 4d 20 74 31 20 57 48 45 52 45 20 6e 6f 64 65 20  M t1 WHERE node 
4120: 3d 20 31 3b 0a 20 20 20 20 20 20 53 45 4c 45 43  = 1;.      SELEC
4130: 54 20 6e 6f 64 65 20 46 52 4f 4d 20 74 31 3b 0a  T node FROM t1;.
4140: 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74    }.} {}.do_test
4150: 20 66 6b 65 79 32 2d 34 2e 33 20 7b 0a 20 20 65   fkey2-4.3 {.  e
4160: 78 65 63 73 71 6c 20 7b 20 0a 20 20 20 20 20 20  xecsql { .      
4170: 44 45 4c 45 54 45 20 46 52 4f 4d 20 74 32 20 57  DELETE FROM t2 W
4180: 48 45 52 45 20 6e 6f 64 65 20 3d 20 31 3b 0a 20  HERE node = 1;. 
4190: 20 20 20 20 20 53 45 4c 45 43 54 20 6e 6f 64 65       SELECT node
41a0: 20 46 52 4f 4d 20 74 32 3b 0a 20 20 20 20 52 4f   FROM t2;.    RO
41b0: 4c 4c 42 41 43 4b 3b 0a 20 20 7d 0a 7d 20 7b 34  LLBACK;.  }.} {4
41c0: 20 35 20 36 20 37 7d 0a 64 6f 5f 74 65 73 74 20   5 6 7}.do_test 
41d0: 66 6b 65 79 32 2d 34 2e 34 20 7b 0a 20 20 65 78  fkey2-4.4 {.  ex
41e0: 65 63 73 71 6c 20 7b 20 50 52 41 47 4d 41 20 72  ecsql { PRAGMA r
41f0: 65 63 75 72 73 69 76 65 5f 74 72 69 67 67 65 72  ecursive_trigger
4200: 73 20 3d 20 6f 6e 20 7d 0a 20 20 65 78 65 63 73  s = on }.  execs
4210: 71 6c 20 7b 20 0a 20 20 20 20 42 45 47 49 4e 3b  ql { .    BEGIN;
4220: 0a 20 20 20 20 20 20 44 45 4c 45 54 45 20 46 52  .      DELETE FR
4230: 4f 4d 20 74 31 20 57 48 45 52 45 20 6e 6f 64 65  OM t1 WHERE node
4240: 20 3d 20 31 3b 0a 20 20 20 20 20 20 53 45 4c 45   = 1;.      SELE
4250: 43 54 20 6e 6f 64 65 20 46 52 4f 4d 20 74 31 3b  CT node FROM t1;
4260: 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73  .  }.} {}.do_tes
4270: 74 20 66 6b 65 79 32 2d 34 2e 33 20 7b 0a 20 20  t fkey2-4.3 {.  
4280: 65 78 65 63 73 71 6c 20 7b 20 0a 20 20 20 20 20  execsql { .     
4290: 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 74 32 20   DELETE FROM t2 
42a0: 57 48 45 52 45 20 6e 6f 64 65 20 3d 20 31 3b 0a  WHERE node = 1;.
42b0: 20 20 20 20 20 20 53 45 4c 45 43 54 20 6e 6f 64        SELECT nod
42c0: 65 20 46 52 4f 4d 20 74 32 3b 0a 20 20 20 20 52  e FROM t2;.    R
42d0: 4f 4c 4c 42 41 43 4b 3b 0a 20 20 7d 0a 7d 20 7b  OLLBACK;.  }.} {
42e0: 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  }..#------------
42f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4300: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4310: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4320: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20  -------------.# 
4330: 54 65 73 74 20 63 61 73 65 73 20 66 6b 65 79 32  Test cases fkey2
4340: 2d 35 2e 2a 20 76 65 72 69 66 79 20 74 68 61 74  -5.* verify that
4350: 20 74 68 65 20 69 6e 63 72 65 6d 65 6e 74 61 6c   the incremental
4360: 20 62 6c 6f 62 20 41 50 49 20 6d 61 79 20 6e 6f   blob API may no
4370: 74 0a 23 20 77 72 69 74 65 20 74 6f 20 61 20 66  t.# write to a f
4380: 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6c 75 6d  oreign key colum
4390: 6e 20 77 68 69 6c 65 20 66 6f 72 65 69 67 6e 2d  n while foreign-
43a0: 6b 65 79 73 20 61 72 65 20 65 6e 61 62 6c 65 64  keys are enabled
43b0: 2e 0a 23 0a 64 72 6f 70 5f 61 6c 6c 5f 74 61 62  ..#.drop_all_tab
43c0: 6c 65 73 0a 69 66 63 61 70 61 62 6c 65 20 69 6e  les.ifcapable in
43d0: 63 72 62 6c 6f 62 20 7b 0a 20 20 64 6f 5f 74 65  crblob {.  do_te
43e0: 73 74 20 66 6b 65 79 32 2d 35 2e 31 20 7b 0a 20  st fkey2-5.1 {. 
43f0: 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20     execsql {.   
4400: 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20     CREATE TABLE 
4410: 74 31 28 61 20 50 52 49 4d 41 52 59 20 4b 45 59  t1(a PRIMARY KEY
4420: 2c 20 62 29 3b 0a 20 20 20 20 20 20 43 52 45 41  , b);.      CREA
4430: 54 45 20 54 41 42 4c 45 20 74 32 28 61 20 50 52  TE TABLE t2(a PR
4440: 49 4d 41 52 59 20 4b 45 59 2c 20 62 20 52 45 46  IMARY KEY, b REF
4450: 45 52 45 4e 43 45 53 20 74 31 28 61 29 29 3b 0a  ERENCES t1(a));.
4460: 20 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54        INSERT INT
4470: 4f 20 74 31 20 56 41 4c 55 45 53 28 27 68 65 6c  O t1 VALUES('hel
4480: 6c 6f 27 2c 20 27 77 6f 72 6c 64 27 29 3b 0a 20  lo', 'world');. 
4490: 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f       INSERT INTO
44a0: 20 74 32 20 56 41 4c 55 45 53 28 27 6b 65 79 27   t2 VALUES('key'
44b0: 2c 20 27 68 65 6c 6c 6f 27 29 3b 0a 20 20 20 20  , 'hello');.    
44c0: 7d 0a 20 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74 65  }.  } {}.  do_te
44d0: 73 74 20 66 6b 65 79 32 2d 35 2e 32 20 7b 0a 20  st fkey2-5.2 {. 
44e0: 20 20 20 73 65 74 20 72 63 20 5b 63 61 74 63 68     set rc [catch
44f0: 20 7b 20 73 65 74 20 66 64 20 5b 64 62 20 69 6e   { set fd [db in
4500: 63 72 62 6c 6f 62 20 74 32 20 62 20 31 5d 20 7d  crblob t2 b 1] }
4510: 20 6d 73 67 5d 0a 20 20 20 20 6c 69 73 74 20 24   msg].    list $
4520: 72 63 20 24 6d 73 67 0a 20 20 7d 20 7b 31 20 7b  rc $msg.  } {1 {
4530: 63 61 6e 6e 6f 74 20 6f 70 65 6e 20 66 6f 72 65  cannot open fore
4540: 69 67 6e 20 6b 65 79 20 63 6f 6c 75 6d 6e 20 66  ign key column f
4550: 6f 72 20 77 72 69 74 69 6e 67 7d 7d 0a 20 20 64  or writing}}.  d
4560: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 35 2e 33  o_test fkey2-5.3
4570: 20 7b 0a 20 20 20 20 73 65 74 20 72 63 20 5b 63   {.    set rc [c
4580: 61 74 63 68 20 7b 20 73 65 74 20 66 64 20 5b 64  atch { set fd [d
4590: 62 20 69 6e 63 72 62 6c 6f 62 20 2d 72 65 61 64  b incrblob -read
45a0: 6f 6e 6c 79 20 74 32 20 62 20 31 5d 20 7d 20 6d  only t2 b 1] } m
45b0: 73 67 5d 0a 20 20 20 20 63 6c 6f 73 65 20 24 66  sg].    close $f
45c0: 64 0a 20 20 20 20 73 65 74 20 72 63 0a 20 20 7d  d.    set rc.  }
45d0: 20 7b 30 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66   {0}.  do_test f
45e0: 6b 65 79 32 2d 35 2e 34 20 7b 0a 20 20 20 20 65  key2-5.4 {.    e
45f0: 78 65 63 73 71 6c 20 7b 20 50 52 41 47 4d 41 20  xecsql { PRAGMA 
4600: 66 6f 72 65 69 67 6e 5f 6b 65 79 73 20 3d 20 6f  foreign_keys = o
4610: 66 66 20 7d 0a 20 20 20 20 73 65 74 20 72 63 20  ff }.    set rc 
4620: 5b 63 61 74 63 68 20 7b 20 73 65 74 20 66 64 20  [catch { set fd 
4630: 5b 64 62 20 69 6e 63 72 62 6c 6f 62 20 74 32 20  [db incrblob t2 
4640: 62 20 31 5d 20 7d 20 6d 73 67 5d 0a 20 20 20 20  b 1] } msg].    
4650: 63 6c 6f 73 65 20 24 66 64 0a 20 20 20 20 73 65  close $fd.    se
4660: 74 20 72 63 0a 20 20 7d 20 7b 30 7d 0a 20 20 64  t rc.  } {0}.  d
4670: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 35 2e 35  o_test fkey2-5.5
4680: 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b   {.    execsql {
4690: 20 50 52 41 47 4d 41 20 66 6f 72 65 69 67 6e 5f   PRAGMA foreign_
46a0: 6b 65 79 73 20 3d 20 6f 6e 20 7d 0a 20 20 7d 20  keys = on }.  } 
46b0: 7b 7d 0a 7d 0a 0a 64 72 6f 70 5f 61 6c 6c 5f 74  {}.}..drop_all_t
46c0: 61 62 6c 65 73 0a 69 66 63 61 70 61 62 6c 65 20  ables.ifcapable 
46d0: 76 61 63 75 75 6d 20 7b 0a 20 20 64 6f 5f 74 65  vacuum {.  do_te
46e0: 73 74 20 66 6b 65 79 32 2d 36 2e 31 20 7b 0a 20  st fkey2-6.1 {. 
46f0: 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20     execsql {.   
4700: 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20     CREATE TABLE 
4710: 74 31 28 61 20 52 45 46 45 52 45 4e 43 45 53 20  t1(a REFERENCES 
4720: 74 32 28 63 29 2c 20 62 29 3b 0a 20 20 20 20 20  t2(c), b);.     
4730: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 32   CREATE TABLE t2
4740: 28 63 20 55 4e 49 51 55 45 2c 20 62 29 3b 0a 20  (c UNIQUE, b);. 
4750: 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f       INSERT INTO
4760: 20 74 32 20 56 41 4c 55 45 53 28 31 2c 20 32 29   t2 VALUES(1, 2)
4770: 3b 0a 20 20 20 20 20 20 49 4e 53 45 52 54 20 49  ;.      INSERT I
4780: 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 31 2c  NTO t1 VALUES(1,
4790: 20 32 29 3b 0a 20 20 20 20 20 20 56 41 43 55 55   2);.      VACUU
47a0: 4d 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 7d 0a  M;.    }.  } {}.
47b0: 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  }..#------------
47c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
47d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
47e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
47f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20  -------------.# 
4800: 54 65 73 74 20 74 68 61 74 20 69 74 20 69 73 20  Test that it is 
4810: 70 6f 73 73 69 62 6c 65 20 74 6f 20 75 73 65 20  possible to use 
4820: 61 6e 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41  an INTEGER PRIMA
4830: 52 59 20 4b 45 59 20 61 73 20 74 68 65 20 63 68  RY KEY as the ch
4840: 69 6c 64 20 6b 65 79 0a 23 20 6f 66 20 61 20 66  ild key.# of a f
4850: 6f 72 65 69 67 6e 20 63 6f 6e 73 74 72 61 69 6e  oreign constrain
4860: 74 2e 0a 23 20 0a 64 72 6f 70 5f 61 6c 6c 5f 74  t..# .drop_all_t
4870: 61 62 6c 65 73 0a 64 6f 5f 74 65 73 74 20 66 6b  ables.do_test fk
4880: 65 79 32 2d 37 2e 31 20 7b 0a 20 20 65 78 65 63  ey2-7.1 {.  exec
4890: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
48a0: 20 54 41 42 4c 45 20 74 31 28 61 20 50 52 49 4d   TABLE t1(a PRIM
48b0: 41 52 59 20 4b 45 59 2c 20 62 29 3b 0a 20 20 20  ARY KEY, b);.   
48c0: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 32   CREATE TABLE t2
48d0: 28 63 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41  (c INTEGER PRIMA
48e0: 52 59 20 4b 45 59 20 52 45 46 45 52 45 4e 43 45  RY KEY REFERENCE
48f0: 53 20 74 31 2c 20 62 29 3b 0a 20 20 7d 0a 7d 20  S t1, b);.  }.} 
4900: 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  {}.do_test fkey2
4910: 2d 37 2e 32 20 7b 0a 20 20 63 61 74 63 68 73 71  -7.2 {.  catchsq
4920: 6c 20 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f 20  l { INSERT INTO 
4930: 74 32 20 56 41 4c 55 45 53 28 31 2c 20 27 41 27  t2 VALUES(1, 'A'
4940: 29 3b 20 7d 0a 7d 20 7b 31 20 7b 46 4f 52 45 49  ); }.} {1 {FOREI
4950: 47 4e 20 4b 45 59 20 63 6f 6e 73 74 72 61 69 6e  GN KEY constrain
4960: 74 20 66 61 69 6c 65 64 7d 7d 0a 64 6f 5f 74 65  t failed}}.do_te
4970: 73 74 20 66 6b 65 79 32 2d 37 2e 33 20 7b 0a 20  st fkey2-7.3 {. 
4980: 20 65 78 65 63 73 71 6c 20 7b 20 0a 20 20 20 20   execsql { .    
4990: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56  INSERT INTO t1 V
49a0: 41 4c 55 45 53 28 31 2c 20 32 29 3b 0a 20 20 20  ALUES(1, 2);.   
49b0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
49c0: 56 41 4c 55 45 53 28 32 2c 20 33 29 3b 0a 20 20  VALUES(2, 3);.  
49d0: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32    INSERT INTO t2
49e0: 20 56 41 4c 55 45 53 28 31 2c 20 27 41 27 29 3b   VALUES(1, 'A');
49f0: 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73  .  }.} {}.do_tes
4a00: 74 20 66 6b 65 79 32 2d 37 2e 34 20 7b 0a 20 20  t fkey2-7.4 {.  
4a10: 65 78 65 63 73 71 6c 20 7b 20 55 50 44 41 54 45  execsql { UPDATE
4a20: 20 74 32 20 53 45 54 20 63 20 3d 20 32 20 7d 0a   t2 SET c = 2 }.
4a30: 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65  } {}.do_test fke
4a40: 79 32 2d 37 2e 35 20 7b 0a 20 20 63 61 74 63 68  y2-7.5 {.  catch
4a50: 73 71 6c 20 7b 20 55 50 44 41 54 45 20 74 32 20  sql { UPDATE t2 
4a60: 53 45 54 20 63 20 3d 20 33 20 7d 0a 7d 20 7b 31  SET c = 3 }.} {1
4a70: 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f   {FOREIGN KEY co
4a80: 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d  nstraint failed}
4a90: 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d  }.do_test fkey2-
4aa0: 37 2e 36 20 7b 0a 20 20 63 61 74 63 68 73 71 6c  7.6 {.  catchsql
4ab0: 20 7b 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 74   { DELETE FROM t
4ac0: 31 20 57 48 45 52 45 20 61 20 3d 20 32 20 7d 0a  1 WHERE a = 2 }.
4ad0: 7d 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45  } {1 {FOREIGN KE
4ae0: 59 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69  Y constraint fai
4af0: 6c 65 64 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b  led}}.do_test fk
4b00: 65 79 32 2d 37 2e 37 20 7b 0a 20 20 65 78 65 63  ey2-7.7 {.  exec
4b10: 73 71 6c 20 7b 20 44 45 4c 45 54 45 20 46 52 4f  sql { DELETE FRO
4b20: 4d 20 74 31 20 57 48 45 52 45 20 61 20 3d 20 31  M t1 WHERE a = 1
4b30: 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20   }.} {}.do_test 
4b40: 66 6b 65 79 32 2d 37 2e 38 20 7b 0a 20 20 63 61  fkey2-7.8 {.  ca
4b50: 74 63 68 73 71 6c 20 7b 20 55 50 44 41 54 45 20  tchsql { UPDATE 
4b60: 74 31 20 53 45 54 20 61 20 3d 20 33 20 7d 0a 7d  t1 SET a = 3 }.}
4b70: 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59   {1 {FOREIGN KEY
4b80: 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c   constraint fail
4b90: 65 64 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65  ed}}.do_test fke
4ba0: 79 32 2d 37 2e 39 20 7b 0a 20 20 63 61 74 63 68  y2-7.9 {.  catch
4bb0: 73 71 6c 20 7b 20 55 50 44 41 54 45 20 74 32 20  sql { UPDATE t2 
4bc0: 53 45 54 20 72 6f 77 69 64 20 3d 20 33 20 7d 0a  SET rowid = 3 }.
4bd0: 7d 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45  } {1 {FOREIGN KE
4be0: 59 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69  Y constraint fai
4bf0: 6c 65 64 7d 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d  led}}..#--------
4c00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4c10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4c20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4c30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4c40: 2d 0a 23 20 54 65 73 74 20 74 68 61 74 20 69 74  -.# Test that it
4c50: 20 69 73 20 6e 6f 74 20 70 6f 73 73 69 62 6c 65   is not possible
4c60: 20 74 6f 20 65 6e 61 62 6c 65 2f 64 69 73 61 62   to enable/disab
4c70: 6c 65 20 46 4b 20 73 75 70 70 6f 72 74 20 77 68  le FK support wh
4c80: 69 6c 65 20 61 0a 23 20 74 72 61 6e 73 61 63 74  ile a.# transact
4c90: 69 6f 6e 20 69 73 20 6f 70 65 6e 2e 0a 23 20 0a  ion is open..# .
4ca0: 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a  drop_all_tables.
4cb0: 70 72 6f 63 20 66 6b 65 79 32 2d 38 2d 74 65 73  proc fkey2-8-tes
4cc0: 74 20 7b 74 6e 20 7a 53 71 6c 20 76 61 6c 75 65  t {tn zSql value
4cd0: 7d 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b  } {.  do_test fk
4ce0: 65 79 2d 32 2e 38 2e 24 74 6e 2e 31 20 5b 6c 69  ey-2.8.$tn.1 [li
4cf0: 73 74 20 65 78 65 63 73 71 6c 20 24 7a 53 71 6c  st execsql $zSql
4d00: 5d 20 7b 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66  ] {}.  do_test f
4d10: 6b 65 79 2d 32 2e 38 2e 24 74 6e 2e 32 20 7b 20  key-2.8.$tn.2 { 
4d20: 65 78 65 63 73 71 6c 20 22 50 52 41 47 4d 41 20  execsql "PRAGMA 
4d30: 66 6f 72 65 69 67 6e 5f 6b 65 79 73 22 20 7d 20  foreign_keys" } 
4d40: 24 76 61 6c 75 65 0a 7d 0a 66 6b 65 79 32 2d 38  $value.}.fkey2-8
4d50: 2d 74 65 73 74 20 20 31 20 7b 20 50 52 41 47 4d  -test  1 { PRAGM
4d60: 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79 73 20 3d  A foreign_keys =
4d70: 20 30 20 20 20 20 20 7d 20 30 0a 66 6b 65 79 32   0     } 0.fkey2
4d80: 2d 38 2d 74 65 73 74 20 20 32 20 7b 20 50 52 41  -8-test  2 { PRA
4d90: 47 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79 73  GMA foreign_keys
4da0: 20 3d 20 31 20 20 20 20 20 7d 20 31 0a 66 6b 65   = 1     } 1.fke
4db0: 79 32 2d 38 2d 74 65 73 74 20 20 33 20 7b 20 42  y2-8-test  3 { B
4dc0: 45 47 49 4e 20 20 20 20 20 20 20 20 20 20 20 20  EGIN            
4dd0: 20 20 20 20 20 20 20 20 20 20 20 7d 20 31 0a 66             } 1.f
4de0: 6b 65 79 32 2d 38 2d 74 65 73 74 20 20 34 20 7b  key2-8-test  4 {
4df0: 20 50 52 41 47 4d 41 20 66 6f 72 65 69 67 6e 5f   PRAGMA foreign_
4e00: 6b 65 79 73 20 3d 20 30 20 20 20 20 20 7d 20 31  keys = 0     } 1
4e10: 0a 66 6b 65 79 32 2d 38 2d 74 65 73 74 20 20 35  .fkey2-8-test  5
4e20: 20 7b 20 43 4f 4d 4d 49 54 20 20 20 20 20 20 20   { COMMIT       
4e30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d                 }
4e40: 20 31 0a 66 6b 65 79 32 2d 38 2d 74 65 73 74 20   1.fkey2-8-test 
4e50: 20 36 20 7b 20 50 52 41 47 4d 41 20 66 6f 72 65   6 { PRAGMA fore
4e60: 69 67 6e 5f 6b 65 79 73 20 3d 20 30 20 20 20 20  ign_keys = 0    
4e70: 20 7d 20 30 0a 66 6b 65 79 32 2d 38 2d 74 65 73   } 0.fkey2-8-tes
4e80: 74 20 20 37 20 7b 20 42 45 47 49 4e 20 20 20 20  t  7 { BEGIN    
4e90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4ea0: 20 20 20 7d 20 30 0a 66 6b 65 79 32 2d 38 2d 74     } 0.fkey2-8-t
4eb0: 65 73 74 20 20 38 20 7b 20 50 52 41 47 4d 41 20  est  8 { PRAGMA 
4ec0: 66 6f 72 65 69 67 6e 5f 6b 65 79 73 20 3d 20 31  foreign_keys = 1
4ed0: 20 20 20 20 20 7d 20 30 0a 66 6b 65 79 32 2d 38       } 0.fkey2-8
4ee0: 2d 74 65 73 74 20 20 39 20 7b 20 43 4f 4d 4d 49  -test  9 { COMMI
4ef0: 54 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  T               
4f00: 20 20 20 20 20 20 20 7d 20 30 0a 66 6b 65 79 32         } 0.fkey2
4f10: 2d 38 2d 74 65 73 74 20 31 30 20 7b 20 50 52 41  -8-test 10 { PRA
4f20: 47 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79 73  GMA foreign_keys
4f30: 20 3d 20 31 20 20 20 20 20 7d 20 31 0a 66 6b 65   = 1     } 1.fke
4f40: 79 32 2d 38 2d 74 65 73 74 20 31 31 20 7b 20 50  y2-8-test 11 { P
4f50: 52 41 47 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65  RAGMA foreign_ke
4f60: 79 73 20 3d 20 6f 66 66 20 20 20 7d 20 30 0a 66  ys = off   } 0.f
4f70: 6b 65 79 32 2d 38 2d 74 65 73 74 20 31 32 20 7b  key2-8-test 12 {
4f80: 20 50 52 41 47 4d 41 20 66 6f 72 65 69 67 6e 5f   PRAGMA foreign_
4f90: 6b 65 79 73 20 3d 20 6f 6e 20 20 20 20 7d 20 31  keys = on    } 1
4fa0: 0a 66 6b 65 79 32 2d 38 2d 74 65 73 74 20 31 33  .fkey2-8-test 13
4fb0: 20 7b 20 50 52 41 47 4d 41 20 66 6f 72 65 69 67   { PRAGMA foreig
4fc0: 6e 5f 6b 65 79 73 20 3d 20 6e 6f 20 20 20 20 7d  n_keys = no    }
4fd0: 20 30 0a 66 6b 65 79 32 2d 38 2d 74 65 73 74 20   0.fkey2-8-test 
4fe0: 31 34 20 7b 20 50 52 41 47 4d 41 20 66 6f 72 65  14 { PRAGMA fore
4ff0: 69 67 6e 5f 6b 65 79 73 20 3d 20 79 65 73 20 20  ign_keys = yes  
5000: 20 7d 20 31 0a 66 6b 65 79 32 2d 38 2d 74 65 73   } 1.fkey2-8-tes
5010: 74 20 31 35 20 7b 20 50 52 41 47 4d 41 20 66 6f  t 15 { PRAGMA fo
5020: 72 65 69 67 6e 5f 6b 65 79 73 20 3d 20 66 61 6c  reign_keys = fal
5030: 73 65 20 7d 20 30 0a 66 6b 65 79 32 2d 38 2d 74  se } 0.fkey2-8-t
5040: 65 73 74 20 31 36 20 7b 20 50 52 41 47 4d 41 20  est 16 { PRAGMA 
5050: 66 6f 72 65 69 67 6e 5f 6b 65 79 73 20 3d 20 74  foreign_keys = t
5060: 72 75 65 20 20 7d 20 31 0a 0a 23 2d 2d 2d 2d 2d  rue  } 1..#-----
5070: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5080: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5090: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
50a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
50b0: 2d 2d 2d 2d 0a 23 20 54 68 65 20 66 6f 6c 6c 6f  ----.# The follo
50c0: 77 69 6e 67 20 74 65 73 74 73 2c 20 66 6b 65 79  wing tests, fkey
50d0: 32 2d 39 2e 2a 2c 20 74 65 73 74 20 53 45 54 20  2-9.*, test SET 
50e0: 44 45 46 41 55 4c 54 20 61 63 74 69 6f 6e 73 2e  DEFAULT actions.
50f0: 0a 23 0a 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c  .#.drop_all_tabl
5100: 65 73 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  es.do_test fkey2
5110: 2d 39 2e 31 2e 31 20 7b 0a 20 20 65 78 65 63 73  -9.1.1 {.  execs
5120: 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  ql {.    CREATE 
5130: 54 41 42 4c 45 20 74 31 28 61 20 49 4e 54 45 47  TABLE t1(a INTEG
5140: 45 52 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20  ER PRIMARY KEY, 
5150: 62 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54  b);.    CREATE T
5160: 41 42 4c 45 20 74 32 28 0a 20 20 20 20 20 20 63  ABLE t2(.      c
5170: 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59   INTEGER PRIMARY
5180: 20 4b 45 59 2c 0a 20 20 20 20 20 20 64 20 49 4e   KEY,.      d IN
5190: 54 45 47 45 52 20 44 45 46 41 55 4c 54 20 31 20  TEGER DEFAULT 1 
51a0: 52 45 46 45 52 45 4e 43 45 53 20 74 31 20 4f 4e  REFERENCES t1 ON
51b0: 20 44 45 4c 45 54 45 20 53 45 54 20 44 45 46 41   DELETE SET DEFA
51c0: 55 4c 54 0a 20 20 20 20 29 3b 0a 20 20 20 20 44  ULT.    );.    D
51d0: 45 4c 45 54 45 20 46 52 4f 4d 20 74 31 3b 0a 20  ELETE FROM t1;. 
51e0: 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20   }.} {}.do_test 
51f0: 66 6b 65 79 32 2d 39 2e 31 2e 32 20 7b 0a 20 20  fkey2-9.1.2 {.  
5200: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e  execsql {.    IN
5210: 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c  SERT INTO t1 VAL
5220: 55 45 53 28 31 2c 20 27 6f 6e 65 27 29 3b 0a 20  UES(1, 'one');. 
5230: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
5240: 31 20 56 41 4c 55 45 53 28 32 2c 20 27 74 77 6f  1 VALUES(2, 'two
5250: 27 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  ');.    INSERT I
5260: 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28 31 2c  NTO t2 VALUES(1,
5270: 20 32 29 3b 0a 20 20 20 20 53 45 4c 45 43 54 20   2);.    SELECT 
5280: 2a 20 46 52 4f 4d 20 74 32 3b 0a 20 20 20 20 44  * FROM t2;.    D
5290: 45 4c 45 54 45 20 46 52 4f 4d 20 74 31 20 57 48  ELETE FROM t1 WH
52a0: 45 52 45 20 61 20 3d 20 32 3b 0a 20 20 20 20 53  ERE a = 2;.    S
52b0: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 32 3b  ELECT * FROM t2;
52c0: 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 31 20 31 7d  .  }.} {1 2 1 1}
52d0: 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 39  .do_test fkey2-9
52e0: 2e 31 2e 33 20 7b 0a 20 20 65 78 65 63 73 71 6c  .1.3 {.  execsql
52f0: 20 7b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e   {.    INSERT IN
5300: 54 4f 20 74 31 20 56 41 4c 55 45 53 28 32 2c 20  TO t1 VALUES(2, 
5310: 27 74 77 6f 27 29 3b 0a 20 20 20 20 55 50 44 41  'two');.    UPDA
5320: 54 45 20 74 32 20 53 45 54 20 64 20 3d 20 32 3b  TE t2 SET d = 2;
5330: 0a 20 20 20 20 44 45 4c 45 54 45 20 46 52 4f 4d  .    DELETE FROM
5340: 20 74 31 20 57 48 45 52 45 20 61 20 3d 20 31 3b   t1 WHERE a = 1;
5350: 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52  .    SELECT * FR
5360: 4f 4d 20 74 32 3b 0a 20 20 7d 0a 7d 20 7b 31 20  OM t2;.  }.} {1 
5370: 32 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  2}.do_test fkey2
5380: 2d 39 2e 31 2e 34 20 7b 0a 20 20 65 78 65 63 73  -9.1.4 {.  execs
5390: 71 6c 20 7b 20 53 45 4c 45 43 54 20 2a 20 46 52  ql { SELECT * FR
53a0: 4f 4d 20 74 31 20 7d 0a 7d 20 7b 32 20 74 77 6f  OM t1 }.} {2 two
53b0: 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d  }.do_test fkey2-
53c0: 39 2e 31 2e 35 20 7b 0a 20 20 63 61 74 63 68 73  9.1.5 {.  catchs
53d0: 71 6c 20 7b 20 44 45 4c 45 54 45 20 46 52 4f 4d  ql { DELETE FROM
53e0: 20 74 31 20 7d 0a 7d 20 7b 31 20 7b 46 4f 52 45   t1 }.} {1 {FORE
53f0: 49 47 4e 20 4b 45 59 20 63 6f 6e 73 74 72 61 69  IGN KEY constrai
5400: 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 0a 64 6f 5f  nt failed}}..do_
5410: 74 65 73 74 20 66 6b 65 79 32 2d 39 2e 32 2e 31  test fkey2-9.2.1
5420: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   {.  execsql {. 
5430: 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20     CREATE TABLE 
5440: 70 70 28 61 2c 20 62 2c 20 63 2c 20 50 52 49 4d  pp(a, b, c, PRIM
5450: 41 52 59 20 4b 45 59 28 62 2c 20 63 29 29 3b 0a  ARY KEY(b, c));.
5460: 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45      CREATE TABLE
5470: 20 63 63 28 64 20 44 45 46 41 55 4c 54 20 33 2c   cc(d DEFAULT 3,
5480: 20 65 20 44 45 46 41 55 4c 54 20 31 2c 20 66 20   e DEFAULT 1, f 
5490: 44 45 46 41 55 4c 54 20 32 2c 0a 20 20 20 20 20  DEFAULT 2,.     
54a0: 20 20 20 46 4f 52 45 49 47 4e 20 4b 45 59 28 66     FOREIGN KEY(f
54b0: 2c 20 64 29 20 52 45 46 45 52 45 4e 43 45 53 20  , d) REFERENCES 
54c0: 70 70 20 0a 20 20 20 20 20 20 20 20 4f 4e 20 55  pp .        ON U
54d0: 50 44 41 54 45 20 53 45 54 20 44 45 46 41 55 4c  PDATE SET DEFAUL
54e0: 54 20 0a 20 20 20 20 20 20 20 20 4f 4e 20 44 45  T .        ON DE
54f0: 4c 45 54 45 20 53 45 54 20 4e 55 4c 4c 0a 20 20  LETE SET NULL.  
5500: 20 20 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20    );.    INSERT 
5510: 49 4e 54 4f 20 70 70 20 56 41 4c 55 45 53 28 31  INTO pp VALUES(1
5520: 2c 20 32 2c 20 33 29 3b 0a 20 20 20 20 49 4e 53  , 2, 3);.    INS
5530: 45 52 54 20 49 4e 54 4f 20 70 70 20 56 41 4c 55  ERT INTO pp VALU
5540: 45 53 28 34 2c 20 35 2c 20 36 29 3b 0a 20 20 20  ES(4, 5, 6);.   
5550: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 70 70 20   INSERT INTO pp 
5560: 56 41 4c 55 45 53 28 37 2c 20 38 2c 20 39 29 3b  VALUES(7, 8, 9);
5570: 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73  .  }.} {}.do_tes
5580: 74 20 66 6b 65 79 32 2d 39 2e 32 2e 32 20 7b 0a  t fkey2-9.2.2 {.
5590: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
55a0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 63 63 20 56  INSERT INTO cc V
55b0: 41 4c 55 45 53 28 36 2c 20 27 41 27 2c 20 35 29  ALUES(6, 'A', 5)
55c0: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
55d0: 4f 20 63 63 20 56 41 4c 55 45 53 28 36 2c 20 27  O cc VALUES(6, '
55e0: 42 27 2c 20 35 29 3b 0a 20 20 20 20 49 4e 53 45  B', 5);.    INSE
55f0: 52 54 20 49 4e 54 4f 20 63 63 20 56 41 4c 55 45  RT INTO cc VALUE
5600: 53 28 39 2c 20 27 41 27 2c 20 38 29 3b 0a 20 20  S(9, 'A', 8);.  
5610: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 63 63    INSERT INTO cc
5620: 20 56 41 4c 55 45 53 28 39 2c 20 27 42 27 2c 20   VALUES(9, 'B', 
5630: 38 29 3b 0a 20 20 20 20 55 50 44 41 54 45 20 70  8);.    UPDATE p
5640: 70 20 53 45 54 20 62 20 3d 20 31 20 57 48 45 52  p SET b = 1 WHER
5650: 45 20 61 20 3d 20 37 3b 0a 20 20 20 20 53 45 4c  E a = 7;.    SEL
5660: 45 43 54 20 2a 20 46 52 4f 4d 20 63 63 3b 0a 20  ECT * FROM cc;. 
5670: 20 7d 0a 7d 20 7b 36 20 41 20 35 20 36 20 42 20   }.} {6 A 5 6 B 
5680: 35 20 33 20 41 20 32 20 33 20 42 20 32 7d 0a 64  5 3 A 2 3 B 2}.d
5690: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 39 2e 32  o_test fkey2-9.2
56a0: 2e 33 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .3 {.  execsql {
56b0: 0a 20 20 20 20 44 45 4c 45 54 45 20 46 52 4f 4d  .    DELETE FROM
56c0: 20 70 70 20 57 48 45 52 45 20 61 20 3d 20 34 3b   pp WHERE a = 4;
56d0: 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52  .    SELECT * FR
56e0: 4f 4d 20 63 63 3b 0a 20 20 7d 0a 7d 20 7b 7b 7d  OM cc;.  }.} {{}
56f0: 20 41 20 7b 7d 20 7b 7d 20 42 20 7b 7d 20 33 20   A {} {} B {} 3 
5700: 41 20 32 20 33 20 42 20 32 7d 0a 64 6f 5f 65 78  A 2 3 B 2}.do_ex
5710: 65 63 73 71 6c 5f 74 65 73 74 20 66 6b 65 79 32  ecsql_test fkey2
5720: 2d 39 2e 33 2e 30 20 7b 0a 20 20 43 52 45 41 54  -9.3.0 {.  CREAT
5730: 45 20 54 41 42 4c 45 20 74 33 28 78 20 50 52 49  E TABLE t3(x PRI
5740: 4d 41 52 59 20 4b 45 59 20 52 45 46 45 52 45 4e  MARY KEY REFEREN
5750: 43 45 53 20 74 33 20 4f 4e 20 44 45 4c 45 54 45  CES t3 ON DELETE
5760: 20 53 45 54 20 4e 55 4c 4c 29 3b 0a 20 20 49 4e   SET NULL);.  IN
5770: 53 45 52 54 20 49 4e 54 4f 20 74 33 28 78 29 20  SERT INTO t3(x) 
5780: 56 41 4c 55 45 53 28 31 32 33 34 35 29 3b 0a 20  VALUES(12345);. 
5790: 20 44 52 4f 50 20 54 41 42 4c 45 20 74 33 3b 0a   DROP TABLE t3;.
57a0: 7d 20 7b 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d  } {}..#---------
57b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
57c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
57d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
57e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
57f0: 0a 23 20 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67  .# The following
5800: 20 74 65 73 74 73 2c 20 66 6b 65 79 32 2d 31 30   tests, fkey2-10
5810: 2e 2a 2c 20 74 65 73 74 20 22 66 6f 72 65 69 67  .*, test "foreig
5820: 6e 20 6b 65 79 20 6d 69 73 6d 61 74 63 68 22 20  n key mismatch" 
5830: 61 6e 64 20 0a 23 20 6f 74 68 65 72 20 65 72 72  and .# other err
5840: 6f 72 73 2e 0a 23 0a 73 65 74 20 74 6e 20 30 0a  ors..#.set tn 0.
5850: 66 6f 72 65 61 63 68 20 7a 53 71 6c 20 5b 6c 69  foreach zSql [li
5860: 73 74 20 7b 0a 20 20 43 52 45 41 54 45 20 54 41  st {.  CREATE TA
5870: 42 4c 45 20 70 28 61 20 50 52 49 4d 41 52 59 20  BLE p(a PRIMARY 
5880: 4b 45 59 2c 20 62 29 3b 0a 20 20 43 52 45 41 54  KEY, b);.  CREAT
5890: 45 20 54 41 42 4c 45 20 63 28 78 20 52 45 46 45  E TABLE c(x REFE
58a0: 52 45 4e 43 45 53 20 70 28 63 29 29 3b 0a 7d 20  RENCES p(c));.} 
58b0: 7b 0a 20 20 43 52 45 41 54 45 20 54 41 42 4c 45  {.  CREATE TABLE
58c0: 20 63 28 78 20 52 45 46 45 52 45 4e 43 45 53 20   c(x REFERENCES 
58d0: 76 28 79 29 29 3b 0a 20 20 43 52 45 41 54 45 20  v(y));.  CREATE 
58e0: 56 49 45 57 20 76 20 41 53 20 53 45 4c 45 43 54  VIEW v AS SELECT
58f0: 20 78 20 41 53 20 79 20 46 52 4f 4d 20 63 3b 0a   x AS y FROM c;.
5900: 7d 20 7b 0a 20 20 43 52 45 41 54 45 20 54 41 42  } {.  CREATE TAB
5910: 4c 45 20 70 28 61 2c 20 62 2c 20 50 52 49 4d 41  LE p(a, b, PRIMA
5920: 52 59 20 4b 45 59 28 61 2c 20 62 29 29 3b 0a 20  RY KEY(a, b));. 
5930: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 63 28   CREATE TABLE c(
5940: 78 20 52 45 46 45 52 45 4e 43 45 53 20 70 29 3b  x REFERENCES p);
5950: 0a 7d 20 7b 0a 20 20 43 52 45 41 54 45 20 54 41  .} {.  CREATE TA
5960: 42 4c 45 20 70 28 61 20 43 4f 4c 4c 41 54 45 20  BLE p(a COLLATE 
5970: 62 69 6e 61 72 79 2c 20 62 29 3b 0a 20 20 43 52  binary, b);.  CR
5980: 45 41 54 45 20 55 4e 49 51 55 45 20 49 4e 44 45  EATE UNIQUE INDE
5990: 58 20 69 20 4f 4e 20 70 28 61 20 43 4f 4c 4c 41  X i ON p(a COLLA
59a0: 54 45 20 6e 6f 63 61 73 65 29 3b 0a 20 20 43 52  TE nocase);.  CR
59b0: 45 41 54 45 20 54 41 42 4c 45 20 63 28 78 20 52  EATE TABLE c(x R
59c0: 45 46 45 52 45 4e 43 45 53 20 70 28 61 29 29 3b  EFERENCES p(a));
59d0: 0a 7d 5d 20 7b 0a 20 20 64 72 6f 70 5f 61 6c 6c  .}] {.  drop_all
59e0: 5f 74 61 62 6c 65 73 0a 20 20 64 6f 5f 74 65 73  _tables.  do_tes
59f0: 74 20 66 6b 65 79 32 2d 31 30 2e 31 2e 5b 69 6e  t fkey2-10.1.[in
5a00: 63 72 20 74 6e 5d 20 7b 0a 20 20 20 20 65 78 65  cr tn] {.    exe
5a10: 63 73 71 6c 20 24 7a 53 71 6c 0a 20 20 20 20 63  csql $zSql.    c
5a20: 61 74 63 68 73 71 6c 20 7b 20 49 4e 53 45 52 54  atchsql { INSERT
5a30: 20 49 4e 54 4f 20 63 20 44 45 46 41 55 4c 54 20   INTO c DEFAULT 
5a40: 56 41 4c 55 45 53 20 7d 0a 20 20 7d 20 7b 2f 31  VALUES }.  } {/1
5a50: 20 7b 66 6f 72 65 69 67 6e 20 6b 65 79 20 6d 69   {foreign key mi
5a60: 73 6d 61 74 63 68 20 2d 20 22 63 22 20 72 65 66  smatch - "c" ref
5a70: 65 72 65 6e 63 69 6e 67 20 22 2e 22 7d 2f 7d 0a  erencing "."}/}.
5a80: 7d 0a 0a 23 20 22 72 6f 77 69 64 22 20 63 61 6e  }..# "rowid" can
5a90: 6e 6f 74 20 62 65 20 75 73 65 64 20 61 73 20 70  not be used as p
5aa0: 61 72 74 20 6f 66 20 61 20 63 68 69 6c 64 20 6f  art of a child o
5ab0: 72 20 70 61 72 65 6e 74 20 6b 65 79 20 64 65 66  r parent key def
5ac0: 69 6e 69 74 69 6f 6e 20 0a 23 20 75 6e 6c 65 73  inition .# unles
5ad0: 73 20 69 74 20 68 61 70 70 65 6e 73 20 74 6f 20  s it happens to 
5ae0: 62 65 20 74 68 65 20 6e 61 6d 65 20 6f 66 20 61  be the name of a
5af0: 6e 20 65 78 70 6c 69 63 69 74 6c 79 20 64 65 63  n explicitly dec
5b00: 6c 61 72 65 64 20 63 6f 6c 75 6d 6e 2e 0a 23 0a  lared column..#.
5b10: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 30  do_test fkey2-10
5b20: 2e 32 2e 31 20 7b 0a 20 20 64 72 6f 70 5f 61 6c  .2.1 {.  drop_al
5b30: 6c 5f 74 61 62 6c 65 73 0a 20 20 63 61 74 63 68  l_tables.  catch
5b40: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
5b50: 20 54 41 42 4c 45 20 74 31 28 61 20 50 52 49 4d   TABLE t1(a PRIM
5b60: 41 52 59 20 4b 45 59 2c 20 62 29 3b 0a 20 20 20  ARY KEY, b);.   
5b70: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 32   CREATE TABLE t2
5b80: 28 63 2c 20 64 2c 20 46 4f 52 45 49 47 4e 20 4b  (c, d, FOREIGN K
5b90: 45 59 28 72 6f 77 69 64 29 20 52 45 46 45 52 45  EY(rowid) REFERE
5ba0: 4e 43 45 53 20 74 31 28 61 29 29 3b 0a 20 20 7d  NCES t1(a));.  }
5bb0: 0a 7d 20 7b 31 20 7b 75 6e 6b 6e 6f 77 6e 20 63  .} {1 {unknown c
5bc0: 6f 6c 75 6d 6e 20 22 72 6f 77 69 64 22 20 69 6e  olumn "rowid" in
5bd0: 20 66 6f 72 65 69 67 6e 20 6b 65 79 20 64 65 66   foreign key def
5be0: 69 6e 69 74 69 6f 6e 7d 7d 0a 64 6f 5f 74 65 73  inition}}.do_tes
5bf0: 74 20 66 6b 65 79 32 2d 31 30 2e 32 2e 32 20 7b  t fkey2-10.2.2 {
5c00: 0a 20 20 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c  .  drop_all_tabl
5c10: 65 73 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a  es.  catchsql {.
5c20: 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45      CREATE TABLE
5c30: 20 74 31 28 61 20 50 52 49 4d 41 52 59 20 4b 45   t1(a PRIMARY KE
5c40: 59 2c 20 62 29 3b 0a 20 20 20 20 43 52 45 41 54  Y, b);.    CREAT
5c50: 45 20 54 41 42 4c 45 20 74 32 28 72 6f 77 69 64  E TABLE t2(rowid
5c60: 2c 20 64 2c 20 46 4f 52 45 49 47 4e 20 4b 45 59  , d, FOREIGN KEY
5c70: 28 72 6f 77 69 64 29 20 52 45 46 45 52 45 4e 43  (rowid) REFERENC
5c80: 45 53 20 74 31 28 61 29 29 3b 0a 20 20 7d 0a 7d  ES t1(a));.  }.}
5c90: 20 7b 30 20 7b 7d 7d 0a 64 6f 5f 74 65 73 74 20   {0 {}}.do_test 
5ca0: 66 6b 65 79 32 2d 31 30 2e 32 2e 31 20 7b 0a 20  fkey2-10.2.1 {. 
5cb0: 20 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73   drop_all_tables
5cc0: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20  .  catchsql {.  
5cd0: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74    CREATE TABLE t
5ce0: 31 28 61 2c 20 62 29 3b 0a 20 20 20 20 43 52 45  1(a, b);.    CRE
5cf0: 41 54 45 20 54 41 42 4c 45 20 74 32 28 63 2c 20  ATE TABLE t2(c, 
5d00: 64 2c 20 46 4f 52 45 49 47 4e 20 4b 45 59 28 63  d, FOREIGN KEY(c
5d10: 29 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 28  ) REFERENCES t1(
5d20: 72 6f 77 69 64 29 29 3b 0a 20 20 20 20 49 4e 53  rowid));.    INS
5d30: 45 52 54 20 49 4e 54 4f 20 74 31 28 72 6f 77 69  ERT INTO t1(rowi
5d40: 64 2c 20 61 2c 20 62 29 20 56 41 4c 55 45 53 28  d, a, b) VALUES(
5d50: 31 2c 20 31 2c 20 31 29 3b 0a 20 20 20 20 49 4e  1, 1, 1);.    IN
5d60: 53 45 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c  SERT INTO t2 VAL
5d70: 55 45 53 28 31 2c 20 31 29 3b 0a 20 20 7d 0a 7d  UES(1, 1);.  }.}
5d80: 20 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65 79   {1 {foreign key
5d90: 20 6d 69 73 6d 61 74 63 68 20 2d 20 22 74 32 22   mismatch - "t2"
5da0: 20 72 65 66 65 72 65 6e 63 69 6e 67 20 22 74 31   referencing "t1
5db0: 22 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79  "}}.do_test fkey
5dc0: 32 2d 31 30 2e 32 2e 32 20 7b 0a 20 20 64 72 6f  2-10.2.2 {.  dro
5dd0: 70 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a 20 20 63  p_all_tables.  c
5de0: 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 43 52  atchsql {.    CR
5df0: 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 72 6f  EATE TABLE t1(ro
5e00: 77 69 64 20 50 52 49 4d 41 52 59 20 4b 45 59 2c  wid PRIMARY KEY,
5e10: 20 62 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20   b);.    CREATE 
5e20: 54 41 42 4c 45 20 74 32 28 63 2c 20 64 2c 20 46  TABLE t2(c, d, F
5e30: 4f 52 45 49 47 4e 20 4b 45 59 28 63 29 20 52 45  OREIGN KEY(c) RE
5e40: 46 45 52 45 4e 43 45 53 20 74 31 28 72 6f 77 69  FERENCES t1(rowi
5e50: 64 29 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  d));.    INSERT 
5e60: 49 4e 54 4f 20 74 31 28 72 6f 77 69 64 2c 20 62  INTO t1(rowid, b
5e70: 29 20 56 41 4c 55 45 53 28 31 2c 20 31 29 3b 0a  ) VALUES(1, 1);.
5e80: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
5e90: 74 32 20 56 41 4c 55 45 53 28 31 2c 20 31 29 3b  t2 VALUES(1, 1);
5ea0: 0a 20 20 7d 0a 7d 20 7b 30 20 7b 7d 7d 0a 0a 0a  .  }.} {0 {}}...
5eb0: 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  #---------------
5ec0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5ed0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5ee0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5ef0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 54 68 65  ----------.# The
5f00: 20 66 6f 6c 6c 6f 77 69 6e 67 20 74 65 73 74 73   following tests
5f10: 2c 20 66 6b 65 79 32 2d 31 31 2e 2a 2c 20 74 65  , fkey2-11.*, te
5f20: 73 74 20 43 41 53 43 41 44 45 20 61 63 74 69 6f  st CASCADE actio
5f30: 6e 73 2e 0a 23 0a 64 72 6f 70 5f 61 6c 6c 5f 74  ns..#.drop_all_t
5f40: 61 62 6c 65 73 0a 64 6f 5f 74 65 73 74 20 66 6b  ables.do_test fk
5f50: 65 79 32 2d 31 31 2e 31 2e 31 20 7b 0a 20 20 65  ey2-11.1.1 {.  e
5f60: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45  xecsql {.    CRE
5f70: 41 54 45 20 54 41 42 4c 45 20 74 31 28 61 20 49  ATE TABLE t1(a I
5f80: 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b  NTEGER PRIMARY K
5f90: 45 59 2c 20 62 2c 20 72 6f 77 69 64 2c 20 5f 72  EY, b, rowid, _r
5fa0: 6f 77 69 64 5f 2c 20 6f 69 64 29 3b 0a 20 20 20  owid_, oid);.   
5fb0: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 32   CREATE TABLE t2
5fc0: 28 63 2c 20 64 2c 20 46 4f 52 45 49 47 4e 20 4b  (c, d, FOREIGN K
5fd0: 45 59 28 63 29 20 52 45 46 45 52 45 4e 43 45 53  EY(c) REFERENCES
5fe0: 20 74 31 28 61 29 20 4f 4e 20 55 50 44 41 54 45   t1(a) ON UPDATE
5ff0: 20 43 41 53 43 41 44 45 29 3b 0a 0a 20 20 20 20   CASCADE);..    
6000: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56  INSERT INTO t1 V
6010: 41 4c 55 45 53 28 31 30 2c 20 31 30 30 2c 20 27  ALUES(10, 100, '
6020: 61 62 63 27 2c 20 27 64 65 66 27 2c 20 27 67 68  abc', 'def', 'gh
6030: 69 27 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  i');.    INSERT 
6040: 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28 31  INTO t2 VALUES(1
6050: 30 2c 20 31 30 30 29 3b 0a 20 20 20 20 55 50 44  0, 100);.    UPD
6060: 41 54 45 20 74 31 20 53 45 54 20 61 20 3d 20 31  ATE t1 SET a = 1
6070: 35 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20  5;.    SELECT * 
6080: 46 52 4f 4d 20 74 32 3b 0a 20 20 7d 0a 7d 20 7b  FROM t2;.  }.} {
6090: 31 35 20 31 30 30 7d 0a 0a 23 2d 2d 2d 2d 2d 2d  15 100}..#------
60a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
60b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
60c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
60d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
60e0: 2d 2d 2d 0a 23 20 54 68 65 20 66 6f 6c 6c 6f 77  ---.# The follow
60f0: 69 6e 67 20 74 65 73 74 73 2c 20 66 6b 65 79 32  ing tests, fkey2
6100: 2d 31 32 2e 2a 2c 20 74 65 73 74 20 52 45 53 54  -12.*, test REST
6110: 52 49 43 54 20 61 63 74 69 6f 6e 73 2e 0a 23 0a  RICT actions..#.
6120: 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a  drop_all_tables.
6130: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 32  do_test fkey2-12
6140: 2e 31 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c  .1.1 {.  execsql
6150: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41   {.    CREATE TA
6160: 42 4c 45 20 74 31 28 61 2c 20 62 20 50 52 49 4d  BLE t1(a, b PRIM
6170: 41 52 59 20 4b 45 59 29 3b 0a 20 20 20 20 43 52  ARY KEY);.    CR
6180: 45 41 54 45 20 54 41 42 4c 45 20 74 32 28 0a 20  EATE TABLE t2(. 
6190: 20 20 20 20 20 78 20 52 45 46 45 52 45 4e 43 45       x REFERENCE
61a0: 53 20 74 31 20 4f 4e 20 55 50 44 41 54 45 20 52  S t1 ON UPDATE R
61b0: 45 53 54 52 49 43 54 20 44 45 46 45 52 52 41 42  ESTRICT DEFERRAB
61c0: 4c 45 20 49 4e 49 54 49 41 4c 4c 59 20 44 45 46  LE INITIALLY DEF
61d0: 45 52 52 45 44 20 0a 20 20 20 20 29 3b 0a 20 20  ERRED .    );.  
61e0: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31    INSERT INTO t1
61f0: 20 56 41 4c 55 45 53 28 31 2c 20 27 6f 6e 65 27   VALUES(1, 'one'
6200: 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  );.    INSERT IN
6210: 54 4f 20 74 31 20 56 41 4c 55 45 53 28 32 2c 20  TO t1 VALUES(2, 
6220: 27 74 77 6f 27 29 3b 0a 20 20 20 20 49 4e 53 45  'two');.    INSE
6230: 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45  RT INTO t1 VALUE
6240: 53 28 33 2c 20 27 74 68 72 65 65 27 29 3b 0a 20  S(3, 'three');. 
6250: 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20   }.} {}.do_test 
6260: 66 6b 65 79 32 2d 31 32 2e 31 2e 32 20 7b 20 0a  fkey2-12.1.2 { .
6270: 20 20 65 78 65 63 73 71 6c 20 22 42 45 47 49 4e    execsql "BEGIN
6280: 22 0a 20 20 65 78 65 63 73 71 6c 20 22 49 4e 53  ".  execsql "INS
6290: 45 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55  ERT INTO t2 VALU
62a0: 45 53 28 27 74 77 6f 27 29 22 0a 7d 20 7b 7d 0a  ES('two')".} {}.
62b0: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 32  do_test fkey2-12
62c0: 2e 31 2e 33 20 7b 20 0a 20 20 65 78 65 63 73 71  .1.3 { .  execsq
62d0: 6c 20 22 55 50 44 41 54 45 20 74 31 20 53 45 54  l "UPDATE t1 SET
62e0: 20 62 20 3d 20 27 66 6f 75 72 27 20 57 48 45 52   b = 'four' WHER
62f0: 45 20 62 20 3d 20 27 6f 6e 65 27 22 0a 7d 20 7b  E b = 'one'".} {
6300: 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d  }.do_test fkey2-
6310: 31 32 2e 31 2e 34 20 7b 20 0a 20 20 63 61 74 63  12.1.4 { .  catc
6320: 68 73 71 6c 20 22 55 50 44 41 54 45 20 74 31 20  hsql "UPDATE t1 
6330: 53 45 54 20 62 20 3d 20 27 66 69 76 65 27 20 57  SET b = 'five' W
6340: 48 45 52 45 20 62 20 3d 20 27 74 77 6f 27 22 0a  HERE b = 'two'".
6350: 7d 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45  } {1 {FOREIGN KE
6360: 59 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69  Y constraint fai
6370: 6c 65 64 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b  led}}.do_test fk
6380: 65 79 32 2d 31 32 2e 31 2e 35 20 7b 20 0a 20 20  ey2-12.1.5 { .  
6390: 65 78 65 63 73 71 6c 20 22 44 45 4c 45 54 45 20  execsql "DELETE 
63a0: 46 52 4f 4d 20 74 31 20 57 48 45 52 45 20 62 20  FROM t1 WHERE b 
63b0: 3d 20 27 74 77 6f 27 22 0a 7d 20 7b 7d 0a 64 6f  = 'two'".} {}.do
63c0: 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 32 2e 31  _test fkey2-12.1
63d0: 2e 36 20 7b 20 0a 20 20 63 61 74 63 68 73 71 6c  .6 { .  catchsql
63e0: 20 22 43 4f 4d 4d 49 54 22 0a 7d 20 7b 31 20 7b   "COMMIT".} {1 {
63f0: 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73  FOREIGN KEY cons
6400: 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a  traint failed}}.
6410: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 32  do_test fkey2-12
6420: 2e 31 2e 37 20 7b 20 0a 20 20 65 78 65 63 73 71  .1.7 { .  execsq
6430: 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  l {.    INSERT I
6440: 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 32 2c  NTO t1 VALUES(2,
6450: 20 27 74 77 6f 27 29 3b 0a 20 20 20 20 43 4f 4d   'two');.    COM
6460: 4d 49 54 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 0a 64  MIT;.  }.} {}..d
6470: 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a 64  rop_all_tables.d
6480: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 32 2e  o_test fkey2-12.
6490: 32 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  2.1 {.  execsql 
64a0: 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42  {.    CREATE TAB
64b0: 4c 45 20 74 31 28 78 20 43 4f 4c 4c 41 54 45 20  LE t1(x COLLATE 
64c0: 4e 4f 43 41 53 45 20 50 52 49 4d 41 52 59 20 4b  NOCASE PRIMARY K
64d0: 45 59 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20  EY);.    CREATE 
64e0: 54 52 49 47 47 45 52 20 74 74 31 20 41 46 54 45  TRIGGER tt1 AFTE
64f0: 52 20 44 45 4c 45 54 45 20 4f 4e 20 74 31 20 0a  R DELETE ON t1 .
6500: 20 20 20 20 20 20 57 48 45 4e 20 45 58 49 53 54        WHEN EXIST
6510: 53 20 28 20 53 45 4c 45 43 54 20 31 20 46 52 4f  S ( SELECT 1 FRO
6520: 4d 20 74 32 20 57 48 45 52 45 20 6f 6c 64 2e 78  M t2 WHERE old.x
6530: 20 3d 20 79 20 29 0a 20 20 20 20 42 45 47 49 4e   = y ).    BEGIN
6540: 0a 20 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e  .      INSERT IN
6550: 54 4f 20 74 31 20 56 41 4c 55 45 53 28 6f 6c 64  TO t1 VALUES(old
6560: 2e 78 29 3b 0a 20 20 20 20 45 4e 44 3b 0a 20 20  .x);.    END;.  
6570: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74    CREATE TABLE t
6580: 32 28 79 20 52 45 46 45 52 45 4e 43 45 53 20 74  2(y REFERENCES t
6590: 31 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  1);.    INSERT I
65a0: 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 27 41  NTO t1 VALUES('A
65b0: 27 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  ');.    INSERT I
65c0: 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 27 42  NTO t1 VALUES('B
65d0: 27 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  ');.    INSERT I
65e0: 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28 27 61  NTO t2 VALUES('a
65f0: 27 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  ');.    INSERT I
6600: 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28 27 62  NTO t2 VALUES('b
6610: 27 29 3b 0a 0a 20 20 20 20 53 45 4c 45 43 54 20  ');..    SELECT 
6620: 2a 20 46 52 4f 4d 20 74 31 3b 0a 20 20 20 20 53  * FROM t1;.    S
6630: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 32 3b  ELECT * FROM t2;
6640: 0a 20 20 7d 0a 7d 20 7b 41 20 42 20 61 20 62 7d  .  }.} {A B a b}
6650: 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31  .do_test fkey2-1
6660: 32 2e 32 2e 32 20 7b 0a 20 20 65 78 65 63 73 71  2.2.2 {.  execsq
6670: 6c 20 7b 20 44 45 4c 45 54 45 20 46 52 4f 4d 20  l { DELETE FROM 
6680: 74 31 20 7d 0a 20 20 65 78 65 63 73 71 6c 20 7b  t1 }.  execsql {
6690: 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52  .    SELECT * FR
66a0: 4f 4d 20 74 31 3b 0a 20 20 20 20 53 45 4c 45 43  OM t1;.    SELEC
66b0: 54 20 2a 20 46 52 4f 4d 20 74 32 3b 0a 20 20 7d  T * FROM t2;.  }
66c0: 0a 7d 20 7b 41 20 42 20 61 20 62 7d 0a 64 6f 5f  .} {A B a b}.do_
66d0: 74 65 73 74 20 66 6b 65 79 32 2d 31 32 2e 32 2e  test fkey2-12.2.
66e0: 33 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  3 {.  execsql {.
66f0: 20 20 20 20 44 52 4f 50 20 54 41 42 4c 45 20 74      DROP TABLE t
6700: 32 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41  2;.    CREATE TA
6710: 42 4c 45 20 74 32 28 79 20 52 45 46 45 52 45 4e  BLE t2(y REFEREN
6720: 43 45 53 20 74 31 20 4f 4e 20 44 45 4c 45 54 45  CES t1 ON DELETE
6730: 20 52 45 53 54 52 49 43 54 29 3b 0a 20 20 20 20   RESTRICT);.    
6740: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 20 56  INSERT INTO t2 V
6750: 41 4c 55 45 53 28 27 61 27 29 3b 0a 20 20 20 20  ALUES('a');.    
6760: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 20 56  INSERT INTO t2 V
6770: 41 4c 55 45 53 28 27 62 27 29 3b 0a 20 20 7d 0a  ALUES('b');.  }.
6780: 20 20 63 61 74 63 68 73 71 6c 20 7b 20 44 45 4c    catchsql { DEL
6790: 45 54 45 20 46 52 4f 4d 20 74 31 20 7d 0a 7d 20  ETE FROM t1 }.} 
67a0: 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20  {1 {FOREIGN KEY 
67b0: 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65  constraint faile
67c0: 64 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79  d}}.do_test fkey
67d0: 32 2d 31 32 2e 32 2e 34 20 7b 0a 20 20 65 78 65  2-12.2.4 {.  exe
67e0: 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43  csql {.    SELEC
67f0: 54 20 2a 20 46 52 4f 4d 20 74 31 3b 0a 20 20 20  T * FROM t1;.   
6800: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
6810: 32 3b 0a 20 20 7d 0a 7d 20 7b 41 20 42 20 61 20  2;.  }.} {A B a 
6820: 62 7d 0a 0a 64 72 6f 70 5f 61 6c 6c 5f 74 61 62  b}..drop_all_tab
6830: 6c 65 73 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79  les.do_test fkey
6840: 32 2d 31 32 2e 33 2e 31 20 7b 0a 20 20 65 78 65  2-12.3.1 {.  exe
6850: 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54  csql {.    CREAT
6860: 45 20 54 41 42 4c 45 20 75 70 28 0a 20 20 20 20  E TABLE up(.    
6870: 20 20 63 30 30 2c 20 63 30 31 2c 20 63 30 32 2c    c00, c01, c02,
6880: 20 63 30 33 2c 20 63 30 34 2c 20 63 30 35 2c 20   c03, c04, c05, 
6890: 63 30 36 2c 20 63 30 37 2c 20 63 30 38 2c 20 63  c06, c07, c08, c
68a0: 30 39 2c 0a 20 20 20 20 20 20 63 31 30 2c 20 63  09,.      c10, c
68b0: 31 31 2c 20 63 31 32 2c 20 63 31 33 2c 20 63 31  11, c12, c13, c1
68c0: 34 2c 20 63 31 35 2c 20 63 31 36 2c 20 63 31 37  4, c15, c16, c17
68d0: 2c 20 63 31 38 2c 20 63 31 39 2c 0a 20 20 20 20  , c18, c19,.    
68e0: 20 20 63 32 30 2c 20 63 32 31 2c 20 63 32 32 2c    c20, c21, c22,
68f0: 20 63 32 33 2c 20 63 32 34 2c 20 63 32 35 2c 20   c23, c24, c25, 
6900: 63 32 36 2c 20 63 32 37 2c 20 63 32 38 2c 20 63  c26, c27, c28, c
6910: 32 39 2c 0a 20 20 20 20 20 20 63 33 30 2c 20 63  29,.      c30, c
6920: 33 31 2c 20 63 33 32 2c 20 63 33 33 2c 20 63 33  31, c32, c33, c3
6930: 34 2c 20 63 33 35 2c 20 63 33 36 2c 20 63 33 37  4, c35, c36, c37
6940: 2c 20 63 33 38 2c 20 63 33 39 2c 0a 20 20 20 20  , c38, c39,.    
6950: 20 20 50 52 49 4d 41 52 59 20 4b 45 59 28 63 33    PRIMARY KEY(c3
6960: 34 2c 20 63 33 35 29 0a 20 20 20 20 29 3b 0a 20  4, c35).    );. 
6970: 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20     CREATE TABLE 
6980: 64 6f 77 6e 28 0a 20 20 20 20 20 20 63 30 30 2c  down(.      c00,
6990: 20 63 30 31 2c 20 63 30 32 2c 20 63 30 33 2c 20   c01, c02, c03, 
69a0: 63 30 34 2c 20 63 30 35 2c 20 63 30 36 2c 20 63  c04, c05, c06, c
69b0: 30 37 2c 20 63 30 38 2c 20 63 30 39 2c 0a 20 20  07, c08, c09,.  
69c0: 20 20 20 20 63 31 30 2c 20 63 31 31 2c 20 63 31      c10, c11, c1
69d0: 32 2c 20 63 31 33 2c 20 63 31 34 2c 20 63 31 35  2, c13, c14, c15
69e0: 2c 20 63 31 36 2c 20 63 31 37 2c 20 63 31 38 2c  , c16, c17, c18,
69f0: 20 63 31 39 2c 0a 20 20 20 20 20 20 63 32 30 2c   c19,.      c20,
6a00: 20 63 32 31 2c 20 63 32 32 2c 20 63 32 33 2c 20   c21, c22, c23, 
6a10: 63 32 34 2c 20 63 32 35 2c 20 63 32 36 2c 20 63  c24, c25, c26, c
6a20: 32 37 2c 20 63 32 38 2c 20 63 32 39 2c 0a 20 20  27, c28, c29,.  
6a30: 20 20 20 20 63 33 30 2c 20 63 33 31 2c 20 63 33      c30, c31, c3
6a40: 32 2c 20 63 33 33 2c 20 63 33 34 2c 20 63 33 35  2, c33, c34, c35
6a50: 2c 20 63 33 36 2c 20 63 33 37 2c 20 63 33 38 2c  , c36, c37, c38,
6a60: 20 63 33 39 2c 0a 20 20 20 20 20 20 46 4f 52 45   c39,.      FORE
6a70: 49 47 4e 20 4b 45 59 28 63 33 39 2c 20 63 33 38  IGN KEY(c39, c38
6a80: 29 20 52 45 46 45 52 45 4e 43 45 53 20 75 70 20  ) REFERENCES up 
6a90: 4f 4e 20 55 50 44 41 54 45 20 43 41 53 43 41 44  ON UPDATE CASCAD
6aa0: 45 0a 20 20 20 20 29 3b 0a 20 20 7d 0a 7d 20 7b  E.    );.  }.} {
6ab0: 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d  }.do_test fkey2-
6ac0: 31 32 2e 33 2e 32 20 7b 0a 20 20 65 78 65 63 73  12.3.2 {.  execs
6ad0: 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52 54 20  ql {.    INSERT 
6ae0: 49 4e 54 4f 20 75 70 28 63 33 34 2c 20 63 33 35  INTO up(c34, c35
6af0: 29 20 56 41 4c 55 45 53 28 27 79 65 73 27 2c 20  ) VALUES('yes', 
6b00: 27 6e 6f 27 29 3b 0a 20 20 20 20 49 4e 53 45 52  'no');.    INSER
6b10: 54 20 49 4e 54 4f 20 64 6f 77 6e 28 63 33 39 2c  T INTO down(c39,
6b20: 20 63 33 38 29 20 56 41 4c 55 45 53 28 27 79 65   c38) VALUES('ye
6b30: 73 27 2c 20 27 6e 6f 27 29 3b 0a 20 20 20 20 55  s', 'no');.    U
6b40: 50 44 41 54 45 20 75 70 20 53 45 54 20 63 33 34  PDATE up SET c34
6b50: 20 3d 20 27 70 6f 73 73 69 62 6c 79 27 3b 0a 20   = 'possibly';. 
6b60: 20 20 20 53 45 4c 45 43 54 20 63 33 38 2c 20 63     SELECT c38, c
6b70: 33 39 20 46 52 4f 4d 20 64 6f 77 6e 3b 0a 20 20  39 FROM down;.  
6b80: 20 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 64 6f    DELETE FROM do
6b90: 77 6e 3b 0a 20 20 7d 0a 7d 20 7b 6e 6f 20 70 6f  wn;.  }.} {no po
6ba0: 73 73 69 62 6c 79 7d 0a 64 6f 5f 74 65 73 74 20  ssibly}.do_test 
6bb0: 66 6b 65 79 32 2d 31 32 2e 33 2e 33 20 7b 0a 20  fkey2-12.3.3 {. 
6bc0: 20 63 61 74 63 68 73 71 6c 20 7b 20 49 4e 53 45   catchsql { INSE
6bd0: 52 54 20 49 4e 54 4f 20 64 6f 77 6e 28 63 33 39  RT INTO down(c39
6be0: 2c 20 63 33 38 29 20 56 41 4c 55 45 53 28 27 79  , c38) VALUES('y
6bf0: 65 73 27 2c 20 27 6e 6f 27 29 20 7d 0a 7d 20 7b  es', 'no') }.} {
6c00: 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20 63  1 {FOREIGN KEY c
6c10: 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64  onstraint failed
6c20: 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  }}.do_test fkey2
6c30: 2d 31 32 2e 33 2e 34 20 7b 0a 20 20 65 78 65 63  -12.3.4 {.  exec
6c40: 73 71 6c 20 7b 20 0a 20 20 20 20 49 4e 53 45 52  sql { .    INSER
6c50: 54 20 49 4e 54 4f 20 75 70 28 63 33 34 2c 20 63  T INTO up(c34, c
6c60: 33 35 29 20 56 41 4c 55 45 53 28 27 79 65 73 27  35) VALUES('yes'
6c70: 2c 20 27 6e 6f 27 29 3b 0a 20 20 20 20 49 4e 53  , 'no');.    INS
6c80: 45 52 54 20 49 4e 54 4f 20 64 6f 77 6e 28 63 33  ERT INTO down(c3
6c90: 39 2c 20 63 33 38 29 20 56 41 4c 55 45 53 28 27  9, c38) VALUES('
6ca0: 79 65 73 27 2c 20 27 6e 6f 27 29 3b 0a 20 20 7d  yes', 'no');.  }
6cb0: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 20 44 45  .  catchsql { DE
6cc0: 4c 45 54 45 20 46 52 4f 4d 20 75 70 20 57 48 45  LETE FROM up WHE
6cd0: 52 45 20 63 33 34 20 3d 20 27 79 65 73 27 20 7d  RE c34 = 'yes' }
6ce0: 0a 7d 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b  .} {1 {FOREIGN K
6cf0: 45 59 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61  EY constraint fa
6d00: 69 6c 65 64 7d 7d 0a 64 6f 5f 74 65 73 74 20 66  iled}}.do_test f
6d10: 6b 65 79 32 2d 31 32 2e 33 2e 35 20 7b 0a 20 20  key2-12.3.5 {.  
6d20: 65 78 65 63 73 71 6c 20 7b 20 0a 20 20 20 20 44  execsql { .    D
6d30: 45 4c 45 54 45 20 46 52 4f 4d 20 75 70 20 57 48  ELETE FROM up WH
6d40: 45 52 45 20 63 33 34 20 3d 20 27 70 6f 73 73 69  ERE c34 = 'possi
6d50: 62 6c 79 27 3b 0a 20 20 20 20 53 45 4c 45 43 54  bly';.    SELECT
6d60: 20 63 33 34 2c 20 63 33 35 20 46 52 4f 4d 20 75   c34, c35 FROM u
6d70: 70 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 63 33  p;.    SELECT c3
6d80: 39 2c 20 63 33 38 20 46 52 4f 4d 20 64 6f 77 6e  9, c38 FROM down
6d90: 3b 0a 20 20 7d 0a 7d 20 7b 79 65 73 20 6e 6f 20  ;.  }.} {yes no 
6da0: 79 65 73 20 6e 6f 7d 0a 0a 23 2d 2d 2d 2d 2d 2d  yes no}..#------
6db0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6dc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6dd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6de0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6df0: 2d 2d 2d 0a 23 20 54 68 65 20 66 6f 6c 6c 6f 77  ---.# The follow
6e00: 69 6e 67 20 74 65 73 74 73 2c 20 66 6b 65 79 32  ing tests, fkey2
6e10: 2d 31 33 2e 2a 2c 20 74 65 73 74 20 74 68 61 74  -13.*, test that
6e20: 20 46 4b 20 70 72 6f 63 65 73 73 69 6e 67 20 69   FK processing i
6e30: 73 20 70 65 72 66 6f 72 6d 65 64 0a 23 20 77 68  s performed.# wh
6e40: 65 6e 20 72 6f 77 73 20 61 72 65 20 52 45 50 4c  en rows are REPL
6e50: 41 43 45 64 2e 0a 23 0a 64 72 6f 70 5f 61 6c 6c  ACEd..#.drop_all
6e60: 5f 74 61 62 6c 65 73 0a 64 6f 5f 74 65 73 74 20  _tables.do_test 
6e70: 66 6b 65 79 32 2d 31 33 2e 31 2e 31 20 7b 0a 20  fkey2-13.1.1 {. 
6e80: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43   execsql {.    C
6e90: 52 45 41 54 45 20 54 41 42 4c 45 20 70 70 28 61  REATE TABLE pp(a
6ea0: 20 55 4e 49 51 55 45 2c 20 62 2c 20 63 2c 20 50   UNIQUE, b, c, P
6eb0: 52 49 4d 41 52 59 20 4b 45 59 28 62 2c 20 63 29  RIMARY KEY(b, c)
6ec0: 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41  );.    CREATE TA
6ed0: 42 4c 45 20 63 63 28 64 2c 20 65 2c 20 66 20 55  BLE cc(d, e, f U
6ee0: 4e 49 51 55 45 2c 20 46 4f 52 45 49 47 4e 20 4b  NIQUE, FOREIGN K
6ef0: 45 59 28 64 2c 20 65 29 20 52 45 46 45 52 45 4e  EY(d, e) REFEREN
6f00: 43 45 53 20 70 70 29 3b 0a 20 20 20 20 49 4e 53  CES pp);.    INS
6f10: 45 52 54 20 49 4e 54 4f 20 70 70 20 56 41 4c 55  ERT INTO pp VALU
6f20: 45 53 28 31 2c 20 32 2c 20 33 29 3b 0a 20 20 20  ES(1, 2, 3);.   
6f30: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 63 63 20   INSERT INTO cc 
6f40: 56 41 4c 55 45 53 28 32 2c 20 33 2c 20 31 29 3b  VALUES(2, 3, 1);
6f50: 0a 20 20 7d 0a 7d 20 7b 7d 0a 66 6f 72 65 61 63  .  }.} {}.foreac
6f60: 68 20 7b 74 6e 20 73 74 6d 74 7d 20 7b 0a 20 20  h {tn stmt} {.  
6f70: 31 20 20 20 22 52 45 50 4c 41 43 45 20 49 4e 54  1   "REPLACE INT
6f80: 4f 20 70 70 20 56 41 4c 55 45 53 28 31 2c 20 34  O pp VALUES(1, 4
6f90: 2c 20 35 29 22 0a 20 20 32 20 20 20 22 52 45 50  , 5)".  2   "REP
6fa0: 4c 41 43 45 20 49 4e 54 4f 20 70 70 28 72 6f 77  LACE INTO pp(row
6fb0: 69 64 2c 20 61 2c 20 62 2c 20 63 29 20 56 41 4c  id, a, b, c) VAL
6fc0: 55 45 53 28 31 2c 20 32 2c 20 33 2c 20 34 29 22  UES(1, 2, 3, 4)"
6fd0: 0a 7d 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20 66  .} {.  do_test f
6fe0: 6b 65 79 32 2d 31 33 2e 31 2e 24 74 6e 2e 31 20  key2-13.1.$tn.1 
6ff0: 7b 0a 20 20 20 20 63 61 74 63 68 73 71 6c 20 24  {.    catchsql $
7000: 73 74 6d 74 0a 20 20 7d 20 7b 31 20 7b 46 4f 52  stmt.  } {1 {FOR
7010: 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73 74 72 61  EIGN KEY constra
7020: 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 20 20 64  int failed}}.  d
7030: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 33 2e  o_test fkey2-13.
7040: 31 2e 24 74 6e 2e 32 20 7b 0a 20 20 20 20 65 78  1.$tn.2 {.    ex
7050: 65 63 73 71 6c 20 7b 0a 20 20 20 20 20 20 53 45  ecsql {.      SE
7060: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 70 70 3b 0a  LECT * FROM pp;.
7070: 20 20 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46        SELECT * F
7080: 52 4f 4d 20 63 63 3b 0a 20 20 20 20 7d 0a 20 20  ROM cc;.    }.  
7090: 7d 20 7b 31 20 32 20 33 20 32 20 33 20 31 7d 0a  } {1 2 3 2 3 1}.
70a0: 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d    do_test fkey2-
70b0: 31 33 2e 31 2e 24 74 6e 2e 33 20 7b 0a 20 20 20  13.1.$tn.3 {.   
70c0: 20 65 78 65 63 73 71 6c 20 42 45 47 49 4e 3b 0a   execsql BEGIN;.
70d0: 20 20 20 20 63 61 74 63 68 73 71 6c 20 24 73 74      catchsql $st
70e0: 6d 74 0a 20 20 7d 20 7b 31 20 7b 46 4f 52 45 49  mt.  } {1 {FOREI
70f0: 47 4e 20 4b 45 59 20 63 6f 6e 73 74 72 61 69 6e  GN KEY constrain
7100: 74 20 66 61 69 6c 65 64 7d 7d 0a 20 20 64 6f 5f  t failed}}.  do_
7110: 74 65 73 74 20 66 6b 65 79 32 2d 31 33 2e 31 2e  test fkey2-13.1.
7120: 24 74 6e 2e 34 20 7b 0a 20 20 20 20 65 78 65 63  $tn.4 {.    exec
7130: 73 71 6c 20 7b 0a 20 20 20 20 20 20 43 4f 4d 4d  sql {.      COMM
7140: 49 54 3b 0a 20 20 20 20 20 20 53 45 4c 45 43 54  IT;.      SELECT
7150: 20 2a 20 46 52 4f 4d 20 70 70 3b 0a 20 20 20 20   * FROM pp;.    
7160: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
7170: 63 63 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 31  cc;.    }.  } {1
7180: 20 32 20 33 20 32 20 33 20 31 7d 0a 7d 0a 64 6f   2 3 2 3 1}.}.do
7190: 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 33 2e 31  _test fkey2-13.1
71a0: 2e 33 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .3 {.  execsql {
71b0: 20 0a 20 20 20 20 52 45 50 4c 41 43 45 20 49 4e   .    REPLACE IN
71c0: 54 4f 20 70 70 28 72 6f 77 69 64 2c 20 61 2c 20  TO pp(rowid, a, 
71d0: 62 2c 20 63 29 20 56 41 4c 55 45 53 28 31 2c 20  b, c) VALUES(1, 
71e0: 32 2c 20 32 2c 20 33 29 3b 0a 20 20 20 20 53 45  2, 2, 3);.    SE
71f0: 4c 45 43 54 20 72 6f 77 69 64 2c 20 2a 20 46 52  LECT rowid, * FR
7200: 4f 4d 20 70 70 3b 0a 20 20 20 20 53 45 4c 45 43  OM pp;.    SELEC
7210: 54 20 2a 20 46 52 4f 4d 20 63 63 3b 0a 20 20 7d  T * FROM cc;.  }
7220: 0a 7d 20 7b 31 20 32 20 32 20 33 20 32 20 33 20  .} {1 2 2 3 2 3 
7230: 31 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  1}.do_test fkey2
7240: 2d 31 33 2e 31 2e 34 20 7b 0a 20 20 65 78 65 63  -13.1.4 {.  exec
7250: 73 71 6c 20 7b 20 0a 20 20 20 20 52 45 50 4c 41  sql { .    REPLA
7260: 43 45 20 49 4e 54 4f 20 70 70 28 72 6f 77 69 64  CE INTO pp(rowid
7270: 2c 20 61 2c 20 62 2c 20 63 29 20 56 41 4c 55 45  , a, b, c) VALUE
7280: 53 28 32 2c 20 32 2c 20 32 2c 20 33 29 3b 0a 20  S(2, 2, 2, 3);. 
7290: 20 20 20 53 45 4c 45 43 54 20 72 6f 77 69 64 2c     SELECT rowid,
72a0: 20 2a 20 46 52 4f 4d 20 70 70 3b 0a 20 20 20 20   * FROM pp;.    
72b0: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 63 63  SELECT * FROM cc
72c0: 3b 0a 20 20 7d 0a 7d 20 7b 32 20 32 20 32 20 33  ;.  }.} {2 2 2 3
72d0: 20 32 20 33 20 31 7d 0a 0a 23 2d 2d 2d 2d 2d 2d   2 3 1}..#------
72e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
72f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
7300: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
7310: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
7320: 2d 2d 2d 0a 23 20 54 68 65 20 66 6f 6c 6c 6f 77  ---.# The follow
7330: 69 6e 67 20 74 65 73 74 73 2c 20 66 6b 65 79 32  ing tests, fkey2
7340: 2d 31 34 2e 2a 2c 20 74 65 73 74 20 74 68 61 74  -14.*, test that
7350: 20 74 68 65 20 22 44 52 4f 50 20 54 41 42 4c 45   the "DROP TABLE
7360: 22 20 61 6e 64 20 22 41 4c 54 45 52 0a 23 20 54  " and "ALTER.# T
7370: 41 42 4c 45 22 20 63 6f 6d 6d 61 6e 64 73 20 77  ABLE" commands w
7380: 6f 72 6b 20 61 73 20 65 78 70 65 63 74 65 64 20  ork as expected 
7390: 77 72 74 20 66 6f 72 65 69 67 6e 20 6b 65 79 20  wrt foreign key 
73a0: 63 6f 6e 73 74 72 61 69 6e 74 73 2e 0a 23 0a 23  constraints..#.#
73b0: 20 66 6b 65 79 32 2d 31 34 2e 31 2a 3a 20 41 4c   fkey2-14.1*: AL
73c0: 54 45 52 20 54 41 42 4c 45 20 41 44 44 20 43 4f  TER TABLE ADD CO
73d0: 4c 55 4d 4e 0a 23 20 66 6b 65 79 32 2d 31 34 2e  LUMN.# fkey2-14.
73e0: 32 2a 3a 20 41 4c 54 45 52 20 54 41 42 4c 45 20  2*: ALTER TABLE 
73f0: 52 45 4e 41 4d 45 20 54 41 42 4c 45 0a 23 20 66  RENAME TABLE.# f
7400: 6b 65 79 32 2d 31 34 2e 33 2a 3a 20 44 52 4f 50  key2-14.3*: DROP
7410: 20 54 41 42 4c 45 0a 23 0a 64 72 6f 70 5f 61 6c   TABLE.#.drop_al
7420: 6c 5f 74 61 62 6c 65 73 0a 69 66 63 61 70 61 62  l_tables.ifcapab
7430: 6c 65 20 61 6c 74 65 72 74 61 62 6c 65 20 7b 0a  le altertable {.
7440: 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d    do_test fkey2-
7450: 31 34 2e 31 2e 31 20 7b 0a 20 20 20 20 23 20 41  14.1.1 {.    # A
7460: 64 64 69 6e 67 20 61 20 63 6f 6c 75 6d 6e 20 77  dding a column w
7470: 69 74 68 20 61 20 52 45 46 45 52 45 4e 43 45 53  ith a REFERENCES
7480: 20 63 6c 61 75 73 65 20 69 73 20 6e 6f 74 20 73   clause is not s
7490: 75 70 70 6f 72 74 65 64 2e 0a 20 20 20 20 65 78  upported..    ex
74a0: 65 63 73 71 6c 20 7b 20 0a 20 20 20 20 20 20 43  ecsql { .      C
74b0: 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 61  REATE TABLE t1(a
74c0: 20 50 52 49 4d 41 52 59 20 4b 45 59 29 3b 0a 20   PRIMARY KEY);. 
74d0: 20 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c       CREATE TABL
74e0: 45 20 74 32 28 61 2c 20 62 29 3b 0a 20 20 20 20  E t2(a, b);.    
74f0: 7d 0a 20 20 20 20 63 61 74 63 68 73 71 6c 20 7b  }.    catchsql {
7500: 20 41 4c 54 45 52 20 54 41 42 4c 45 20 74 32 20   ALTER TABLE t2 
7510: 41 44 44 20 43 4f 4c 55 4d 4e 20 63 20 52 45 46  ADD COLUMN c REF
7520: 45 52 45 4e 43 45 53 20 74 31 20 7d 0a 20 20 7d  ERENCES t1 }.  }
7530: 20 7b 30 20 7b 7d 7d 0a 20 20 64 6f 5f 74 65 73   {0 {}}.  do_tes
7540: 74 20 66 6b 65 79 32 2d 31 34 2e 31 2e 32 20 7b  t fkey2-14.1.2 {
7550: 0a 20 20 20 20 63 61 74 63 68 73 71 6c 20 7b 20  .    catchsql { 
7560: 41 4c 54 45 52 20 54 41 42 4c 45 20 74 32 20 41  ALTER TABLE t2 A
7570: 44 44 20 43 4f 4c 55 4d 4e 20 64 20 44 45 46 41  DD COLUMN d DEFA
7580: 55 4c 54 20 4e 55 4c 4c 20 52 45 46 45 52 45 4e  ULT NULL REFEREN
7590: 43 45 53 20 74 31 20 7d 0a 20 20 7d 20 7b 30 20  CES t1 }.  } {0 
75a0: 7b 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b  {}}.  do_test fk
75b0: 65 79 32 2d 31 34 2e 31 2e 33 20 7b 0a 20 20 20  ey2-14.1.3 {.   
75c0: 20 63 61 74 63 68 73 71 6c 20 7b 20 41 4c 54 45   catchsql { ALTE
75d0: 52 20 54 41 42 4c 45 20 74 32 20 41 44 44 20 43  R TABLE t2 ADD C
75e0: 4f 4c 55 4d 4e 20 65 20 52 45 46 45 52 45 4e 43  OLUMN e REFERENC
75f0: 45 53 20 74 31 20 44 45 46 41 55 4c 54 20 4e 55  ES t1 DEFAULT NU
7600: 4c 4c 7d 0a 20 20 7d 20 7b 30 20 7b 7d 7d 0a 20  LL}.  } {0 {}}. 
7610: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31   do_test fkey2-1
7620: 34 2e 31 2e 34 20 7b 0a 20 20 20 20 63 61 74 63  4.1.4 {.    catc
7630: 68 73 71 6c 20 7b 20 41 4c 54 45 52 20 54 41 42  hsql { ALTER TAB
7640: 4c 45 20 74 32 20 41 44 44 20 43 4f 4c 55 4d 4e  LE t2 ADD COLUMN
7650: 20 66 20 52 45 46 45 52 45 4e 43 45 53 20 74 31   f REFERENCES t1
7660: 20 44 45 46 41 55 4c 54 20 27 74 65 78 74 27 7d   DEFAULT 'text'}
7670: 0a 20 20 7d 20 7b 31 20 7b 43 61 6e 6e 6f 74 20  .  } {1 {Cannot 
7680: 61 64 64 20 61 20 52 45 46 45 52 45 4e 43 45 53  add a REFERENCES
7690: 20 63 6f 6c 75 6d 6e 20 77 69 74 68 20 6e 6f 6e   column with non
76a0: 2d 4e 55 4c 4c 20 64 65 66 61 75 6c 74 20 76 61  -NULL default va
76b0: 6c 75 65 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20  lue}}.  do_test 
76c0: 66 6b 65 79 32 2d 31 34 2e 31 2e 35 20 7b 0a 20  fkey2-14.1.5 {. 
76d0: 20 20 20 63 61 74 63 68 73 71 6c 20 7b 20 41 4c     catchsql { AL
76e0: 54 45 52 20 54 41 42 4c 45 20 74 32 20 41 44 44  TER TABLE t2 ADD
76f0: 20 43 4f 4c 55 4d 4e 20 67 20 44 45 46 41 55 4c   COLUMN g DEFAUL
7700: 54 20 43 55 52 52 45 4e 54 5f 54 49 4d 45 20 52  T CURRENT_TIME R
7710: 45 46 45 52 45 4e 43 45 53 20 74 31 20 7d 0a 20  EFERENCES t1 }. 
7720: 20 7d 20 7b 31 20 7b 43 61 6e 6e 6f 74 20 61 64   } {1 {Cannot ad
7730: 64 20 61 20 52 45 46 45 52 45 4e 43 45 53 20 63  d a REFERENCES c
7740: 6f 6c 75 6d 6e 20 77 69 74 68 20 6e 6f 6e 2d 4e  olumn with non-N
7750: 55 4c 4c 20 64 65 66 61 75 6c 74 20 76 61 6c 75  ULL default valu
7760: 65 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b  e}}.  do_test fk
7770: 65 79 32 2d 31 34 2e 31 2e 36 20 7b 0a 20 20 20  ey2-14.1.6 {.   
7780: 20 65 78 65 63 73 71 6c 20 7b 20 0a 20 20 20 20   execsql { .    
7790: 20 20 50 52 41 47 4d 41 20 66 6f 72 65 69 67 6e    PRAGMA foreign
77a0: 5f 6b 65 79 73 20 3d 20 6f 66 66 3b 0a 20 20 20  _keys = off;.   
77b0: 20 20 20 41 4c 54 45 52 20 54 41 42 4c 45 20 74     ALTER TABLE t
77c0: 32 20 41 44 44 20 43 4f 4c 55 4d 4e 20 68 20 44  2 ADD COLUMN h D
77d0: 45 46 41 55 4c 54 20 27 74 65 78 74 27 20 52 45  EFAULT 'text' RE
77e0: 46 45 52 45 4e 43 45 53 20 74 31 3b 0a 20 20 20  FERENCES t1;.   
77f0: 20 20 20 50 52 41 47 4d 41 20 66 6f 72 65 69 67     PRAGMA foreig
7800: 6e 5f 6b 65 79 73 20 3d 20 6f 6e 3b 0a 20 20 20  n_keys = on;.   
7810: 20 20 20 53 45 4c 45 43 54 20 73 71 6c 20 46 52     SELECT sql FR
7820: 4f 4d 20 73 71 6c 69 74 65 5f 6d 61 73 74 65 72  OM sqlite_master
7830: 20 57 48 45 52 45 20 6e 61 6d 65 3d 27 74 32 27   WHERE name='t2'
7840: 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 7b 43 52  ;.    }.  } {{CR
7850: 45 41 54 45 20 54 41 42 4c 45 20 74 32 28 61 2c  EATE TABLE t2(a,
7860: 20 62 2c 20 63 20 52 45 46 45 52 45 4e 43 45 53   b, c REFERENCES
7870: 20 74 31 2c 20 64 20 44 45 46 41 55 4c 54 20 4e   t1, d DEFAULT N
7880: 55 4c 4c 20 52 45 46 45 52 45 4e 43 45 53 20 74  ULL REFERENCES t
7890: 31 2c 20 65 20 52 45 46 45 52 45 4e 43 45 53 20  1, e REFERENCES 
78a0: 74 31 20 44 45 46 41 55 4c 54 20 4e 55 4c 4c 2c  t1 DEFAULT NULL,
78b0: 20 68 20 44 45 46 41 55 4c 54 20 27 74 65 78 74   h DEFAULT 'text
78c0: 27 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 29  ' REFERENCES t1)
78d0: 7d 7d 0a 20 20 0a 20 20 0a 20 20 23 20 54 65 73  }}.  .  .  # Tes
78e0: 74 20 74 68 65 20 73 71 6c 69 74 65 5f 72 65 6e  t the sqlite_ren
78f0: 61 6d 65 5f 70 61 72 65 6e 74 28 29 20 66 75 6e  ame_parent() fun
7900: 63 74 69 6f 6e 20 64 69 72 65 63 74 6c 79 2e 0a  ction directly..
7910: 20 20 23 0a 20 20 70 72 6f 63 20 74 65 73 74 5f    #.  proc test_
7920: 72 65 6e 61 6d 65 5f 70 61 72 65 6e 74 20 7b 7a  rename_parent {z
7930: 43 72 65 61 74 65 20 7a 4f 6c 64 20 7a 4e 65 77  Create zOld zNew
7940: 7d 20 7b 0a 20 20 20 20 64 62 20 65 76 61 6c 20  } {.    db eval 
7950: 7b 53 45 4c 45 43 54 20 73 71 6c 69 74 65 5f 72  {SELECT sqlite_r
7960: 65 6e 61 6d 65 5f 74 61 62 6c 65 28 0a 20 20 20  ename_table(.   
7970: 20 20 20 20 20 27 6d 61 69 6e 27 2c 20 27 74 61       'main', 'ta
7980: 62 6c 65 27 2c 20 27 74 31 27 2c 20 24 7a 43 72  ble', 't1', $zCr
7990: 65 61 74 65 2c 20 24 7a 4f 6c 64 2c 20 24 7a 4e  eate, $zOld, $zN
79a0: 65 77 2c 20 30 0a 20 20 20 20 29 7d 0a 20 20 7d  ew, 0.    )}.  }
79b0: 0a 20 20 73 71 6c 69 74 65 33 5f 74 65 73 74 5f  .  sqlite3_test_
79c0: 63 6f 6e 74 72 6f 6c 20 53 51 4c 49 54 45 5f 54  control SQLITE_T
79d0: 45 53 54 43 54 52 4c 5f 49 4e 54 45 52 4e 41 4c  ESTCTRL_INTERNAL
79e0: 5f 46 55 4e 43 54 49 4f 4e 53 20 31 0a 20 20 64  _FUNCTIONS 1.  d
79f0: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 34 2e  o_test fkey2-14.
7a00: 32 2e 31 2e 31 20 7b 0a 20 20 20 20 74 65 73 74  2.1.1 {.    test
7a10: 5f 72 65 6e 61 6d 65 5f 70 61 72 65 6e 74 20 7b  _rename_parent {
7a20: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28  CREATE TABLE t1(
7a30: 61 20 52 45 46 45 52 45 4e 43 45 53 20 74 32 29  a REFERENCES t2)
7a40: 7d 20 74 32 20 74 33 0a 20 20 7d 20 7b 7b 43 52  } t2 t3.  } {{CR
7a50: 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 61 20  EATE TABLE t1(a 
7a60: 52 45 46 45 52 45 4e 43 45 53 20 22 74 33 22 29  REFERENCES "t3")
7a70: 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65  }}.  do_test fke
7a80: 79 32 2d 31 34 2e 32 2e 31 2e 32 20 7b 0a 20 20  y2-14.2.1.2 {.  
7a90: 20 20 74 65 73 74 5f 72 65 6e 61 6d 65 5f 70 61    test_rename_pa
7aa0: 72 65 6e 74 20 7b 43 52 45 41 54 45 20 54 41 42  rent {CREATE TAB
7ab0: 4c 45 20 74 31 28 61 20 52 45 46 45 52 45 4e 43  LE t1(a REFERENC
7ac0: 45 53 20 74 32 29 7d 20 74 34 20 74 33 0a 20 20  ES t2)} t4 t3.  
7ad0: 7d 20 7b 7b 43 52 45 41 54 45 20 54 41 42 4c 45  } {{CREATE TABLE
7ae0: 20 74 31 28 61 20 52 45 46 45 52 45 4e 43 45 53   t1(a REFERENCES
7af0: 20 74 32 29 7d 7d 0a 20 20 64 6f 5f 74 65 73 74   t2)}}.  do_test
7b00: 20 66 6b 65 79 32 2d 31 34 2e 32 2e 31 2e 33 20   fkey2-14.2.1.3 
7b10: 7b 0a 20 20 20 20 74 65 73 74 5f 72 65 6e 61 6d  {.    test_renam
7b20: 65 5f 70 61 72 65 6e 74 20 7b 43 52 45 41 54 45  e_parent {CREATE
7b30: 20 54 41 42 4c 45 20 74 31 28 61 20 52 45 46 45   TABLE t1(a REFE
7b40: 52 45 4e 43 45 53 20 22 74 32 22 29 7d 20 74 32  RENCES "t2")} t2
7b50: 20 74 33 0a 20 20 7d 20 7b 7b 43 52 45 41 54 45   t3.  } {{CREATE
7b60: 20 54 41 42 4c 45 20 74 31 28 61 20 52 45 46 45   TABLE t1(a REFE
7b70: 52 45 4e 43 45 53 20 22 74 33 22 29 7d 7d 0a 20  RENCES "t3")}}. 
7b80: 20 73 71 6c 69 74 65 33 5f 74 65 73 74 5f 63 6f   sqlite3_test_co
7b90: 6e 74 72 6f 6c 20 53 51 4c 49 54 45 5f 54 45 53  ntrol SQLITE_TES
7ba0: 54 43 54 52 4c 5f 49 4e 54 45 52 4e 41 4c 5f 46  TCTRL_INTERNAL_F
7bb0: 55 4e 43 54 49 4f 4e 53 20 30 0a 20 20 0a 20 20  UNCTIONS 0.  .  
7bc0: 23 20 54 65 73 74 20 41 4c 54 45 52 20 54 41 42  # Test ALTER TAB
7bd0: 4c 45 20 52 45 4e 41 4d 45 20 54 41 42 4c 45 20  LE RENAME TABLE 
7be0: 61 20 62 69 74 2e 0a 20 20 23 0a 20 20 64 6f 5f  a bit..  #.  do_
7bf0: 74 65 73 74 20 66 6b 65 79 32 2d 31 34 2e 32 2e  test fkey2-14.2.
7c00: 32 2e 31 20 7b 0a 20 20 20 20 64 72 6f 70 5f 61  2.1 {.    drop_a
7c10: 6c 6c 5f 74 61 62 6c 65 73 0a 20 20 20 20 65 78  ll_tables.    ex
7c20: 65 63 73 71 6c 20 7b 0a 20 20 20 20 20 20 43 52  ecsql {.      CR
7c30: 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 61 20  EATE TABLE t1(a 
7c40: 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62 20 52  PRIMARY KEY, b R
7c50: 45 46 45 52 45 4e 43 45 53 20 74 31 29 3b 0a 20  EFERENCES t1);. 
7c60: 20 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c       CREATE TABL
7c70: 45 20 74 32 28 61 20 50 52 49 4d 41 52 59 20 4b  E t2(a PRIMARY K
7c80: 45 59 2c 20 62 20 52 45 46 45 52 45 4e 43 45 53  EY, b REFERENCES
7c90: 20 74 31 2c 20 63 20 52 45 46 45 52 45 4e 43 45   t1, c REFERENCE
7ca0: 53 20 74 32 29 3b 0a 20 20 20 20 20 20 43 52 45  S t2);.      CRE
7cb0: 41 54 45 20 54 41 42 4c 45 20 74 33 28 61 20 52  ATE TABLE t3(a R
7cc0: 45 46 45 52 45 4e 43 45 53 20 74 31 2c 20 62 20  EFERENCES t1, b 
7cd0: 52 45 46 45 52 45 4e 43 45 53 20 74 32 2c 20 63  REFERENCES t2, c
7ce0: 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 29 3b   REFERENCES t1);
7cf0: 0a 20 20 20 20 7d 0a 20 20 20 20 65 78 65 63 73  .    }.    execs
7d00: 71 6c 20 7b 20 53 45 4c 45 43 54 20 73 71 6c 20  ql { SELECT sql 
7d10: 46 52 4f 4d 20 73 71 6c 69 74 65 5f 6d 61 73 74  FROM sqlite_mast
7d20: 65 72 20 57 48 45 52 45 20 74 79 70 65 20 3d 20  er WHERE type = 
7d30: 27 74 61 62 6c 65 27 7d 0a 20 20 7d 20 5b 6c 69  'table'}.  } [li
7d40: 73 74 20 5c 0a 20 20 20 20 7b 43 52 45 41 54 45  st \.    {CREATE
7d50: 20 54 41 42 4c 45 20 74 31 28 61 20 50 52 49 4d   TABLE t1(a PRIM
7d60: 41 52 59 20 4b 45 59 2c 20 62 20 52 45 46 45 52  ARY KEY, b REFER
7d70: 45 4e 43 45 53 20 74 31 29 7d 20 20 20 20 20 20  ENCES t1)}      
7d80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 5c                 \
7d90: 0a 20 20 20 20 7b 43 52 45 41 54 45 20 54 41 42  .    {CREATE TAB
7da0: 4c 45 20 74 32 28 61 20 50 52 49 4d 41 52 59 20  LE t2(a PRIMARY 
7db0: 4b 45 59 2c 20 62 20 52 45 46 45 52 45 4e 43 45  KEY, b REFERENCE
7dc0: 53 20 74 31 2c 20 63 20 52 45 46 45 52 45 4e 43  S t1, c REFERENC
7dd0: 45 53 20 74 32 29 7d 20 20 20 20 5c 0a 20 20 20  ES t2)}    \.   
7de0: 20 7b 43 52 45 41 54 45 20 54 41 42 4c 45 20 74   {CREATE TABLE t
7df0: 33 28 61 20 52 45 46 45 52 45 4e 43 45 53 20 74  3(a REFERENCES t
7e00: 31 2c 20 62 20 52 45 46 45 52 45 4e 43 45 53 20  1, b REFERENCES 
7e10: 74 32 2c 20 63 20 52 45 46 45 52 45 4e 43 45 53  t2, c REFERENCES
7e20: 20 74 31 29 7d 20 20 5c 0a 20 20 5d 0a 20 20 64   t1)}  \.  ].  d
7e30: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 34 2e  o_test fkey2-14.
7e40: 32 2e 32 2e 32 20 7b 0a 20 20 20 20 65 78 65 63  2.2.2 {.    exec
7e50: 73 71 6c 20 7b 20 41 4c 54 45 52 20 54 41 42 4c  sql { ALTER TABL
7e60: 45 20 74 31 20 52 45 4e 41 4d 45 20 54 4f 20 74  E t1 RENAME TO t
7e70: 34 20 7d 0a 20 20 20 20 65 78 65 63 73 71 6c 20  4 }.    execsql 
7e80: 7b 20 53 45 4c 45 43 54 20 73 71 6c 20 46 52 4f  { SELECT sql FRO
7e90: 4d 20 73 71 6c 69 74 65 5f 6d 61 73 74 65 72 20  M sqlite_master 
7ea0: 57 48 45 52 45 20 74 79 70 65 20 3d 20 27 74 61  WHERE type = 'ta
7eb0: 62 6c 65 27 7d 0a 20 20 7d 20 5b 6c 69 73 74 20  ble'}.  } [list 
7ec0: 5c 0a 20 20 20 20 7b 43 52 45 41 54 45 20 54 41  \.    {CREATE TA
7ed0: 42 4c 45 20 22 74 34 22 28 61 20 50 52 49 4d 41  BLE "t4"(a PRIMA
7ee0: 52 59 20 4b 45 59 2c 20 62 20 52 45 46 45 52 45  RY KEY, b REFERE
7ef0: 4e 43 45 53 20 22 74 34 22 29 7d 20 20 20 20 20  NCES "t4")}     
7f00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 5c                 \
7f10: 0a 20 20 20 20 7b 43 52 45 41 54 45 20 54 41 42  .    {CREATE TAB
7f20: 4c 45 20 74 32 28 61 20 50 52 49 4d 41 52 59 20  LE t2(a PRIMARY 
7f30: 4b 45 59 2c 20 62 20 52 45 46 45 52 45 4e 43 45  KEY, b REFERENCE
7f40: 53 20 22 74 34 22 2c 20 63 20 52 45 46 45 52 45  S "t4", c REFERE
7f50: 4e 43 45 53 20 74 32 29 7d 20 20 20 20 20 5c 0a  NCES t2)}     \.
7f60: 20 20 20 20 7b 43 52 45 41 54 45 20 54 41 42 4c      {CREATE TABL
7f70: 45 20 74 33 28 61 20 52 45 46 45 52 45 4e 43 45  E t3(a REFERENCE
7f80: 53 20 22 74 34 22 2c 20 62 20 52 45 46 45 52 45  S "t4", b REFERE
7f90: 4e 43 45 53 20 74 32 2c 20 63 20 52 45 46 45 52  NCES t2, c REFER
7fa0: 45 4e 43 45 53 20 22 74 34 22 29 7d 20 5c 0a 20  ENCES "t4")} \. 
7fb0: 20 5d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65   ].  do_test fke
7fc0: 79 32 2d 31 34 2e 32 2e 32 2e 33 20 7b 0a 20 20  y2-14.2.2.3 {.  
7fd0: 20 20 63 61 74 63 68 73 71 6c 20 7b 20 49 4e 53    catchsql { INS
7fe0: 45 52 54 20 49 4e 54 4f 20 74 33 20 56 41 4c 55  ERT INTO t3 VALU
7ff0: 45 53 28 31 2c 20 32 2c 20 33 29 20 7d 0a 20 20  ES(1, 2, 3) }.  
8000: 7d 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45  } {1 {FOREIGN KE
8010: 59 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69  Y constraint fai
8020: 6c 65 64 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20  led}}.  do_test 
8030: 66 6b 65 79 32 2d 31 34 2e 32 2e 32 2e 34 20 7b  fkey2-14.2.2.4 {
8040: 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20 49  .    execsql { I
8050: 4e 53 45 52 54 20 49 4e 54 4f 20 74 34 20 56 41  NSERT INTO t4 VA
8060: 4c 55 45 53 28 31 2c 20 4e 55 4c 4c 29 20 7d 0a  LUES(1, NULL) }.
8070: 20 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74 65 73 74    } {}.  do_test
8080: 20 66 6b 65 79 32 2d 31 34 2e 32 2e 32 2e 35 20   fkey2-14.2.2.5 
8090: 7b 0a 20 20 20 20 63 61 74 63 68 73 71 6c 20 7b  {.    catchsql {
80a0: 20 55 50 44 41 54 45 20 74 34 20 53 45 54 20 62   UPDATE t4 SET b
80b0: 20 3d 20 35 20 7d 0a 20 20 7d 20 7b 31 20 7b 46   = 5 }.  } {1 {F
80c0: 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73 74  OREIGN KEY const
80d0: 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 20  raint failed}}. 
80e0: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31   do_test fkey2-1
80f0: 34 2e 32 2e 32 2e 36 20 7b 0a 20 20 20 20 63 61  4.2.2.6 {.    ca
8100: 74 63 68 73 71 6c 20 7b 20 55 50 44 41 54 45 20  tchsql { UPDATE 
8110: 74 34 20 53 45 54 20 62 20 3d 20 31 20 7d 0a 20  t4 SET b = 1 }. 
8120: 20 7d 20 7b 30 20 7b 7d 7d 0a 20 20 64 6f 5f 74   } {0 {}}.  do_t
8130: 65 73 74 20 66 6b 65 79 32 2d 31 34 2e 32 2e 32  est fkey2-14.2.2
8140: 2e 37 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c  .7 {.    execsql
8150: 20 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74   { INSERT INTO t
8160: 33 20 56 41 4c 55 45 53 28 31 2c 20 4e 55 4c 4c  3 VALUES(1, NULL
8170: 2c 20 31 29 20 7d 0a 20 20 7d 20 7b 7d 0a 0a 20  , 1) }.  } {}.. 
8180: 20 23 20 52 65 70 65 61 74 20 66 6f 72 20 54 45   # Repeat for TE
8190: 4d 50 20 74 61 62 6c 65 73 0a 20 20 23 0a 20 20  MP tables.  #.  
81a0: 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a  drop_all_tables.
81b0: 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d    do_test fkey2-
81c0: 31 34 2e 31 74 6d 70 2e 31 20 7b 0a 20 20 20 20  14.1tmp.1 {.    
81d0: 23 20 41 64 64 69 6e 67 20 61 20 63 6f 6c 75 6d  # Adding a colum
81e0: 6e 20 77 69 74 68 20 61 20 52 45 46 45 52 45 4e  n with a REFEREN
81f0: 43 45 53 20 63 6c 61 75 73 65 20 69 73 20 6e 6f  CES clause is no
8200: 74 20 73 75 70 70 6f 72 74 65 64 2e 0a 20 20 20  t supported..   
8210: 20 65 78 65 63 73 71 6c 20 7b 20 0a 20 20 20 20   execsql { .    
8220: 20 20 43 52 45 41 54 45 20 54 45 4d 50 20 54 41    CREATE TEMP TA
8230: 42 4c 45 20 74 31 28 61 20 50 52 49 4d 41 52 59  BLE t1(a PRIMARY
8240: 20 4b 45 59 29 3b 0a 20 20 20 20 20 20 43 52 45   KEY);.      CRE
8250: 41 54 45 20 54 45 4d 50 20 54 41 42 4c 45 20 74  ATE TEMP TABLE t
8260: 32 28 61 2c 20 62 29 3b 0a 20 20 20 20 7d 0a 20  2(a, b);.    }. 
8270: 20 20 20 63 61 74 63 68 73 71 6c 20 7b 20 41 4c     catchsql { AL
8280: 54 45 52 20 54 41 42 4c 45 20 74 32 20 41 44 44  TER TABLE t2 ADD
8290: 20 43 4f 4c 55 4d 4e 20 63 20 52 45 46 45 52 45   COLUMN c REFERE
82a0: 4e 43 45 53 20 74 31 20 7d 0a 20 20 7d 20 7b 30  NCES t1 }.  } {0
82b0: 20 7b 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66   {}}.  do_test f
82c0: 6b 65 79 32 2d 31 34 2e 31 74 6d 70 2e 32 20 7b  key2-14.1tmp.2 {
82d0: 0a 20 20 20 20 63 61 74 63 68 73 71 6c 20 7b 20  .    catchsql { 
82e0: 41 4c 54 45 52 20 54 41 42 4c 45 20 74 32 20 41  ALTER TABLE t2 A
82f0: 44 44 20 43 4f 4c 55 4d 4e 20 64 20 44 45 46 41  DD COLUMN d DEFA
8300: 55 4c 54 20 4e 55 4c 4c 20 52 45 46 45 52 45 4e  ULT NULL REFEREN
8310: 43 45 53 20 74 31 20 7d 0a 20 20 7d 20 7b 30 20  CES t1 }.  } {0 
8320: 7b 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b  {}}.  do_test fk
8330: 65 79 32 2d 31 34 2e 31 74 6d 70 2e 33 20 7b 0a  ey2-14.1tmp.3 {.
8340: 20 20 20 20 63 61 74 63 68 73 71 6c 20 7b 20 41      catchsql { A
8350: 4c 54 45 52 20 54 41 42 4c 45 20 74 32 20 41 44  LTER TABLE t2 AD
8360: 44 20 43 4f 4c 55 4d 4e 20 65 20 52 45 46 45 52  D COLUMN e REFER
8370: 45 4e 43 45 53 20 74 31 20 44 45 46 41 55 4c 54  ENCES t1 DEFAULT
8380: 20 4e 55 4c 4c 7d 0a 20 20 7d 20 7b 30 20 7b 7d   NULL}.  } {0 {}
8390: 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79  }.  do_test fkey
83a0: 32 2d 31 34 2e 31 74 6d 70 2e 34 20 7b 0a 20 20  2-14.1tmp.4 {.  
83b0: 20 20 63 61 74 63 68 73 71 6c 20 7b 20 41 4c 54    catchsql { ALT
83c0: 45 52 20 54 41 42 4c 45 20 74 32 20 41 44 44 20  ER TABLE t2 ADD 
83d0: 43 4f 4c 55 4d 4e 20 66 20 52 45 46 45 52 45 4e  COLUMN f REFEREN
83e0: 43 45 53 20 74 31 20 44 45 46 41 55 4c 54 20 27  CES t1 DEFAULT '
83f0: 74 65 78 74 27 7d 0a 20 20 7d 20 7b 31 20 7b 43  text'}.  } {1 {C
8400: 61 6e 6e 6f 74 20 61 64 64 20 61 20 52 45 46 45  annot add a REFE
8410: 52 45 4e 43 45 53 20 63 6f 6c 75 6d 6e 20 77 69  RENCES column wi
8420: 74 68 20 6e 6f 6e 2d 4e 55 4c 4c 20 64 65 66 61  th non-NULL defa
8430: 75 6c 74 20 76 61 6c 75 65 7d 7d 0a 20 20 64 6f  ult value}}.  do
8440: 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 34 2e 31  _test fkey2-14.1
8450: 74 6d 70 2e 35 20 7b 0a 20 20 20 20 63 61 74 63  tmp.5 {.    catc
8460: 68 73 71 6c 20 7b 20 41 4c 54 45 52 20 54 41 42  hsql { ALTER TAB
8470: 4c 45 20 74 32 20 41 44 44 20 43 4f 4c 55 4d 4e  LE t2 ADD COLUMN
8480: 20 67 20 44 45 46 41 55 4c 54 20 43 55 52 52 45   g DEFAULT CURRE
8490: 4e 54 5f 54 49 4d 45 20 52 45 46 45 52 45 4e 43  NT_TIME REFERENC
84a0: 45 53 20 74 31 20 7d 0a 20 20 7d 20 7b 31 20 7b  ES t1 }.  } {1 {
84b0: 43 61 6e 6e 6f 74 20 61 64 64 20 61 20 52 45 46  Cannot add a REF
84c0: 45 52 45 4e 43 45 53 20 63 6f 6c 75 6d 6e 20 77  ERENCES column w
84d0: 69 74 68 20 6e 6f 6e 2d 4e 55 4c 4c 20 64 65 66  ith non-NULL def
84e0: 61 75 6c 74 20 76 61 6c 75 65 7d 7d 0a 20 20 64  ault value}}.  d
84f0: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 34 2e  o_test fkey2-14.
8500: 31 74 6d 70 2e 36 20 7b 0a 20 20 20 20 65 78 65  1tmp.6 {.    exe
8510: 63 73 71 6c 20 7b 20 0a 20 20 20 20 20 20 50 52  csql { .      PR
8520: 41 47 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79  AGMA foreign_key
8530: 73 20 3d 20 6f 66 66 3b 0a 20 20 20 20 20 20 41  s = off;.      A
8540: 4c 54 45 52 20 54 41 42 4c 45 20 74 32 20 41 44  LTER TABLE t2 AD
8550: 44 20 43 4f 4c 55 4d 4e 20 68 20 44 45 46 41 55  D COLUMN h DEFAU
8560: 4c 54 20 27 74 65 78 74 27 20 52 45 46 45 52 45  LT 'text' REFERE
8570: 4e 43 45 53 20 74 31 3b 0a 20 20 20 20 20 20 50  NCES t1;.      P
8580: 52 41 47 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65  RAGMA foreign_ke
8590: 79 73 20 3d 20 6f 6e 3b 0a 20 20 20 20 20 20 53  ys = on;.      S
85a0: 45 4c 45 43 54 20 73 71 6c 20 46 52 4f 4d 20 74  ELECT sql FROM t
85b0: 65 6d 70 2e 73 71 6c 69 74 65 5f 6d 61 73 74 65  emp.sqlite_maste
85c0: 72 20 57 48 45 52 45 20 6e 61 6d 65 3d 27 74 32  r WHERE name='t2
85d0: 27 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 7b 43  ';.    }.  } {{C
85e0: 52 45 41 54 45 20 54 41 42 4c 45 20 74 32 28 61  REATE TABLE t2(a
85f0: 2c 20 62 2c 20 63 20 52 45 46 45 52 45 4e 43 45  , b, c REFERENCE
8600: 53 20 74 31 2c 20 64 20 44 45 46 41 55 4c 54 20  S t1, d DEFAULT 
8610: 4e 55 4c 4c 20 52 45 46 45 52 45 4e 43 45 53 20  NULL REFERENCES 
8620: 74 31 2c 20 65 20 52 45 46 45 52 45 4e 43 45 53  t1, e REFERENCES
8630: 20 74 31 20 44 45 46 41 55 4c 54 20 4e 55 4c 4c   t1 DEFAULT NULL
8640: 2c 20 68 20 44 45 46 41 55 4c 54 20 27 74 65 78  , h DEFAULT 'tex
8650: 74 27 20 52 45 46 45 52 45 4e 43 45 53 20 74 31  t' REFERENCES t1
8660: 29 7d 7d 0a 0a 20 20 73 71 6c 69 74 65 33 5f 74  )}}..  sqlite3_t
8670: 65 73 74 5f 63 6f 6e 74 72 6f 6c 20 53 51 4c 49  est_control SQLI
8680: 54 45 5f 54 45 53 54 43 54 52 4c 5f 49 4e 54 45  TE_TESTCTRL_INTE
8690: 52 4e 41 4c 5f 46 55 4e 43 54 49 4f 4e 53 20 31  RNAL_FUNCTIONS 1
86a0: 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  .  do_test fkey2
86b0: 2d 31 34 2e 32 74 6d 70 2e 31 2e 31 20 7b 0a 20  -14.2tmp.1.1 {. 
86c0: 20 20 20 74 65 73 74 5f 72 65 6e 61 6d 65 5f 70     test_rename_p
86d0: 61 72 65 6e 74 20 7b 43 52 45 41 54 45 20 54 41  arent {CREATE TA
86e0: 42 4c 45 20 74 31 28 61 20 52 45 46 45 52 45 4e  BLE t1(a REFEREN
86f0: 43 45 53 20 74 32 29 7d 20 74 32 20 74 33 0a 20  CES t2)} t2 t3. 
8700: 20 7d 20 7b 7b 43 52 45 41 54 45 20 54 41 42 4c   } {{CREATE TABL
8710: 45 20 74 31 28 61 20 52 45 46 45 52 45 4e 43 45  E t1(a REFERENCE
8720: 53 20 22 74 33 22 29 7d 7d 0a 20 20 64 6f 5f 74  S "t3")}}.  do_t
8730: 65 73 74 20 66 6b 65 79 32 2d 31 34 2e 32 74 6d  est fkey2-14.2tm
8740: 70 2e 31 2e 32 20 7b 0a 20 20 20 20 74 65 73 74  p.1.2 {.    test
8750: 5f 72 65 6e 61 6d 65 5f 70 61 72 65 6e 74 20 7b  _rename_parent {
8760: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28  CREATE TABLE t1(
8770: 61 20 52 45 46 45 52 45 4e 43 45 53 20 74 32 29  a REFERENCES t2)
8780: 7d 20 74 34 20 74 33 0a 20 20 7d 20 7b 7b 43 52  } t4 t3.  } {{CR
8790: 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 61 20  EATE TABLE t1(a 
87a0: 52 45 46 45 52 45 4e 43 45 53 20 74 32 29 7d 7d  REFERENCES t2)}}
87b0: 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  .  do_test fkey2
87c0: 2d 31 34 2e 32 74 6d 70 2e 31 2e 33 20 7b 0a 20  -14.2tmp.1.3 {. 
87d0: 20 20 20 74 65 73 74 5f 72 65 6e 61 6d 65 5f 70     test_rename_p
87e0: 61 72 65 6e 74 20 7b 43 52 45 41 54 45 20 54 41  arent {CREATE TA
87f0: 42 4c 45 20 74 31 28 61 20 52 45 46 45 52 45 4e  BLE t1(a REFEREN
8800: 43 45 53 20 22 74 32 22 29 7d 20 74 32 20 74 33  CES "t2")} t2 t3
8810: 0a 20 20 7d 20 7b 7b 43 52 45 41 54 45 20 54 41  .  } {{CREATE TA
8820: 42 4c 45 20 74 31 28 61 20 52 45 46 45 52 45 4e  BLE t1(a REFEREN
8830: 43 45 53 20 22 74 33 22 29 7d 7d 0a 20 20 73 71  CES "t3")}}.  sq
8840: 6c 69 74 65 33 5f 74 65 73 74 5f 63 6f 6e 74 72  lite3_test_contr
8850: 6f 6c 20 53 51 4c 49 54 45 5f 54 45 53 54 43 54  ol SQLITE_TESTCT
8860: 52 4c 5f 49 4e 54 45 52 4e 41 4c 5f 46 55 4e 43  RL_INTERNAL_FUNC
8870: 54 49 4f 4e 53 20 30 0a 20 20 0a 20 20 23 20 54  TIONS 0.  .  # T
8880: 65 73 74 20 41 4c 54 45 52 20 54 41 42 4c 45 20  est ALTER TABLE 
8890: 52 45 4e 41 4d 45 20 54 41 42 4c 45 20 61 20 62  RENAME TABLE a b
88a0: 69 74 2e 0a 20 20 23 0a 20 20 64 6f 5f 74 65 73  it..  #.  do_tes
88b0: 74 20 66 6b 65 79 32 2d 31 34 2e 32 74 6d 70 2e  t fkey2-14.2tmp.
88c0: 32 2e 31 20 7b 0a 20 20 20 20 64 72 6f 70 5f 61  2.1 {.    drop_a
88d0: 6c 6c 5f 74 61 62 6c 65 73 0a 20 20 20 20 65 78  ll_tables.    ex
88e0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 20 20 43 52  ecsql {.      CR
88f0: 45 41 54 45 20 54 45 4d 50 20 54 41 42 4c 45 20  EATE TEMP TABLE 
8900: 74 31 28 61 20 50 52 49 4d 41 52 59 20 4b 45 59  t1(a PRIMARY KEY
8910: 2c 20 62 20 52 45 46 45 52 45 4e 43 45 53 20 74  , b REFERENCES t
8920: 31 29 3b 0a 20 20 20 20 20 20 43 52 45 41 54 45  1);.      CREATE
8930: 20 54 45 4d 50 20 54 41 42 4c 45 20 74 32 28 61   TEMP TABLE t2(a
8940: 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62 20   PRIMARY KEY, b 
8950: 52 45 46 45 52 45 4e 43 45 53 20 74 31 2c 20 63  REFERENCES t1, c
8960: 20 52 45 46 45 52 45 4e 43 45 53 20 74 32 29 3b   REFERENCES t2);
8970: 0a 20 20 20 20 20 20 43 52 45 41 54 45 20 54 45  .      CREATE TE
8980: 4d 50 20 54 41 42 4c 45 20 74 33 28 61 20 52 45  MP TABLE t3(a RE
8990: 46 45 52 45 4e 43 45 53 20 74 31 2c 20 62 20 52  FERENCES t1, b R
89a0: 45 46 45 52 45 4e 43 45 53 20 74 32 2c 20 63 20  EFERENCES t2, c 
89b0: 52 45 46 45 52 45 4e 43 45 53 20 74 31 29 3b 0a  REFERENCES t1);.
89c0: 20 20 20 20 7d 0a 20 20 20 20 65 78 65 63 73 71      }.    execsq
89d0: 6c 20 7b 20 53 45 4c 45 43 54 20 73 71 6c 20 46  l { SELECT sql F
89e0: 52 4f 4d 20 73 71 6c 69 74 65 5f 74 65 6d 70 5f  ROM sqlite_temp_
89f0: 6d 61 73 74 65 72 20 57 48 45 52 45 20 74 79 70  master WHERE typ
8a00: 65 20 3d 20 27 74 61 62 6c 65 27 7d 0a 20 20 7d  e = 'table'}.  }
8a10: 20 5b 6c 69 73 74 20 5c 0a 20 20 20 20 7b 43 52   [list \.    {CR
8a20: 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 61 20  EATE TABLE t1(a 
8a30: 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62 20 52  PRIMARY KEY, b R
8a40: 45 46 45 52 45 4e 43 45 53 20 74 31 29 7d 20 20  EFERENCES t1)}  
8a50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8a60: 20 20 20 5c 0a 20 20 20 20 7b 43 52 45 41 54 45     \.    {CREATE
8a70: 20 54 41 42 4c 45 20 74 32 28 61 20 50 52 49 4d   TABLE t2(a PRIM
8a80: 41 52 59 20 4b 45 59 2c 20 62 20 52 45 46 45 52  ARY KEY, b REFER
8a90: 45 4e 43 45 53 20 74 31 2c 20 63 20 52 45 46 45  ENCES t1, c REFE
8aa0: 52 45 4e 43 45 53 20 74 32 29 7d 20 20 20 20 5c  RENCES t2)}    \
8ab0: 0a 20 20 20 20 7b 43 52 45 41 54 45 20 54 41 42  .    {CREATE TAB
8ac0: 4c 45 20 74 33 28 61 20 52 45 46 45 52 45 4e 43  LE t3(a REFERENC
8ad0: 45 53 20 74 31 2c 20 62 20 52 45 46 45 52 45 4e  ES t1, b REFEREN
8ae0: 43 45 53 20 74 32 2c 20 63 20 52 45 46 45 52 45  CES t2, c REFERE
8af0: 4e 43 45 53 20 74 31 29 7d 20 20 5c 0a 20 20 5d  NCES t1)}  \.  ]
8b00: 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  .  do_test fkey2
8b10: 2d 31 34 2e 32 74 6d 70 2e 32 2e 32 20 7b 0a 20  -14.2tmp.2.2 {. 
8b20: 20 20 20 65 78 65 63 73 71 6c 20 7b 20 41 4c 54     execsql { ALT
8b30: 45 52 20 54 41 42 4c 45 20 74 31 20 52 45 4e 41  ER TABLE t1 RENA
8b40: 4d 45 20 54 4f 20 74 34 20 7d 0a 20 20 20 20 65  ME TO t4 }.    e
8b50: 78 65 63 73 71 6c 20 7b 20 53 45 4c 45 43 54 20  xecsql { SELECT 
8b60: 73 71 6c 20 46 52 4f 4d 20 74 65 6d 70 2e 73 71  sql FROM temp.sq
8b70: 6c 69 74 65 5f 6d 61 73 74 65 72 20 57 48 45 52  lite_master WHER
8b80: 45 20 74 79 70 65 20 3d 20 27 74 61 62 6c 65 27  E type = 'table'
8b90: 7d 0a 20 20 7d 20 5b 6c 69 73 74 20 5c 0a 20 20  }.  } [list \.  
8ba0: 20 20 7b 43 52 45 41 54 45 20 54 41 42 4c 45 20    {CREATE TABLE 
8bb0: 22 74 34 22 28 61 20 50 52 49 4d 41 52 59 20 4b  "t4"(a PRIMARY K
8bc0: 45 59 2c 20 62 20 52 45 46 45 52 45 4e 43 45 53  EY, b REFERENCES
8bd0: 20 22 74 34 22 29 7d 20 20 20 20 20 20 20 20 20   "t4")}         
8be0: 20 20 20 20 20 20 20 20 20 20 20 5c 0a 20 20 20             \.   
8bf0: 20 7b 43 52 45 41 54 45 20 54 41 42 4c 45 20 74   {CREATE TABLE t
8c00: 32 28 61 20 50 52 49 4d 41 52 59 20 4b 45 59 2c  2(a PRIMARY KEY,
8c10: 20 62 20 52 45 46 45 52 45 4e 43 45 53 20 22 74   b REFERENCES "t
8c20: 34 22 2c 20 63 20 52 45 46 45 52 45 4e 43 45 53  4", c REFERENCES
8c30: 20 74 32 29 7d 20 20 20 20 20 5c 0a 20 20 20 20   t2)}     \.    
8c40: 7b 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 33  {CREATE TABLE t3
8c50: 28 61 20 52 45 46 45 52 45 4e 43 45 53 20 22 74  (a REFERENCES "t
8c60: 34 22 2c 20 62 20 52 45 46 45 52 45 4e 43 45 53  4", b REFERENCES
8c70: 20 74 32 2c 20 63 20 52 45 46 45 52 45 4e 43 45   t2, c REFERENCE
8c80: 53 20 22 74 34 22 29 7d 20 5c 0a 20 20 5d 0a 20  S "t4")} \.  ]. 
8c90: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31   do_test fkey2-1
8ca0: 34 2e 32 74 6d 70 2e 32 2e 33 20 7b 0a 20 20 20  4.2tmp.2.3 {.   
8cb0: 20 63 61 74 63 68 73 71 6c 20 7b 20 49 4e 53 45   catchsql { INSE
8cc0: 52 54 20 49 4e 54 4f 20 74 33 20 56 41 4c 55 45  RT INTO t3 VALUE
8cd0: 53 28 31 2c 20 32 2c 20 33 29 20 7d 0a 20 20 7d  S(1, 2, 3) }.  }
8ce0: 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59   {1 {FOREIGN KEY
8cf0: 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c   constraint fail
8d00: 65 64 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66  ed}}.  do_test f
8d10: 6b 65 79 32 2d 31 34 2e 32 74 6d 70 2e 32 2e 34  key2-14.2tmp.2.4
8d20: 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b   {.    execsql {
8d30: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 34 20   INSERT INTO t4 
8d40: 56 41 4c 55 45 53 28 31 2c 20 4e 55 4c 4c 29 20  VALUES(1, NULL) 
8d50: 7d 0a 20 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74 65  }.  } {}.  do_te
8d60: 73 74 20 66 6b 65 79 32 2d 31 34 2e 32 74 6d 70  st fkey2-14.2tmp
8d70: 2e 32 2e 35 20 7b 0a 20 20 20 20 63 61 74 63 68  .2.5 {.    catch
8d80: 73 71 6c 20 7b 20 55 50 44 41 54 45 20 74 34 20  sql { UPDATE t4 
8d90: 53 45 54 20 62 20 3d 20 35 20 7d 0a 20 20 7d 20  SET b = 5 }.  } 
8da0: 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20  {1 {FOREIGN KEY 
8db0: 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65  constraint faile
8dc0: 64 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b  d}}.  do_test fk
8dd0: 65 79 32 2d 31 34 2e 32 74 6d 70 2e 32 2e 36 20  ey2-14.2tmp.2.6 
8de0: 7b 0a 20 20 20 20 63 61 74 63 68 73 71 6c 20 7b  {.    catchsql {
8df0: 20 55 50 44 41 54 45 20 74 34 20 53 45 54 20 62   UPDATE t4 SET b
8e00: 20 3d 20 31 20 7d 0a 20 20 7d 20 7b 30 20 7b 7d   = 1 }.  } {0 {}
8e10: 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79  }.  do_test fkey
8e20: 32 2d 31 34 2e 32 74 6d 70 2e 32 2e 37 20 7b 0a  2-14.2tmp.2.7 {.
8e30: 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20 49 4e      execsql { IN
8e40: 53 45 52 54 20 49 4e 54 4f 20 74 33 20 56 41 4c  SERT INTO t3 VAL
8e50: 55 45 53 28 31 2c 20 4e 55 4c 4c 2c 20 31 29 20  UES(1, NULL, 1) 
8e60: 7d 0a 20 20 7d 20 7b 7d 0a 0a 20 20 23 20 52 65  }.  } {}..  # Re
8e70: 70 65 61 74 20 66 6f 72 20 41 54 54 41 43 48 2d  peat for ATTACH-
8e80: 65 64 20 74 61 62 6c 65 73 0a 20 20 23 0a 20 20  ed tables.  #.  
8e90: 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a  drop_all_tables.
8ea0: 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d    do_test fkey2-
8eb0: 31 34 2e 31 61 75 78 2e 31 20 7b 0a 20 20 20 20  14.1aux.1 {.    
8ec0: 23 20 41 64 64 69 6e 67 20 61 20 63 6f 6c 75 6d  # Adding a colum
8ed0: 6e 20 77 69 74 68 20 61 20 52 45 46 45 52 45 4e  n with a REFEREN
8ee0: 43 45 53 20 63 6c 61 75 73 65 20 69 73 20 6e 6f  CES clause is no
8ef0: 74 20 73 75 70 70 6f 72 74 65 64 2e 0a 20 20 20  t supported..   
8f00: 20 65 78 65 63 73 71 6c 20 7b 20 0a 20 20 20 20   execsql { .    
8f10: 20 20 41 54 54 41 43 48 20 27 3a 6d 65 6d 6f 72    ATTACH ':memor
8f20: 79 3a 27 20 41 53 20 61 75 78 3b 0a 20 20 20 20  y:' AS aux;.    
8f30: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 61    CREATE TABLE a
8f40: 75 78 2e 74 31 28 61 20 50 52 49 4d 41 52 59 20  ux.t1(a PRIMARY 
8f50: 4b 45 59 29 3b 0a 20 20 20 20 20 20 43 52 45 41  KEY);.      CREA
8f60: 54 45 20 54 41 42 4c 45 20 61 75 78 2e 74 32 28  TE TABLE aux.t2(
8f70: 61 2c 20 62 29 3b 0a 20 20 20 20 7d 0a 20 20 20  a, b);.    }.   
8f80: 20 63 61 74 63 68 73 71 6c 20 7b 20 41 4c 54 45   catchsql { ALTE
8f90: 52 20 54 41 42 4c 45 20 74 32 20 41 44 44 20 43  R TABLE t2 ADD C
8fa0: 4f 4c 55 4d 4e 20 63 20 52 45 46 45 52 45 4e 43  OLUMN c REFERENC
8fb0: 45 53 20 74 31 20 7d 0a 20 20 7d 20 7b 30 20 7b  ES t1 }.  } {0 {
8fc0: 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65  }}.  do_test fke
8fd0: 79 32 2d 31 34 2e 31 61 75 78 2e 32 20 7b 0a 20  y2-14.1aux.2 {. 
8fe0: 20 20 20 63 61 74 63 68 73 71 6c 20 7b 20 41 4c     catchsql { AL
8ff0: 54 45 52 20 54 41 42 4c 45 20 74 32 20 41 44 44  TER TABLE t2 ADD
9000: 20 43 4f 4c 55 4d 4e 20 64 20 44 45 46 41 55 4c   COLUMN d DEFAUL
9010: 54 20 4e 55 4c 4c 20 52 45 46 45 52 45 4e 43 45  T NULL REFERENCE
9020: 53 20 74 31 20 7d 0a 20 20 7d 20 7b 30 20 7b 7d  S t1 }.  } {0 {}
9030: 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79  }.  do_test fkey
9040: 32 2d 31 34 2e 31 61 75 78 2e 33 20 7b 0a 20 20  2-14.1aux.3 {.  
9050: 20 20 63 61 74 63 68 73 71 6c 20 7b 20 41 4c 54    catchsql { ALT
9060: 45 52 20 54 41 42 4c 45 20 74 32 20 41 44 44 20  ER TABLE t2 ADD 
9070: 43 4f 4c 55 4d 4e 20 65 20 52 45 46 45 52 45 4e  COLUMN e REFEREN
9080: 43 45 53 20 74 31 20 44 45 46 41 55 4c 54 20 4e  CES t1 DEFAULT N
9090: 55 4c 4c 7d 0a 20 20 7d 20 7b 30 20 7b 7d 7d 0a  ULL}.  } {0 {}}.
90a0: 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d    do_test fkey2-
90b0: 31 34 2e 31 61 75 78 2e 34 20 7b 0a 20 20 20 20  14.1aux.4 {.    
90c0: 63 61 74 63 68 73 71 6c 20 7b 20 41 4c 54 45 52  catchsql { ALTER
90d0: 20 54 41 42 4c 45 20 74 32 20 41 44 44 20 43 4f   TABLE t2 ADD CO
90e0: 4c 55 4d 4e 20 66 20 52 45 46 45 52 45 4e 43 45  LUMN f REFERENCE
90f0: 53 20 74 31 20 44 45 46 41 55 4c 54 20 27 74 65  S t1 DEFAULT 'te
9100: 78 74 27 7d 0a 20 20 7d 20 7b 31 20 7b 43 61 6e  xt'}.  } {1 {Can
9110: 6e 6f 74 20 61 64 64 20 61 20 52 45 46 45 52 45  not add a REFERE
9120: 4e 43 45 53 20 63 6f 6c 75 6d 6e 20 77 69 74 68  NCES column with
9130: 20 6e 6f 6e 2d 4e 55 4c 4c 20 64 65 66 61 75 6c   non-NULL defaul
9140: 74 20 76 61 6c 75 65 7d 7d 0a 20 20 64 6f 5f 74  t value}}.  do_t
9150: 65 73 74 20 66 6b 65 79 32 2d 31 34 2e 31 61 75  est fkey2-14.1au
9160: 78 2e 35 20 7b 0a 20 20 20 20 63 61 74 63 68 73  x.5 {.    catchs
9170: 71 6c 20 7b 20 41 4c 54 45 52 20 54 41 42 4c 45  ql { ALTER TABLE
9180: 20 74 32 20 41 44 44 20 43 4f 4c 55 4d 4e 20 67   t2 ADD COLUMN g
9190: 20 44 45 46 41 55 4c 54 20 43 55 52 52 45 4e 54   DEFAULT CURRENT
91a0: 5f 54 49 4d 45 20 52 45 46 45 52 45 4e 43 45 53  _TIME REFERENCES
91b0: 20 74 31 20 7d 0a 20 20 7d 20 7b 31 20 7b 43 61   t1 }.  } {1 {Ca
91c0: 6e 6e 6f 74 20 61 64 64 20 61 20 52 45 46 45 52  nnot add a REFER
91d0: 45 4e 43 45 53 20 63 6f 6c 75 6d 6e 20 77 69 74  ENCES column wit
91e0: 68 20 6e 6f 6e 2d 4e 55 4c 4c 20 64 65 66 61 75  h non-NULL defau
91f0: 6c 74 20 76 61 6c 75 65 7d 7d 0a 20 20 64 6f 5f  lt value}}.  do_
9200: 74 65 73 74 20 66 6b 65 79 32 2d 31 34 2e 31 61  test fkey2-14.1a
9210: 75 78 2e 36 20 7b 0a 20 20 20 20 65 78 65 63 73  ux.6 {.    execs
9220: 71 6c 20 7b 20 0a 20 20 20 20 20 20 50 52 41 47  ql { .      PRAG
9230: 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79 73 20  MA foreign_keys 
9240: 3d 20 6f 66 66 3b 0a 20 20 20 20 20 20 41 4c 54  = off;.      ALT
9250: 45 52 20 54 41 42 4c 45 20 74 32 20 41 44 44 20  ER TABLE t2 ADD 
9260: 43 4f 4c 55 4d 4e 20 68 20 44 45 46 41 55 4c 54  COLUMN h DEFAULT
9270: 20 27 74 65 78 74 27 20 52 45 46 45 52 45 4e 43   'text' REFERENC
9280: 45 53 20 74 31 3b 0a 20 20 20 20 20 20 50 52 41  ES t1;.      PRA
9290: 47 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79 73  GMA foreign_keys
92a0: 20 3d 20 6f 6e 3b 0a 20 20 20 20 20 20 53 45 4c   = on;.      SEL
92b0: 45 43 54 20 73 71 6c 20 46 52 4f 4d 20 61 75 78  ECT sql FROM aux
92c0: 2e 73 71 6c 69 74 65 5f 6d 61 73 74 65 72 20 57  .sqlite_master W
92d0: 48 45 52 45 20 6e 61 6d 65 3d 27 74 32 27 3b 0a  HERE name='t2';.
92e0: 20 20 20 20 7d 0a 20 20 7d 20 7b 7b 43 52 45 41      }.  } {{CREA
92f0: 54 45 20 54 41 42 4c 45 20 74 32 28 61 2c 20 62  TE TABLE t2(a, b
9300: 2c 20 63 20 52 45 46 45 52 45 4e 43 45 53 20 74  , c REFERENCES t
9310: 31 2c 20 64 20 44 45 46 41 55 4c 54 20 4e 55 4c  1, d DEFAULT NUL
9320: 4c 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 2c  L REFERENCES t1,
9330: 20 65 20 52 45 46 45 52 45 4e 43 45 53 20 74 31   e REFERENCES t1
9340: 20 44 45 46 41 55 4c 54 20 4e 55 4c 4c 2c 20 68   DEFAULT NULL, h
9350: 20 44 45 46 41 55 4c 54 20 27 74 65 78 74 27 20   DEFAULT 'text' 
9360: 52 45 46 45 52 45 4e 43 45 53 20 74 31 29 7d 7d  REFERENCES t1)}}
9370: 0a 0a 20 20 73 71 6c 69 74 65 33 5f 74 65 73 74  ..  sqlite3_test
9380: 5f 63 6f 6e 74 72 6f 6c 20 53 51 4c 49 54 45 5f  _control SQLITE_
9390: 54 45 53 54 43 54 52 4c 5f 49 4e 54 45 52 4e 41  TESTCTRL_INTERNA
93a0: 4c 5f 46 55 4e 43 54 49 4f 4e 53 20 31 0a 20 20  L_FUNCTIONS 1.  
93b0: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 34  do_test fkey2-14
93c0: 2e 32 61 75 78 2e 31 2e 31 20 7b 0a 20 20 20 20  .2aux.1.1 {.    
93d0: 74 65 73 74 5f 72 65 6e 61 6d 65 5f 70 61 72 65  test_rename_pare
93e0: 6e 74 20 7b 43 52 45 41 54 45 20 54 41 42 4c 45  nt {CREATE TABLE
93f0: 20 74 31 28 61 20 52 45 46 45 52 45 4e 43 45 53   t1(a REFERENCES
9400: 20 74 32 29 7d 20 74 32 20 74 33 0a 20 20 7d 20   t2)} t2 t3.  } 
9410: 7b 7b 43 52 45 41 54 45 20 54 41 42 4c 45 20 74  {{CREATE TABLE t
9420: 31 28 61 20 52 45 46 45 52 45 4e 43 45 53 20 22  1(a REFERENCES "
9430: 74 33 22 29 7d 7d 0a 20 20 64 6f 5f 74 65 73 74  t3")}}.  do_test
9440: 20 66 6b 65 79 32 2d 31 34 2e 32 61 75 78 2e 31   fkey2-14.2aux.1
9450: 2e 32 20 7b 0a 20 20 20 20 74 65 73 74 5f 72 65  .2 {.    test_re
9460: 6e 61 6d 65 5f 70 61 72 65 6e 74 20 7b 43 52 45  name_parent {CRE
9470: 41 54 45 20 54 41 42 4c 45 20 74 31 28 61 20 52  ATE TABLE t1(a R
9480: 45 46 45 52 45 4e 43 45 53 20 74 32 29 7d 20 74  EFERENCES t2)} t
9490: 34 20 74 33 0a 20 20 7d 20 7b 7b 43 52 45 41 54  4 t3.  } {{CREAT
94a0: 45 20 54 41 42 4c 45 20 74 31 28 61 20 52 45 46  E TABLE t1(a REF
94b0: 45 52 45 4e 43 45 53 20 74 32 29 7d 7d 0a 20 20  ERENCES t2)}}.  
94c0: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 34  do_test fkey2-14
94d0: 2e 32 61 75 78 2e 31 2e 33 20 7b 0a 20 20 20 20  .2aux.1.3 {.    
94e0: 74 65 73 74 5f 72 65 6e 61 6d 65 5f 70 61 72 65  test_rename_pare
94f0: 6e 74 20 7b 43 52 45 41 54 45 20 54 41 42 4c 45  nt {CREATE TABLE
9500: 20 74 31 28 61 20 52 45 46 45 52 45 4e 43 45 53   t1(a REFERENCES
9510: 20 22 74 32 22 29 7d 20 74 32 20 74 33 0a 20 20   "t2")} t2 t3.  
9520: 7d 20 7b 7b 43 52 45 41 54 45 20 54 41 42 4c 45  } {{CREATE TABLE
9530: 20 74 31 28 61 20 52 45 46 45 52 45 4e 43 45 53   t1(a REFERENCES
9540: 20 22 74 33 22 29 7d 7d 0a 20 20 73 71 6c 69 74   "t3")}}.  sqlit
9550: 65 33 5f 74 65 73 74 5f 63 6f 6e 74 72 6f 6c 20  e3_test_control 
9560: 53 51 4c 49 54 45 5f 54 45 53 54 43 54 52 4c 5f  SQLITE_TESTCTRL_
9570: 49 4e 54 45 52 4e 41 4c 5f 46 55 4e 43 54 49 4f  INTERNAL_FUNCTIO
9580: 4e 53 20 30 0a 20 20 0a 20 20 23 20 54 65 73 74  NS 0.  .  # Test
9590: 20 41 4c 54 45 52 20 54 41 42 4c 45 20 52 45 4e   ALTER TABLE REN
95a0: 41 4d 45 20 54 41 42 4c 45 20 61 20 62 69 74 2e  AME TABLE a bit.
95b0: 0a 20 20 23 0a 20 20 64 6f 5f 74 65 73 74 20 66  .  #.  do_test f
95c0: 6b 65 79 32 2d 31 34 2e 32 61 75 78 2e 32 2e 31  key2-14.2aux.2.1
95d0: 20 7b 0a 20 20 20 20 64 72 6f 70 5f 61 6c 6c 5f   {.    drop_all_
95e0: 74 61 62 6c 65 73 0a 20 20 20 20 65 78 65 63 73  tables.    execs
95f0: 71 6c 20 7b 0a 20 20 20 20 20 20 43 52 45 41 54  ql {.      CREAT
9600: 45 20 54 41 42 4c 45 20 61 75 78 2e 74 31 28 61  E TABLE aux.t1(a
9610: 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62 20   PRIMARY KEY, b 
9620: 52 45 46 45 52 45 4e 43 45 53 20 74 31 29 3b 0a  REFERENCES t1);.
9630: 20 20 20 20 20 20 43 52 45 41 54 45 20 54 41 42        CREATE TAB
9640: 4c 45 20 61 75 78 2e 74 32 28 61 20 50 52 49 4d  LE aux.t2(a PRIM
9650: 41 52 59 20 4b 45 59 2c 20 62 20 52 45 46 45 52  ARY KEY, b REFER
9660: 45 4e 43 45 53 20 74 31 2c 20 63 20 52 45 46 45  ENCES t1, c REFE
9670: 52 45 4e 43 45 53 20 74 32 29 3b 0a 20 20 20 20  RENCES t2);.    
9680: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 61    CREATE TABLE a
9690: 75 78 2e 74 33 28 61 20 52 45 46 45 52 45 4e 43  ux.t3(a REFERENC
96a0: 45 53 20 74 31 2c 20 62 20 52 45 46 45 52 45 4e  ES t1, b REFEREN
96b0: 43 45 53 20 74 32 2c 20 63 20 52 45 46 45 52 45  CES t2, c REFERE
96c0: 4e 43 45 53 20 74 31 29 3b 0a 20 20 20 20 7d 0a  NCES t1);.    }.
96d0: 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20 53 45      execsql { SE
96e0: 4c 45 43 54 20 73 71 6c 20 46 52 4f 4d 20 61 75  LECT sql FROM au
96f0: 78 2e 73 71 6c 69 74 65 5f 6d 61 73 74 65 72 20  x.sqlite_master 
9700: 57 48 45 52 45 20 74 79 70 65 20 3d 20 27 74 61  WHERE type = 'ta
9710: 62 6c 65 27 7d 0a 20 20 7d 20 5b 6c 69 73 74 20  ble'}.  } [list 
9720: 5c 0a 20 20 20 20 7b 43 52 45 41 54 45 20 54 41  \.    {CREATE TA
9730: 42 4c 45 20 74 31 28 61 20 50 52 49 4d 41 52 59  BLE t1(a PRIMARY
9740: 20 4b 45 59 2c 20 62 20 52 45 46 45 52 45 4e 43   KEY, b REFERENC
9750: 45 53 20 74 31 29 7d 20 20 20 20 20 20 20 20 20  ES t1)}         
9760: 20 20 20 20 20 20 20 20 20 20 20 20 5c 0a 20 20              \.  
9770: 20 20 7b 43 52 45 41 54 45 20 54 41 42 4c 45 20    {CREATE TABLE 
9780: 74 32 28 61 20 50 52 49 4d 41 52 59 20 4b 45 59  t2(a PRIMARY KEY
9790: 2c 20 62 20 52 45 46 45 52 45 4e 43 45 53 20 74  , b REFERENCES t
97a0: 31 2c 20 63 20 52 45 46 45 52 45 4e 43 45 53 20  1, c REFERENCES 
97b0: 74 32 29 7d 20 20 20 20 5c 0a 20 20 20 20 7b 43  t2)}    \.    {C
97c0: 52 45 41 54 45 20 54 41 42 4c 45 20 74 33 28 61  REATE TABLE t3(a
97d0: 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 2c 20   REFERENCES t1, 
97e0: 62 20 52 45 46 45 52 45 4e 43 45 53 20 74 32 2c  b REFERENCES t2,
97f0: 20 63 20 52 45 46 45 52 45 4e 43 45 53 20 74 31   c REFERENCES t1
9800: 29 7d 20 20 5c 0a 20 20 5d 0a 20 20 64 6f 5f 74  )}  \.  ].  do_t
9810: 65 73 74 20 66 6b 65 79 32 2d 31 34 2e 32 61 75  est fkey2-14.2au
9820: 78 2e 32 2e 32 20 7b 0a 20 20 20 20 65 78 65 63  x.2.2 {.    exec
9830: 73 71 6c 20 7b 20 41 4c 54 45 52 20 54 41 42 4c  sql { ALTER TABL
9840: 45 20 74 31 20 52 45 4e 41 4d 45 20 54 4f 20 74  E t1 RENAME TO t
9850: 34 20 7d 0a 20 20 20 20 65 78 65 63 73 71 6c 20  4 }.    execsql 
9860: 7b 20 53 45 4c 45 43 54 20 73 71 6c 20 46 52 4f  { SELECT sql FRO
9870: 4d 20 61 75 78 2e 73 71 6c 69 74 65 5f 6d 61 73  M aux.sqlite_mas
9880: 74 65 72 20 57 48 45 52 45 20 74 79 70 65 20 3d  ter WHERE type =
9890: 20 27 74 61 62 6c 65 27 7d 0a 20 20 7d 20 5b 6c   'table'}.  } [l
98a0: 69 73 74 20 5c 0a 20 20 20 20 7b 43 52 45 41 54  ist \.    {CREAT
98b0: 45 20 54 41 42 4c 45 20 22 74 34 22 28 61 20 50  E TABLE "t4"(a P
98c0: 52 49 4d 41 52 59 20 4b 45 59 2c 20 62 20 52 45  RIMARY KEY, b RE
98d0: 46 45 52 45 4e 43 45 53 20 22 74 34 22 29 7d 20  FERENCES "t4")} 
98e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
98f0: 20 20 20 5c 0a 20 20 20 20 7b 43 52 45 41 54 45     \.    {CREATE
9900: 20 54 41 42 4c 45 20 74 32 28 61 20 50 52 49 4d   TABLE t2(a PRIM
9910: 41 52 59 20 4b 45 59 2c 20 62 20 52 45 46 45 52  ARY KEY, b REFER
9920: 45 4e 43 45 53 20 22 74 34 22 2c 20 63 20 52 45  ENCES "t4", c RE
9930: 46 45 52 45 4e 43 45 53 20 74 32 29 7d 20 20 20  FERENCES t2)}   
9940: 20 20 5c 0a 20 20 20 20 7b 43 52 45 41 54 45 20    \.    {CREATE 
9950: 54 41 42 4c 45 20 74 33 28 61 20 52 45 46 45 52  TABLE t3(a REFER
9960: 45 4e 43 45 53 20 22 74 34 22 2c 20 62 20 52 45  ENCES "t4", b RE
9970: 46 45 52 45 4e 43 45 53 20 74 32 2c 20 63 20 52  FERENCES t2, c R
9980: 45 46 45 52 45 4e 43 45 53 20 22 74 34 22 29 7d  EFERENCES "t4")}
9990: 20 5c 0a 20 20 5d 0a 20 20 64 6f 5f 74 65 73 74   \.  ].  do_test
99a0: 20 66 6b 65 79 32 2d 31 34 2e 32 61 75 78 2e 32   fkey2-14.2aux.2
99b0: 2e 33 20 7b 0a 20 20 20 20 63 61 74 63 68 73 71  .3 {.    catchsq
99c0: 6c 20 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f 20  l { INSERT INTO 
99d0: 74 33 20 56 41 4c 55 45 53 28 31 2c 20 32 2c 20  t3 VALUES(1, 2, 
99e0: 33 29 20 7d 0a 20 20 7d 20 7b 31 20 7b 46 4f 52  3) }.  } {1 {FOR
99f0: 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73 74 72 61  EIGN KEY constra
9a00: 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 20 20 64  int failed}}.  d
9a10: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 34 2e  o_test fkey2-14.
9a20: 32 61 75 78 2e 32 2e 34 20 7b 0a 20 20 20 20 65  2aux.2.4 {.    e
9a30: 78 65 63 73 71 6c 20 7b 20 49 4e 53 45 52 54 20  xecsql { INSERT 
9a40: 49 4e 54 4f 20 74 34 20 56 41 4c 55 45 53 28 31  INTO t4 VALUES(1
9a50: 2c 20 4e 55 4c 4c 29 20 7d 0a 20 20 7d 20 7b 7d  , NULL) }.  } {}
9a60: 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  .  do_test fkey2
9a70: 2d 31 34 2e 32 61 75 78 2e 32 2e 35 20 7b 0a 20  -14.2aux.2.5 {. 
9a80: 20 20 20 63 61 74 63 68 73 71 6c 20 7b 20 55 50     catchsql { UP
9a90: 44 41 54 45 20 74 34 20 53 45 54 20 62 20 3d 20  DATE t4 SET b = 
9aa0: 35 20 7d 0a 20 20 7d 20 7b 31 20 7b 46 4f 52 45  5 }.  } {1 {FORE
9ab0: 49 47 4e 20 4b 45 59 20 63 6f 6e 73 74 72 61 69  IGN KEY constrai
9ac0: 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 20 20 64 6f  nt failed}}.  do
9ad0: 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 34 2e 32  _test fkey2-14.2
9ae0: 61 75 78 2e 32 2e 36 20 7b 0a 20 20 20 20 63 61  aux.2.6 {.    ca
9af0: 74 63 68 73 71 6c 20 7b 20 55 50 44 41 54 45 20  tchsql { UPDATE 
9b00: 74 34 20 53 45 54 20 62 20 3d 20 31 20 7d 0a 20  t4 SET b = 1 }. 
9b10: 20 7d 20 7b 30 20 7b 7d 7d 0a 20 20 64 6f 5f 74   } {0 {}}.  do_t
9b20: 65 73 74 20 66 6b 65 79 32 2d 31 34 2e 32 61 75  est fkey2-14.2au
9b30: 78 2e 32 2e 37 20 7b 0a 20 20 20 20 65 78 65 63  x.2.7 {.    exec
9b40: 73 71 6c 20 7b 20 49 4e 53 45 52 54 20 49 4e 54  sql { INSERT INT
9b50: 4f 20 74 33 20 56 41 4c 55 45 53 28 31 2c 20 4e  O t3 VALUES(1, N
9b60: 55 4c 4c 2c 20 31 29 20 7d 0a 20 20 7d 20 7b 7d  ULL, 1) }.  } {}
9b70: 0a 7d 0a 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79  .}..do_test fkey
9b80: 2d 32 2e 31 34 2e 33 2e 31 20 7b 0a 20 20 64 72  -2.14.3.1 {.  dr
9b90: 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a 20 20  op_all_tables.  
9ba0: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52  execsql {.    CR
9bb0: 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 61 2c  EATE TABLE t1(a,
9bc0: 20 62 20 52 45 46 45 52 45 4e 43 45 53 20 6e 6f   b REFERENCES no
9bd0: 73 75 63 68 74 61 62 6c 65 29 3b 0a 20 20 20 20  suchtable);.    
9be0: 44 52 4f 50 20 54 41 42 4c 45 20 74 31 3b 0a 20  DROP TABLE t1;. 
9bf0: 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20   }.} {}.do_test 
9c00: 66 6b 65 79 2d 32 2e 31 34 2e 33 2e 32 20 7b 0a  fkey-2.14.3.2 {.
9c10: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
9c20: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28  CREATE TABLE t1(
9c30: 61 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62  a PRIMARY KEY, b
9c40: 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  );.    INSERT IN
9c50: 54 4f 20 74 31 20 56 41 4c 55 45 53 28 27 61 27  TO t1 VALUES('a'
9c60: 2c 20 31 29 3b 0a 20 20 20 20 43 52 45 41 54 45  , 1);.    CREATE
9c70: 20 54 41 42 4c 45 20 74 32 28 78 20 52 45 46 45   TABLE t2(x REFE
9c80: 52 45 4e 43 45 53 20 74 31 29 3b 0a 20 20 20 20  RENCES t1);.    
9c90: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 20 56  INSERT INTO t2 V
9ca0: 41 4c 55 45 53 28 27 61 27 29 3b 0a 20 20 7d 0a  ALUES('a');.  }.
9cb0: 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65  } {}.do_test fke
9cc0: 79 2d 32 2e 31 34 2e 33 2e 33 20 7b 0a 20 20 63  y-2.14.3.3 {.  c
9cd0: 61 74 63 68 73 71 6c 20 7b 20 44 52 4f 50 20 54  atchsql { DROP T
9ce0: 41 42 4c 45 20 74 31 20 7d 0a 7d 20 7b 31 20 7b  ABLE t1 }.} {1 {
9cf0: 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73  FOREIGN KEY cons
9d00: 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a  traint failed}}.
9d10: 64 6f 5f 74 65 73 74 20 66 6b 65 79 2d 32 2e 31  do_test fkey-2.1
9d20: 34 2e 33 2e 34 20 7b 0a 20 20 65 78 65 63 73 71  4.3.4 {.  execsq
9d30: 6c 20 7b 0a 20 20 20 20 44 45 4c 45 54 45 20 46  l {.    DELETE F
9d40: 52 4f 4d 20 74 32 3b 0a 20 20 20 20 44 52 4f 50  ROM t2;.    DROP
9d50: 20 54 41 42 4c 45 20 74 31 3b 0a 20 20 7d 0a 7d   TABLE t1;.  }.}
9d60: 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79   {}.do_test fkey
9d70: 2d 32 2e 31 34 2e 33 2e 34 20 7b 0a 20 20 63 61  -2.14.3.4 {.  ca
9d80: 74 63 68 73 71 6c 20 7b 20 49 4e 53 45 52 54 20  tchsql { INSERT 
9d90: 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28 27  INTO t2 VALUES('
9da0: 78 27 29 20 7d 0a 7d 20 7b 31 20 7b 6e 6f 20 73  x') }.} {1 {no s
9db0: 75 63 68 20 74 61 62 6c 65 3a 20 6d 61 69 6e 2e  uch table: main.
9dc0: 74 31 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65  t1}}.do_test fke
9dd0: 79 2d 32 2e 31 34 2e 33 2e 35 20 7b 0a 20 20 65  y-2.14.3.5 {.  e
9de0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45  xecsql {.    CRE
9df0: 41 54 45 20 54 41 42 4c 45 20 74 31 28 78 20 50  ATE TABLE t1(x P
9e00: 52 49 4d 41 52 59 20 4b 45 59 29 3b 0a 20 20 20  RIMARY KEY);.   
9e10: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
9e20: 56 41 4c 55 45 53 28 27 78 27 29 3b 0a 20 20 7d  VALUES('x');.  }
9e30: 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 49 4e 53  .  execsql { INS
9e40: 45 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55  ERT INTO t2 VALU
9e50: 45 53 28 27 78 27 29 20 7d 0a 7d 20 7b 7d 0a 64  ES('x') }.} {}.d
9e60: 6f 5f 74 65 73 74 20 66 6b 65 79 2d 32 2e 31 34  o_test fkey-2.14
9e70: 2e 33 2e 36 20 7b 0a 20 20 63 61 74 63 68 73 71  .3.6 {.  catchsq
9e80: 6c 20 7b 20 44 52 4f 50 20 54 41 42 4c 45 20 74  l { DROP TABLE t
9e90: 31 20 7d 0a 7d 20 7b 31 20 7b 46 4f 52 45 49 47  1 }.} {1 {FOREIG
9ea0: 4e 20 4b 45 59 20 63 6f 6e 73 74 72 61 69 6e 74  N KEY constraint
9eb0: 20 66 61 69 6c 65 64 7d 7d 0a 64 6f 5f 74 65 73   failed}}.do_tes
9ec0: 74 20 66 6b 65 79 2d 32 2e 31 34 2e 33 2e 37 20  t fkey-2.14.3.7 
9ed0: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
9ee0: 20 20 44 52 4f 50 20 54 41 42 4c 45 20 74 32 3b    DROP TABLE t2;
9ef0: 0a 20 20 20 20 44 52 4f 50 20 54 41 42 4c 45 20  .    DROP TABLE 
9f00: 74 31 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f  t1;.  }.} {}.do_
9f10: 74 65 73 74 20 66 6b 65 79 2d 32 2e 31 34 2e 33  test fkey-2.14.3
9f20: 2e 38 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .8 {.  execsql {
9f30: 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  .    CREATE TABL
9f40: 45 20 70 70 28 78 2c 20 79 2c 20 50 52 49 4d 41  E pp(x, y, PRIMA
9f50: 52 59 20 4b 45 59 28 78 2c 20 79 29 29 3b 0a 20  RY KEY(x, y));. 
9f60: 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20     CREATE TABLE 
9f70: 63 63 28 61 2c 20 62 2c 20 46 4f 52 45 49 47 4e  cc(a, b, FOREIGN
9f80: 20 4b 45 59 28 61 2c 20 62 29 20 52 45 46 45 52   KEY(a, b) REFER
9f90: 45 4e 43 45 53 20 70 70 28 78 2c 20 7a 29 29 3b  ENCES pp(x, z));
9fa0: 0a 20 20 7d 0a 20 20 63 61 74 63 68 73 71 6c 20  .  }.  catchsql 
9fb0: 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 63 63  { INSERT INTO cc
9fc0: 20 56 41 4c 55 45 53 28 31 2c 20 32 29 20 7d 0a   VALUES(1, 2) }.
9fd0: 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65  } {1 {foreign ke
9fe0: 79 20 6d 69 73 6d 61 74 63 68 20 2d 20 22 63 63  y mismatch - "cc
9ff0: 22 20 72 65 66 65 72 65 6e 63 69 6e 67 20 22 70  " referencing "p
a000: 70 22 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65  p"}}.do_test fke
a010: 79 2d 32 2e 31 34 2e 33 2e 39 20 7b 0a 20 20 65  y-2.14.3.9 {.  e
a020: 78 65 63 73 71 6c 20 7b 20 44 52 4f 50 20 54 41  xecsql { DROP TA
a030: 42 4c 45 20 63 63 20 7d 0a 7d 20 7b 7d 0a 64 6f  BLE cc }.} {}.do
a040: 5f 74 65 73 74 20 66 6b 65 79 2d 32 2e 31 34 2e  _test fkey-2.14.
a050: 33 2e 31 30 20 7b 0a 20 20 65 78 65 63 73 71 6c  3.10 {.  execsql
a060: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41   {.    CREATE TA
a070: 42 4c 45 20 63 63 28 61 2c 20 62 2c 20 0a 20 20  BLE cc(a, b, .  
a080: 20 20 20 20 46 4f 52 45 49 47 4e 20 4b 45 59 28      FOREIGN KEY(
a090: 61 2c 20 62 29 20 52 45 46 45 52 45 4e 43 45 53  a, b) REFERENCES
a0a0: 20 70 70 20 44 45 46 45 52 52 41 42 4c 45 20 49   pp DEFERRABLE I
a0b0: 4e 49 54 49 41 4c 4c 59 20 44 45 46 45 52 52 45  NITIALLY DEFERRE
a0c0: 44 0a 20 20 20 20 29 3b 0a 20 20 7d 0a 20 20 65  D.    );.  }.  e
a0d0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53  xecsql {.    INS
a0e0: 45 52 54 20 49 4e 54 4f 20 70 70 20 56 41 4c 55  ERT INTO pp VALU
a0f0: 45 53 28 27 61 27 2c 20 27 62 27 29 3b 0a 20 20  ES('a', 'b');.  
a100: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 63 63    INSERT INTO cc
a110: 20 56 41 4c 55 45 53 28 27 61 27 2c 20 27 62 27   VALUES('a', 'b'
a120: 29 3b 0a 20 20 20 20 42 45 47 49 4e 3b 0a 20 20  );.    BEGIN;.  
a130: 20 20 20 20 44 52 4f 50 20 54 41 42 4c 45 20 70      DROP TABLE p
a140: 70 3b 0a 20 20 20 20 20 20 43 52 45 41 54 45 20  p;.      CREATE 
a150: 54 41 42 4c 45 20 70 70 28 61 2c 20 62 2c 20 63  TABLE pp(a, b, c
a160: 2c 20 50 52 49 4d 41 52 59 20 4b 45 59 28 62 2c  , PRIMARY KEY(b,
a170: 20 63 29 29 3b 0a 20 20 20 20 20 20 49 4e 53 45   c));.      INSE
a180: 52 54 20 49 4e 54 4f 20 70 70 20 56 41 4c 55 45  RT INTO pp VALUE
a190: 53 28 31 2c 20 27 61 27 2c 20 27 62 27 29 3b 0a  S(1, 'a', 'b');.
a1a0: 20 20 20 20 43 4f 4d 4d 49 54 3b 0a 20 20 7d 0a      COMMIT;.  }.
a1b0: 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65  } {}.do_test fke
a1c0: 79 2d 32 2e 31 34 2e 33 2e 31 31 20 7b 0a 20 20  y-2.14.3.11 {.  
a1d0: 65 78 65 63 73 71 6c 20 7b 20 0a 20 20 20 20 42  execsql { .    B
a1e0: 45 47 49 4e 3b 0a 20 20 20 20 20 20 44 52 4f 50  EGIN;.      DROP
a1f0: 20 54 41 42 4c 45 20 63 63 3b 0a 20 20 20 20 20   TABLE cc;.     
a200: 20 44 52 4f 50 20 54 41 42 4c 45 20 70 70 3b 0a   DROP TABLE pp;.
a210: 20 20 20 20 43 4f 4d 4d 49 54 3b 0a 20 20 7d 0a      COMMIT;.  }.
a220: 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65  } {}.do_test fke
a230: 79 2d 32 2e 31 34 2e 33 2e 31 32 20 7b 0a 20 20  y-2.14.3.12 {.  
a240: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52  execsql {.    CR
a250: 45 41 54 45 20 54 41 42 4c 45 20 62 31 28 61 2c  EATE TABLE b1(a,
a260: 20 62 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20   b);.    CREATE 
a270: 54 41 42 4c 45 20 62 32 28 61 2c 20 62 20 52 45  TABLE b2(a, b RE
a280: 46 45 52 45 4e 43 45 53 20 62 31 29 3b 0a 20 20  FERENCES b1);.  
a290: 20 20 44 52 4f 50 20 54 41 42 4c 45 20 62 31 3b    DROP TABLE b1;
a2a0: 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73  .  }.} {}.do_tes
a2b0: 74 20 66 6b 65 79 2d 32 2e 31 34 2e 33 2e 31 33  t fkey-2.14.3.13
a2c0: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   {.  execsql {. 
a2d0: 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20     CREATE TABLE 
a2e0: 62 33 28 61 2c 20 62 20 52 45 46 45 52 45 4e 43  b3(a, b REFERENC
a2f0: 45 53 20 62 32 20 44 45 46 45 52 52 41 42 4c 45  ES b2 DEFERRABLE
a300: 20 49 4e 49 54 49 41 4c 4c 59 20 44 45 46 45 52   INITIALLY DEFER
a310: 52 45 44 29 3b 0a 20 20 20 20 44 52 4f 50 20 54  RED);.    DROP T
a320: 41 42 4c 45 20 62 32 3b 0a 20 20 7d 0a 7d 20 7b  ABLE b2;.  }.} {
a330: 7d 0a 0a 23 20 54 65 73 74 20 74 68 61 74 20 6e  }..# Test that n
a340: 6f 74 68 69 6e 67 20 67 6f 65 73 20 77 72 6f 6e  othing goes wron
a350: 67 20 77 68 65 6e 20 64 72 6f 70 70 69 6e 67 20  g when dropping 
a360: 61 20 74 61 62 6c 65 20 74 68 61 74 20 72 65 66  a table that ref
a370: 65 72 73 20 74 6f 20 61 20 76 69 65 77 2e 0a 23  ers to a view..#
a380: 20 4f 72 20 64 72 6f 70 70 69 6e 67 20 61 20 76   Or dropping a v
a390: 69 65 77 20 74 68 61 74 20 61 6e 20 65 78 69 73  iew that an exis
a3a0: 74 69 6e 67 20 46 4b 20 28 69 6e 63 6f 72 72 65  ting FK (incorre
a3b0: 63 74 6c 79 29 20 72 65 66 65 72 73 20 74 6f 2e  ctly) refers to.
a3c0: 20 4f 72 20 65 69 74 68 65 72 0a 23 20 6f 66 20   Or either.# of 
a3d0: 74 68 65 20 61 62 6f 76 65 20 73 63 65 6e 61 72  the above scenar
a3e0: 69 6f 73 20 77 69 74 68 20 61 20 76 69 72 74 75  ios with a virtu
a3f0: 61 6c 20 74 61 62 6c 65 2e 0a 64 72 6f 70 5f 61  al table..drop_a
a400: 6c 6c 5f 74 61 62 6c 65 73 0a 64 6f 5f 74 65 73  ll_tables.do_tes
a410: 74 20 66 6b 65 79 2d 32 2e 31 34 2e 34 2e 31 20  t fkey-2.14.4.1 
a420: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
a430: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74    CREATE TABLE t
a440: 31 28 78 20 52 45 46 45 52 45 4e 43 45 53 20 76  1(x REFERENCES v
a450: 29 3b 20 0a 20 20 20 20 43 52 45 41 54 45 20 56  ); .    CREATE V
a460: 49 45 57 20 76 20 41 53 20 53 45 4c 45 43 54 20  IEW v AS SELECT 
a470: 2a 20 46 52 4f 4d 20 74 31 3b 0a 20 20 7d 0a 7d  * FROM t1;.  }.}
a480: 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79   {}.do_test fkey
a490: 2d 32 2e 31 34 2e 34 2e 32 20 7b 0a 20 20 65 78  -2.14.4.2 {.  ex
a4a0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50  ecsql {.    DROP
a4b0: 20 56 49 45 57 20 76 3b 0a 20 20 7d 0a 7d 20 7b   VIEW v;.  }.} {
a4c0: 7d 0a 69 66 63 61 70 61 62 6c 65 20 76 74 61 62  }.ifcapable vtab
a4d0: 20 7b 0a 20 20 72 65 67 69 73 74 65 72 5f 65 63   {.  register_ec
a4e0: 68 6f 5f 6d 6f 64 75 6c 65 20 64 62 0a 20 20 64  ho_module db.  d
a4f0: 6f 5f 74 65 73 74 20 66 6b 65 79 2d 32 2e 31 34  o_test fkey-2.14
a500: 2e 34 2e 33 20 7b 0a 20 20 20 20 65 78 65 63 73  .4.3 {.    execs
a510: 71 6c 20 7b 20 43 52 45 41 54 45 20 56 49 52 54  ql { CREATE VIRT
a520: 55 41 4c 20 54 41 42 4c 45 20 76 20 55 53 49 4e  UAL TABLE v USIN
a530: 47 20 65 63 68 6f 28 74 31 29 20 7d 0a 20 20 7d  G echo(t1) }.  }
a540: 20 7b 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b   {}.  do_test fk
a550: 65 79 2d 32 2e 31 34 2e 34 2e 32 20 7b 0a 20 20  ey-2.14.4.2 {.  
a560: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
a570: 20 20 44 52 4f 50 20 54 41 42 4c 45 20 76 3b 0a    DROP TABLE v;.
a580: 20 20 20 20 7d 0a 20 20 7d 20 7b 7d 0a 7d 0a 0a      }.  } {}.}..
a590: 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  #---------------
a5a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
a5b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
a5c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
a5d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 54 68 65  ----------.# The
a5e0: 20 66 6f 6c 6c 6f 77 69 6e 67 20 74 65 73 74 73   following tests
a5f0: 2c 20 66 6b 65 79 32 2d 31 35 2e 2a 2c 20 74 65  , fkey2-15.*, te
a600: 73 74 20 74 68 61 74 20 75 6e 6e 65 63 65 73 73  st that unnecess
a610: 61 72 79 20 46 4b 20 72 65 6c 61 74 65 64 20 73  ary FK related s
a620: 63 61 6e 73 20 0a 23 20 61 6e 64 20 6c 6f 6f 6b  cans .# and look
a630: 75 70 73 20 61 72 65 20 61 76 6f 69 64 65 64 20  ups are avoided 
a640: 77 68 65 6e 20 74 68 65 20 63 6f 6e 73 74 72 61  when the constra
a650: 69 6e 74 20 63 6f 75 6e 74 65 72 73 20 61 72 65  int counters are
a660: 20 7a 65 72 6f 2e 0a 23 0a 64 72 6f 70 5f 61 6c   zero..#.drop_al
a670: 6c 5f 74 61 62 6c 65 73 0a 70 72 6f 63 20 65 78  l_tables.proc ex
a680: 65 63 73 71 6c 53 20 7b 7a 53 71 6c 7d 20 7b 0a  ecsqlS {zSql} {.
a690: 20 20 73 65 74 20 3a 3a 73 71 6c 69 74 65 5f 73    set ::sqlite_s
a6a0: 65 61 72 63 68 5f 63 6f 75 6e 74 20 30 0a 20 20  earch_count 0.  
a6b0: 73 65 74 20 3a 3a 73 71 6c 69 74 65 5f 66 6f 75  set ::sqlite_fou
a6c0: 6e 64 5f 63 6f 75 6e 74 20 30 0a 20 20 73 65 74  nd_count 0.  set
a6d0: 20 72 65 73 20 5b 75 70 6c 65 76 65 6c 20 5b 6c   res [uplevel [l
a6e0: 69 73 74 20 65 78 65 63 73 71 6c 20 24 7a 53 71  ist execsql $zSq
a6f0: 6c 5d 5d 0a 20 20 63 6f 6e 63 61 74 20 5b 65 78  l]].  concat [ex
a700: 70 72 20 24 3a 3a 73 71 6c 69 74 65 5f 66 6f 75  pr $::sqlite_fou
a710: 6e 64 5f 63 6f 75 6e 74 20 2b 20 24 3a 3a 73 71  nd_count + $::sq
a720: 6c 69 74 65 5f 73 65 61 72 63 68 5f 63 6f 75 6e  lite_search_coun
a730: 74 5d 20 24 72 65 73 0a 7d 0a 64 6f 5f 74 65 73  t] $res.}.do_tes
a740: 74 20 66 6b 65 79 32 2d 31 35 2e 31 2e 31 20 7b  t fkey2-15.1.1 {
a750: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
a760: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 70 70   CREATE TABLE pp
a770: 28 61 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20  (a PRIMARY KEY, 
a780: 62 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54  b);.    CREATE T
a790: 41 42 4c 45 20 63 63 28 78 2c 20 79 20 52 45 46  ABLE cc(x, y REF
a7a0: 45 52 45 4e 43 45 53 20 70 70 20 44 45 46 45 52  ERENCES pp DEFER
a7b0: 52 41 42 4c 45 20 49 4e 49 54 49 41 4c 4c 59 20  RABLE INITIALLY 
a7c0: 44 45 46 45 52 52 45 44 29 3b 0a 20 20 20 20 49  DEFERRED);.    I
a7d0: 4e 53 45 52 54 20 49 4e 54 4f 20 70 70 20 56 41  NSERT INTO pp VA
a7e0: 4c 55 45 53 28 31 2c 20 27 6f 6e 65 27 29 3b 0a  LUES(1, 'one');.
a7f0: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
a800: 70 70 20 56 41 4c 55 45 53 28 32 2c 20 27 74 77  pp VALUES(2, 'tw
a810: 6f 27 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  o');.    INSERT 
a820: 49 4e 54 4f 20 63 63 20 56 41 4c 55 45 53 28 27  INTO cc VALUES('
a830: 6e 65 75 6e 67 27 2c 20 31 29 3b 0a 20 20 20 20  neung', 1);.    
a840: 49 4e 53 45 52 54 20 49 4e 54 4f 20 63 63 20 56  INSERT INTO cc V
a850: 41 4c 55 45 53 28 27 73 6f 6e 67 27 2c 20 32 29  ALUES('song', 2)
a860: 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65  ;.  }.} {}.do_te
a870: 73 74 20 66 6b 65 79 32 2d 31 35 2e 31 2e 32 20  st fkey2-15.1.2 
a880: 7b 0a 20 20 65 78 65 63 73 71 6c 53 20 7b 20 49  {.  execsqlS { I
a890: 4e 53 45 52 54 20 49 4e 54 4f 20 70 70 20 56 41  NSERT INTO pp VA
a8a0: 4c 55 45 53 28 33 2c 20 27 74 68 72 65 65 27 29  LUES(3, 'three')
a8b0: 20 7d 0a 7d 20 7b 30 7d 0a 64 6f 5f 74 65 73 74   }.} {0}.do_test
a8c0: 20 66 6b 65 79 32 2d 31 35 2e 31 2e 33 20 7b 0a   fkey2-15.1.3 {.
a8d0: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
a8e0: 42 45 47 49 4e 3b 0a 20 20 20 20 20 20 49 4e 53  BEGIN;.      INS
a8f0: 45 52 54 20 49 4e 54 4f 20 63 63 20 56 41 4c 55  ERT INTO cc VALU
a900: 45 53 28 27 73 65 65 27 2c 20 34 29 3b 20 20 20  ES('see', 4);   
a910: 20 2d 2d 20 56 69 6f 6c 61 74 65 73 20 64 65 66   -- Violates def
a920: 65 72 72 65 64 20 63 6f 6e 73 74 72 61 69 6e 74  erred constraint
a930: 0a 20 20 7d 0a 20 20 65 78 65 63 73 71 6c 53 20  .  }.  execsqlS 
a940: 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 70 70  { INSERT INTO pp
a950: 20 56 41 4c 55 45 53 28 35 2c 20 27 66 69 76 65   VALUES(5, 'five
a960: 27 29 20 7d 0a 7d 20 7b 32 7d 0a 64 6f 5f 74 65  ') }.} {2}.do_te
a970: 73 74 20 66 6b 65 79 32 2d 31 35 2e 31 2e 34 20  st fkey2-15.1.4 
a980: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 44 45  {.  execsql { DE
a990: 4c 45 54 45 20 46 52 4f 4d 20 63 63 20 57 48 45  LETE FROM cc WHE
a9a0: 52 45 20 78 20 3d 20 27 73 65 65 27 20 7d 0a 20  RE x = 'see' }. 
a9b0: 20 65 78 65 63 73 71 6c 53 20 7b 20 49 4e 53 45   execsqlS { INSE
a9c0: 52 54 20 49 4e 54 4f 20 70 70 20 56 41 4c 55 45  RT INTO pp VALUE
a9d0: 53 28 36 2c 20 27 73 69 78 27 29 20 7d 0a 7d 20  S(6, 'six') }.} 
a9e0: 7b 30 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79  {0}.do_test fkey
a9f0: 32 2d 31 35 2e 31 2e 35 20 7b 0a 20 20 65 78 65  2-15.1.5 {.  exe
aa00: 63 73 71 6c 20 43 4f 4d 4d 49 54 0a 7d 20 7b 7d  csql COMMIT.} {}
aa10: 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31  .do_test fkey2-1
aa20: 35 2e 31 2e 36 20 7b 0a 20 20 65 78 65 63 73 71  5.1.6 {.  execsq
aa30: 6c 20 42 45 47 49 4e 0a 20 20 65 78 65 63 73 71  l BEGIN.  execsq
aa40: 6c 53 20 7b 0a 20 20 20 20 44 45 4c 45 54 45 20  lS {.    DELETE 
aa50: 46 52 4f 4d 20 63 63 20 57 48 45 52 45 20 78 20  FROM cc WHERE x 
aa60: 3d 20 27 6e 65 75 6e 67 27 3b 0a 20 20 20 20 52  = 'neung';.    R
aa70: 4f 4c 4c 42 41 43 4b 3b 0a 20 20 7d 0a 7d 20 7b  OLLBACK;.  }.} {
aa80: 31 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  1}.do_test fkey2
aa90: 2d 31 35 2e 31 2e 37 20 7b 0a 20 20 65 78 65 63  -15.1.7 {.  exec
aaa0: 73 71 6c 20 7b 20 0a 20 20 20 20 42 45 47 49 4e  sql { .    BEGIN
aab0: 3b 0a 20 20 20 20 44 45 4c 45 54 45 20 46 52 4f  ;.    DELETE FRO
aac0: 4d 20 70 70 20 57 48 45 52 45 20 61 20 3d 20 32  M pp WHERE a = 2
aad0: 3b 0a 20 20 7d 0a 20 20 65 78 65 63 73 71 6c 53  ;.  }.  execsqlS
aae0: 20 7b 0a 20 20 20 20 44 45 4c 45 54 45 20 46 52   {.    DELETE FR
aaf0: 4f 4d 20 63 63 20 57 48 45 52 45 20 78 20 3d 20  OM cc WHERE x = 
ab00: 27 6e 65 75 6e 67 27 3b 0a 20 20 20 20 52 4f 4c  'neung';.    ROL
ab10: 4c 42 41 43 4b 3b 0a 20 20 7d 0a 7d 20 7b 32 7d  LBACK;.  }.} {2}
ab20: 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ..#-------------
ab30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
ab40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
ab50: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
ab60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 54  ------------.# T
ab70: 68 69 73 20 6e 65 78 74 20 62 6c 6f 63 6b 20 6f  his next block o
ab80: 66 20 74 65 73 74 73 2c 20 66 6b 65 79 32 2d 31  f tests, fkey2-1
ab90: 36 2e 2a 2c 20 74 65 73 74 20 74 68 61 74 20 72  6.*, test that r
aba0: 6f 77 73 20 74 68 61 74 20 72 65 66 65 72 20 74  ows that refer t
abb0: 6f 0a 23 20 74 68 65 6d 73 65 6c 76 65 73 20 6d  o.# themselves m
abc0: 61 79 20 62 65 20 69 6e 73 65 72 74 65 64 20 61  ay be inserted a
abd0: 6e 64 20 64 65 6c 65 74 65 64 2e 0a 23 0a 66 6f  nd deleted..#.fo
abe0: 72 65 61 63 68 20 7b 74 6e 20 7a 53 63 68 65 6d  reach {tn zSchem
abf0: 61 7d 20 7b 0a 20 20 31 20 7b 20 43 52 45 41 54  a} {.  1 { CREAT
ac00: 45 20 54 41 42 4c 45 20 73 65 6c 66 28 61 20 49  E TABLE self(a I
ac10: 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b  NTEGER PRIMARY K
ac20: 45 59 2c 20 62 20 52 45 46 45 52 45 4e 43 45 53  EY, b REFERENCES
ac30: 20 73 65 6c 66 28 61 29 29 20 7d 0a 20 20 32 20   self(a)) }.  2 
ac40: 7b 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 73  { CREATE TABLE s
ac50: 65 6c 66 28 61 20 50 52 49 4d 41 52 59 20 4b 45  elf(a PRIMARY KE
ac60: 59 2c 20 62 20 52 45 46 45 52 45 4e 43 45 53 20  Y, b REFERENCES 
ac70: 73 65 6c 66 28 61 29 29 20 7d 0a 20 20 33 20 7b  self(a)) }.  3 {
ac80: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 73 65   CREATE TABLE se
ac90: 6c 66 28 61 20 55 4e 49 51 55 45 2c 20 62 20 49  lf(a UNIQUE, b I
aca0: 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b  NTEGER PRIMARY K
acb0: 45 59 20 52 45 46 45 52 45 4e 43 45 53 20 73 65  EY REFERENCES se
acc0: 6c 66 28 61 29 29 20 7d 0a 7d 20 7b 0a 20 20 64  lf(a)) }.} {.  d
acd0: 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a 20  rop_all_tables. 
ace0: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31   do_test fkey2-1
acf0: 36 2e 31 2e 24 74 6e 2e 31 20 7b 0a 20 20 20 20  6.1.$tn.1 {.    
ad00: 65 78 65 63 73 71 6c 20 24 7a 53 63 68 65 6d 61  execsql $zSchema
ad10: 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20 49  .    execsql { I
ad20: 4e 53 45 52 54 20 49 4e 54 4f 20 73 65 6c 66 20  NSERT INTO self 
ad30: 56 41 4c 55 45 53 28 31 33 2c 20 31 33 29 20 7d  VALUES(13, 13) }
ad40: 0a 20 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74 65 73  .  } {}.  do_tes
ad50: 74 20 66 6b 65 79 32 2d 31 36 2e 31 2e 24 74 6e  t fkey2-16.1.$tn
ad60: 2e 32 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c  .2 {.    execsql
ad70: 20 7b 20 55 50 44 41 54 45 20 73 65 6c 66 20 53   { UPDATE self S
ad80: 45 54 20 61 20 3d 20 31 34 2c 20 62 20 3d 20 31  ET a = 14, b = 1
ad90: 34 20 7d 0a 20 20 7d 20 7b 7d 0a 0a 20 20 64 6f  4 }.  } {}..  do
ada0: 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 36 2e 31  _test fkey2-16.1
adb0: 2e 24 74 6e 2e 33 20 7b 0a 20 20 20 20 63 61 74  .$tn.3 {.    cat
adc0: 63 68 73 71 6c 20 7b 20 55 50 44 41 54 45 20 73  chsql { UPDATE s
add0: 65 6c 66 20 53 45 54 20 62 20 3d 20 31 35 20 7d  elf SET b = 15 }
ade0: 0a 20 20 7d 20 7b 31 20 7b 46 4f 52 45 49 47 4e  .  } {1 {FOREIGN
adf0: 20 4b 45 59 20 63 6f 6e 73 74 72 61 69 6e 74 20   KEY constraint 
ae00: 66 61 69 6c 65 64 7d 7d 0a 0a 20 20 64 6f 5f 74  failed}}..  do_t
ae10: 65 73 74 20 66 6b 65 79 32 2d 31 36 2e 31 2e 24  est fkey2-16.1.$
ae20: 74 6e 2e 34 20 7b 0a 20 20 20 20 63 61 74 63 68  tn.4 {.    catch
ae30: 73 71 6c 20 7b 20 55 50 44 41 54 45 20 73 65 6c  sql { UPDATE sel
ae40: 66 20 53 45 54 20 61 20 3d 20 31 35 20 7d 0a 20  f SET a = 15 }. 
ae50: 20 7d 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b   } {1 {FOREIGN K
ae60: 45 59 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61  EY constraint fa
ae70: 69 6c 65 64 7d 7d 0a 0a 20 20 64 6f 5f 74 65 73  iled}}..  do_tes
ae80: 74 20 66 6b 65 79 32 2d 31 36 2e 31 2e 24 74 6e  t fkey2-16.1.$tn
ae90: 2e 35 20 7b 0a 20 20 20 20 63 61 74 63 68 73 71  .5 {.    catchsq
aea0: 6c 20 7b 20 55 50 44 41 54 45 20 73 65 6c 66 20  l { UPDATE self 
aeb0: 53 45 54 20 61 20 3d 20 31 35 2c 20 62 20 3d 20  SET a = 15, b = 
aec0: 31 36 20 7d 0a 20 20 7d 20 7b 31 20 7b 46 4f 52  16 }.  } {1 {FOR
aed0: 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73 74 72 61  EIGN KEY constra
aee0: 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 0a 20 20  int failed}}..  
aef0: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 36  do_test fkey2-16
af00: 2e 31 2e 24 74 6e 2e 36 20 7b 0a 20 20 20 20 63  .1.$tn.6 {.    c
af10: 61 74 63 68 73 71 6c 20 7b 20 55 50 44 41 54 45  atchsql { UPDATE
af20: 20 73 65 6c 66 20 53 45 54 20 61 20 3d 20 31 37   self SET a = 17
af30: 2c 20 62 20 3d 20 31 37 20 7d 0a 20 20 7d 20 7b  , b = 17 }.  } {
af40: 30 20 7b 7d 7d 0a 0a 20 20 64 6f 5f 74 65 73 74  0 {}}..  do_test
af50: 20 66 6b 65 79 32 2d 31 36 2e 31 2e 24 74 6e 2e   fkey2-16.1.$tn.
af60: 37 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20  7 {.    execsql 
af70: 7b 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 73 65  { DELETE FROM se
af80: 6c 66 20 7d 0a 20 20 7d 20 7b 7d 0a 20 20 64 6f  lf }.  } {}.  do
af90: 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 36 2e 31  _test fkey2-16.1
afa0: 2e 24 74 6e 2e 38 20 7b 0a 20 20 20 20 63 61 74  .$tn.8 {.    cat
afb0: 63 68 73 71 6c 20 7b 20 49 4e 53 45 52 54 20 49  chsql { INSERT I
afc0: 4e 54 4f 20 73 65 6c 66 20 56 41 4c 55 45 53 28  NTO self VALUES(
afd0: 32 30 2c 20 32 31 29 20 7d 0a 20 20 7d 20 7b 31  20, 21) }.  } {1
afe0: 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f   {FOREIGN KEY co
aff0: 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d  nstraint failed}
b000: 7d 0a 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  }.}..#----------
b010: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
b020: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
b030: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
b040: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a  ---------------.
b050: 23 20 54 68 69 73 20 6e 65 78 74 20 62 6c 6f 63  # This next bloc
b060: 6b 20 6f 66 20 74 65 73 74 73 2c 20 66 6b 65 79  k of tests, fkey
b070: 32 2d 31 37 2e 2a 2c 20 74 65 73 74 73 20 74 68  2-17.*, tests th
b080: 61 74 20 69 66 20 22 50 52 41 47 4d 41 20 63 6f  at if "PRAGMA co
b090: 75 6e 74 5f 63 68 61 6e 67 65 73 22 0a 23 20 69  unt_changes".# i
b0a0: 73 20 74 75 72 6e 65 64 20 6f 6e 20 73 74 61 74  s turned on stat
b0b0: 65 6d 65 6e 74 73 20 74 68 61 74 20 76 69 6f 6c  ements that viol
b0c0: 61 74 65 20 69 6d 6d 65 64 69 61 74 65 20 46 4b  ate immediate FK
b0d0: 20 63 6f 6e 73 74 72 61 69 6e 74 73 20 72 65 74   constraints ret
b0e0: 75 72 6e 0a 23 20 53 51 4c 49 54 45 5f 43 4f 4e  urn.# SQLITE_CON
b0f0: 53 54 52 41 49 4e 54 20 69 6d 6d 65 64 69 61 74  STRAINT immediat
b100: 65 6c 79 2c 20 6e 6f 74 20 61 66 74 65 72 20 72  ely, not after r
b110: 65 74 75 72 6e 69 6e 67 20 61 20 6e 75 6d 62 65  eturning a numbe
b120: 72 20 6f 66 20 72 6f 77 73 2e 0a 23 20 57 68 65  r of rows..# Whe
b130: 72 65 61 73 20 73 74 61 74 65 6d 65 6e 74 73 20  reas statements 
b140: 74 68 61 74 20 76 69 6f 6c 61 74 65 20 64 65 66  that violate def
b150: 65 72 72 65 64 20 46 4b 20 63 6f 6e 73 74 72 61  erred FK constra
b160: 69 6e 74 73 20 72 65 74 75 72 6e 20 74 68 65 20  ints return the 
b170: 6e 75 6d 62 65 72 0a 23 20 6f 66 20 72 6f 77 73  number.# of rows
b180: 20 62 65 66 6f 72 65 20 66 61 69 6c 69 6e 67 2e   before failing.
b190: 0a 23 0a 23 20 41 6c 73 6f 20 74 65 73 74 20 74  .#.# Also test t
b1a0: 68 61 74 20 72 6f 77 73 20 6d 6f 64 69 66 69 65  hat rows modifie
b1b0: 64 20 62 79 20 46 4b 20 61 63 74 69 6f 6e 73 20  d by FK actions 
b1c0: 61 72 65 20 6e 6f 74 20 63 6f 75 6e 74 65 64 20  are not counted 
b1d0: 69 6e 20 65 69 74 68 65 72 20 74 68 65 0a 23 20  in either the.# 
b1e0: 72 65 74 75 72 6e 65 64 20 72 6f 77 20 63 6f 75  returned row cou
b1f0: 6e 74 20 6f 72 20 74 68 65 20 76 61 6c 75 65 73  nt or the values
b200: 20 72 65 74 75 72 6e 65 64 20 62 79 20 73 71 6c   returned by sql
b210: 69 74 65 33 5f 63 68 61 6e 67 65 73 28 29 2e 20  ite3_changes(). 
b220: 4c 69 6b 65 0a 23 20 74 72 69 67 67 65 72 20 72  Like.# trigger r
b230: 65 6c 61 74 65 64 20 63 68 61 6e 67 65 73 2c 20  elated changes, 
b240: 74 68 65 79 20 61 72 65 20 69 6e 63 6c 75 64 65  they are include
b250: 64 20 69 6e 20 73 71 6c 69 74 65 33 5f 74 6f 74  d in sqlite3_tot
b260: 61 6c 5f 63 68 61 6e 67 65 73 28 29 20 74 68 6f  al_changes() tho
b270: 75 67 68 2e 0a 23 0a 64 72 6f 70 5f 61 6c 6c 5f  ugh..#.drop_all_
b280: 74 61 62 6c 65 73 0a 64 6f 5f 74 65 73 74 20 66  tables.do_test f
b290: 6b 65 79 32 2d 31 37 2e 31 2e 31 20 7b 0a 20 20  key2-17.1.1 {.  
b2a0: 65 78 65 63 73 71 6c 20 7b 20 50 52 41 47 4d 41  execsql { PRAGMA
b2b0: 20 63 6f 75 6e 74 5f 63 68 61 6e 67 65 73 20 3d   count_changes =
b2c0: 20 31 20 7d 0a 20 20 65 78 65 63 73 71 6c 20 7b   1 }.  execsql {
b2d0: 20 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42   .    CREATE TAB
b2e0: 4c 45 20 6f 6e 65 28 61 2c 20 62 2c 20 63 2c 20  LE one(a, b, c, 
b2f0: 55 4e 49 51 55 45 28 62 2c 20 63 29 29 3b 0a 20  UNIQUE(b, c));. 
b300: 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20     CREATE TABLE 
b310: 74 77 6f 28 64 2c 20 65 2c 20 66 2c 20 46 4f 52  two(d, e, f, FOR
b320: 45 49 47 4e 20 4b 45 59 28 65 2c 20 66 29 20 52  EIGN KEY(e, f) R
b330: 45 46 45 52 45 4e 43 45 53 20 6f 6e 65 28 62 2c  EFERENCES one(b,
b340: 20 63 29 29 3b 0a 20 20 20 20 49 4e 53 45 52 54   c));.    INSERT
b350: 20 49 4e 54 4f 20 6f 6e 65 20 56 41 4c 55 45 53   INTO one VALUES
b360: 28 31 2c 20 32 2c 20 33 29 3b 0a 20 20 7d 0a 7d  (1, 2, 3);.  }.}
b370: 20 7b 31 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65   {1}.do_test fke
b380: 79 32 2d 31 37 2e 31 2e 32 20 7b 0a 20 20 73 65  y2-17.1.2 {.  se
b390: 74 20 53 54 4d 54 20 5b 73 71 6c 69 74 65 33 5f  t STMT [sqlite3_
b3a0: 70 72 65 70 61 72 65 5f 76 32 20 64 62 20 22 49  prepare_v2 db "I
b3b0: 4e 53 45 52 54 20 49 4e 54 4f 20 74 77 6f 20 56  NSERT INTO two V
b3c0: 41 4c 55 45 53 28 34 2c 20 35 2c 20 36 29 22 20  ALUES(4, 5, 6)" 
b3d0: 2d 31 20 64 75 6d 6d 79 5d 0a 20 20 73 71 6c 69  -1 dummy].  sqli
b3e0: 74 65 33 5f 73 74 65 70 20 24 53 54 4d 54 0a 7d  te3_step $STMT.}
b3f0: 20 7b 53 51 4c 49 54 45 5f 43 4f 4e 53 54 52 41   {SQLITE_CONSTRA
b400: 49 4e 54 7d 0a 76 65 72 69 66 79 5f 65 78 5f 65  INT}.verify_ex_e
b410: 72 72 63 6f 64 65 20 66 6b 65 79 32 2d 31 37 2e  rrcode fkey2-17.
b420: 31 2e 32 62 20 53 51 4c 49 54 45 5f 43 4f 4e 53  1.2b SQLITE_CONS
b430: 54 52 41 49 4e 54 5f 46 4f 52 45 49 47 4e 4b 45  TRAINT_FOREIGNKE
b440: 59 0a 69 66 63 61 70 61 62 6c 65 20 61 75 74 6f  Y.ifcapable auto
b450: 72 65 73 65 74 20 7b 0a 20 20 64 6f 5f 74 65 73  reset {.  do_tes
b460: 74 20 66 6b 65 79 32 2d 31 37 2e 31 2e 33 20 7b  t fkey2-17.1.3 {
b470: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 73 74 65  .    sqlite3_ste
b480: 70 20 24 53 54 4d 54 0a 20 20 7d 20 7b 53 51 4c  p $STMT.  } {SQL
b490: 49 54 45 5f 43 4f 4e 53 54 52 41 49 4e 54 7d 0a  ITE_CONSTRAINT}.
b4a0: 20 20 76 65 72 69 66 79 5f 65 78 5f 65 72 72 63    verify_ex_errc
b4b0: 6f 64 65 20 66 6b 65 79 32 2d 31 37 2e 31 2e 33  ode fkey2-17.1.3
b4c0: 62 20 53 51 4c 49 54 45 5f 43 4f 4e 53 54 52 41  b SQLITE_CONSTRA
b4d0: 49 4e 54 5f 46 4f 52 45 49 47 4e 4b 45 59 0a 7d  INT_FOREIGNKEY.}
b4e0: 20 65 6c 73 65 20 7b 0a 20 20 64 6f 5f 74 65 73   else {.  do_tes
b4f0: 74 20 66 6b 65 79 32 2d 31 37 2e 31 2e 33 20 7b  t fkey2-17.1.3 {
b500: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 73 74 65  .    sqlite3_ste
b510: 70 20 24 53 54 4d 54 0a 20 20 7d 20 7b 53 51 4c  p $STMT.  } {SQL
b520: 49 54 45 5f 4d 49 53 55 53 45 7d 0a 7d 0a 64 6f  ITE_MISUSE}.}.do
b530: 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 37 2e 31  _test fkey2-17.1
b540: 2e 34 20 7b 0a 20 20 73 71 6c 69 74 65 33 5f 66  .4 {.  sqlite3_f
b550: 69 6e 61 6c 69 7a 65 20 24 53 54 4d 54 0a 7d 20  inalize $STMT.} 
b560: 7b 53 51 4c 49 54 45 5f 43 4f 4e 53 54 52 41 49  {SQLITE_CONSTRAI
b570: 4e 54 7d 0a 76 65 72 69 66 79 5f 65 78 5f 65 72  NT}.verify_ex_er
b580: 72 63 6f 64 65 20 66 6b 65 79 32 2d 31 37 2e 31  rcode fkey2-17.1
b590: 2e 34 62 20 53 51 4c 49 54 45 5f 43 4f 4e 53 54  .4b SQLITE_CONST
b5a0: 52 41 49 4e 54 5f 46 4f 52 45 49 47 4e 4b 45 59  RAINT_FOREIGNKEY
b5b0: 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31  .do_test fkey2-1
b5c0: 37 2e 31 2e 35 20 7b 0a 20 20 65 78 65 63 73 71  7.1.5 {.  execsq
b5d0: 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  l {.    INSERT I
b5e0: 4e 54 4f 20 6f 6e 65 20 56 41 4c 55 45 53 28 32  NTO one VALUES(2
b5f0: 2c 20 33 2c 20 34 29 3b 0a 20 20 20 20 49 4e 53  , 3, 4);.    INS
b600: 45 52 54 20 49 4e 54 4f 20 6f 6e 65 20 56 41 4c  ERT INTO one VAL
b610: 55 45 53 28 33 2c 20 34 2c 20 35 29 3b 0a 20 20  UES(3, 4, 5);.  
b620: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 77    INSERT INTO tw
b630: 6f 20 56 41 4c 55 45 53 28 31 2c 20 32 2c 20 33  o VALUES(1, 2, 3
b640: 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  );.    INSERT IN
b650: 54 4f 20 74 77 6f 20 56 41 4c 55 45 53 28 32 2c  TO two VALUES(2,
b660: 20 33 2c 20 34 29 3b 0a 20 20 20 20 49 4e 53 45   3, 4);.    INSE
b670: 52 54 20 49 4e 54 4f 20 74 77 6f 20 56 41 4c 55  RT INTO two VALU
b680: 45 53 28 33 2c 20 34 2c 20 35 29 3b 0a 20 20 7d  ES(3, 4, 5);.  }
b690: 0a 7d 20 7b 31 20 31 20 31 20 31 20 31 7d 0a 64  .} {1 1 1 1 1}.d
b6a0: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 37 2e  o_test fkey2-17.
b6b0: 31 2e 36 20 7b 0a 20 20 63 61 74 63 68 73 71 6c  1.6 {.  catchsql
b6c0: 20 7b 0a 20 20 20 20 42 45 47 49 4e 3b 0a 20 20   {.    BEGIN;.  
b6d0: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
b6e0: 6f 6e 65 20 56 41 4c 55 45 53 28 30 2c 20 30 2c  one VALUES(0, 0,
b6f0: 20 30 29 3b 0a 20 20 20 20 20 20 55 50 44 41 54   0);.      UPDAT
b700: 45 20 74 77 6f 20 53 45 54 20 65 3d 65 2b 31 2c  E two SET e=e+1,
b710: 20 66 3d 66 2b 31 3b 0a 20 20 7d 0a 7d 20 7b 31   f=f+1;.  }.} {1
b720: 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f   {FOREIGN KEY co
b730: 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d  nstraint failed}
b740: 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d  }.do_test fkey2-
b750: 31 37 2e 31 2e 37 20 7b 0a 20 20 65 78 65 63 73  17.1.7 {.  execs
b760: 71 6c 20 7b 20 53 45 4c 45 43 54 20 2a 20 46 52  ql { SELECT * FR
b770: 4f 4d 20 6f 6e 65 20 7d 0a 7d 20 7b 31 20 32 20  OM one }.} {1 2 
b780: 33 20 32 20 33 20 34 20 33 20 34 20 35 20 30 20  3 2 3 4 3 4 5 0 
b790: 30 20 30 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65  0 0}.do_test fke
b7a0: 79 32 2d 31 37 2e 31 2e 38 20 7b 0a 20 20 65 78  y2-17.1.8 {.  ex
b7b0: 65 63 73 71 6c 20 7b 20 53 45 4c 45 43 54 20 2a  ecsql { SELECT *
b7c0: 20 46 52 4f 4d 20 74 77 6f 20 7d 0a 7d 20 7b 31   FROM two }.} {1
b7d0: 20 32 20 33 20 32 20 33 20 34 20 33 20 34 20 35   2 3 2 3 4 3 4 5
b7e0: 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d  }.do_test fkey2-
b7f0: 31 37 2e 31 2e 39 20 7b 0a 20 20 65 78 65 63 73  17.1.9 {.  execs
b800: 71 6c 20 43 4f 4d 4d 49 54 0a 7d 20 7b 7d 0a 64  ql COMMIT.} {}.d
b810: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 37 2e  o_test fkey2-17.
b820: 31 2e 31 30 20 7b 0a 20 20 65 78 65 63 73 71 6c  1.10 {.  execsql
b830: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41   {.    CREATE TA
b840: 42 4c 45 20 74 68 72 65 65 28 0a 20 20 20 20 20  BLE three(.     
b850: 20 67 2c 20 68 2c 20 69 2c 20 0a 20 20 20 20 20   g, h, i, .     
b860: 20 46 4f 52 45 49 47 4e 20 4b 45 59 28 68 2c 20   FOREIGN KEY(h, 
b870: 69 29 20 52 45 46 45 52 45 4e 43 45 53 20 6f 6e  i) REFERENCES on
b880: 65 28 62 2c 20 63 29 20 44 45 46 45 52 52 41 42  e(b, c) DEFERRAB
b890: 4c 45 20 49 4e 49 54 49 41 4c 4c 59 20 44 45 46  LE INITIALLY DEF
b8a0: 45 52 52 45 44 0a 20 20 20 20 29 3b 0a 20 20 7d  ERRED.    );.  }
b8b0: 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b  .} {}.do_test fk
b8c0: 65 79 32 2d 31 37 2e 31 2e 31 31 20 7b 0a 20 20  ey2-17.1.11 {.  
b8d0: 73 65 74 20 53 54 4d 54 20 5b 73 71 6c 69 74 65  set STMT [sqlite
b8e0: 33 5f 70 72 65 70 61 72 65 5f 76 32 20 64 62 20  3_prepare_v2 db 
b8f0: 22 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 68 72  "INSERT INTO thr
b900: 65 65 20 56 41 4c 55 45 53 28 37 2c 20 38 2c 20  ee VALUES(7, 8, 
b910: 39 29 22 20 2d 31 20 64 75 6d 6d 79 5d 0a 20 20  9)" -1 dummy].  
b920: 73 71 6c 69 74 65 33 5f 73 74 65 70 20 24 53 54  sqlite3_step $ST
b930: 4d 54 0a 7d 20 7b 53 51 4c 49 54 45 5f 52 4f 57  MT.} {SQLITE_ROW
b940: 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d  }.do_test fkey2-
b950: 31 37 2e 31 2e 31 32 20 7b 0a 20 20 73 71 6c 69  17.1.12 {.  sqli
b960: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 20  te3_column_text 
b970: 24 53 54 4d 54 20 30 0a 7d 20 7b 31 7d 0a 64 6f  $STMT 0.} {1}.do
b980: 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 37 2e 31  _test fkey2-17.1
b990: 2e 31 33 20 7b 0a 20 20 73 71 6c 69 74 65 33 5f  .13 {.  sqlite3_
b9a0: 73 74 65 70 20 24 53 54 4d 54 0a 7d 20 7b 53 51  step $STMT.} {SQ
b9b0: 4c 49 54 45 5f 43 4f 4e 53 54 52 41 49 4e 54 7d  LITE_CONSTRAINT}
b9c0: 0a 76 65 72 69 66 79 5f 65 78 5f 65 72 72 63 6f  .verify_ex_errco
b9d0: 64 65 20 66 6b 65 79 32 2d 31 37 2e 31 2e 31 33  de fkey2-17.1.13
b9e0: 62 20 53 51 4c 49 54 45 5f 43 4f 4e 53 54 52 41  b SQLITE_CONSTRA
b9f0: 49 4e 54 5f 46 4f 52 45 49 47 4e 4b 45 59 0a 64  INT_FOREIGNKEY.d
ba00: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 37 2e  o_test fkey2-17.
ba10: 31 2e 31 34 20 7b 0a 20 20 73 71 6c 69 74 65 33  1.14 {.  sqlite3
ba20: 5f 66 69 6e 61 6c 69 7a 65 20 24 53 54 4d 54 0a  _finalize $STMT.
ba30: 7d 20 7b 53 51 4c 49 54 45 5f 43 4f 4e 53 54 52  } {SQLITE_CONSTR
ba40: 41 49 4e 54 7d 0a 76 65 72 69 66 79 5f 65 78 5f  AINT}.verify_ex_
ba50: 65 72 72 63 6f 64 65 20 66 6b 65 79 32 2d 31 37  errcode fkey2-17
ba60: 2e 31 2e 31 34 62 20 53 51 4c 49 54 45 5f 43 4f  .1.14b SQLITE_CO
ba70: 4e 53 54 52 41 49 4e 54 5f 46 4f 52 45 49 47 4e  NSTRAINT_FOREIGN
ba80: 4b 45 59 0a 0a 64 72 6f 70 5f 61 6c 6c 5f 74 61  KEY..drop_all_ta
ba90: 62 6c 65 73 0a 64 6f 5f 74 65 73 74 20 66 6b 65  bles.do_test fke
baa0: 79 32 2d 31 37 2e 32 2e 31 20 7b 0a 20 20 65 78  y2-17.2.1 {.  ex
bab0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41  ecsql {.    CREA
bac0: 54 45 20 54 41 42 4c 45 20 68 69 67 68 28 22 61  TE TABLE high("a
bad0: 27 62 21 22 20 50 52 49 4d 41 52 59 20 4b 45 59  'b!" PRIMARY KEY
bae0: 2c 20 62 29 3b 0a 20 20 20 20 43 52 45 41 54 45  , b);.    CREATE
baf0: 20 54 41 42 4c 45 20 6c 6f 77 28 0a 20 20 20 20   TABLE low(.    
bb00: 20 20 63 2c 20 0a 20 20 20 20 20 20 22 64 26 36    c, .      "d&6
bb10: 22 20 52 45 46 45 52 45 4e 43 45 53 20 68 69 67  " REFERENCES hig
bb20: 68 20 4f 4e 20 55 50 44 41 54 45 20 43 41 53 43  h ON UPDATE CASC
bb30: 41 44 45 20 4f 4e 20 44 45 4c 45 54 45 20 43 41  ADE ON DELETE CA
bb40: 53 43 41 44 45 0a 20 20 20 20 29 3b 0a 20 20 7d  SCADE.    );.  }
bb50: 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b  .} {}.do_test fk
bb60: 65 79 32 2d 31 37 2e 32 2e 32 20 7b 0a 20 20 65  ey2-17.2.2 {.  e
bb70: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53  xecsql {.    INS
bb80: 45 52 54 20 49 4e 54 4f 20 68 69 67 68 20 56 41  ERT INTO high VA
bb90: 4c 55 45 53 28 27 61 27 2c 20 27 62 27 29 3b 0a  LUES('a', 'b');.
bba0: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
bbb0: 6c 6f 77 20 56 41 4c 55 45 53 28 27 62 27 2c 20  low VALUES('b', 
bbc0: 27 61 27 29 3b 0a 20 20 7d 0a 20 20 64 62 20 63  'a');.  }.  db c
bbd0: 68 61 6e 67 65 73 0a 7d 20 7b 31 7d 0a 73 65 74  hanges.} {1}.set
bbe0: 20 6e 54 6f 74 61 6c 20 5b 64 62 20 74 6f 74 61   nTotal [db tota
bbf0: 6c 5f 63 68 61 6e 67 65 73 5d 0a 64 6f 5f 74 65  l_changes].do_te
bc00: 73 74 20 66 6b 65 79 32 2d 31 37 2e 32 2e 33 20  st fkey2-17.2.3 
bc10: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 55 50  {.  execsql { UP
bc20: 44 41 54 45 20 68 69 67 68 20 53 45 54 20 22 61  DATE high SET "a
bc30: 27 62 21 22 20 3d 20 27 63 27 20 7d 0a 7d 20 7b  'b!" = 'c' }.} {
bc40: 31 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  1}.do_test fkey2
bc50: 2d 31 37 2e 32 2e 34 20 7b 0a 20 20 64 62 20 63  -17.2.4 {.  db c
bc60: 68 61 6e 67 65 73 0a 7d 20 7b 31 7d 0a 64 6f 5f  hanges.} {1}.do_
bc70: 74 65 73 74 20 66 6b 65 79 32 2d 31 37 2e 32 2e  test fkey2-17.2.
bc80: 35 20 7b 0a 20 20 65 78 70 72 20 5b 64 62 20 74  5 {.  expr [db t
bc90: 6f 74 61 6c 5f 63 68 61 6e 67 65 73 5d 20 2d 20  otal_changes] - 
bca0: 24 6e 54 6f 74 61 6c 0a 7d 20 7b 32 7d 0a 64 6f  $nTotal.} {2}.do
bcb0: 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 37 2e 32  _test fkey2-17.2
bcc0: 2e 36 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .6 {.  execsql {
bcd0: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 68   SELECT * FROM h
bce0: 69 67 68 20 3b 20 53 45 4c 45 43 54 20 2a 20 46  igh ; SELECT * F
bcf0: 52 4f 4d 20 6c 6f 77 20 7d 0a 7d 20 7b 63 20 62  ROM low }.} {c b
bd00: 20 62 20 63 7d 0a 64 6f 5f 74 65 73 74 20 66 6b   b c}.do_test fk
bd10: 65 79 32 2d 31 37 2e 32 2e 37 20 7b 0a 20 20 65  ey2-17.2.7 {.  e
bd20: 78 65 63 73 71 6c 20 7b 20 44 45 4c 45 54 45 20  xecsql { DELETE 
bd30: 46 52 4f 4d 20 68 69 67 68 20 7d 0a 7d 20 7b 31  FROM high }.} {1
bd40: 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d  }.do_test fkey2-
bd50: 31 37 2e 32 2e 38 20 7b 0a 20 20 64 62 20 63 68  17.2.8 {.  db ch
bd60: 61 6e 67 65 73 0a 7d 20 7b 31 7d 0a 64 6f 5f 74  anges.} {1}.do_t
bd70: 65 73 74 20 66 6b 65 79 32 2d 31 37 2e 32 2e 39  est fkey2-17.2.9
bd80: 20 7b 0a 20 20 65 78 70 72 20 5b 64 62 20 74 6f   {.  expr [db to
bd90: 74 61 6c 5f 63 68 61 6e 67 65 73 5d 20 2d 20 24  tal_changes] - $
bda0: 6e 54 6f 74 61 6c 0a 7d 20 7b 34 7d 0a 64 6f 5f  nTotal.} {4}.do_
bdb0: 74 65 73 74 20 66 6b 65 79 32 2d 31 37 2e 32 2e  test fkey2-17.2.
bdc0: 31 30 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  10 {.  execsql {
bdd0: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 68   SELECT * FROM h
bde0: 69 67 68 20 3b 20 53 45 4c 45 43 54 20 2a 20 46  igh ; SELECT * F
bdf0: 52 4f 4d 20 6c 6f 77 20 7d 0a 7d 20 7b 7d 0a 65  ROM low }.} {}.e
be00: 78 65 63 73 71 6c 20 7b 20 50 52 41 47 4d 41 20  xecsql { PRAGMA 
be10: 63 6f 75 6e 74 5f 63 68 61 6e 67 65 73 20 3d 20  count_changes = 
be20: 30 20 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  0 }..#----------
be30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
be40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
be50: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
be60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a  ---------------.
be70: 23 20 54 65 73 74 20 74 68 61 74 20 74 68 65 20  # Test that the 
be80: 61 75 74 68 6f 72 69 7a 61 74 69 6f 6e 20 63 61  authorization ca
be90: 6c 6c 62 61 63 6b 20 77 6f 72 6b 73 2e 0a 23 0a  llback works..#.
bea0: 0a 69 66 63 61 70 61 62 6c 65 20 61 75 74 68 20  .ifcapable auth 
beb0: 7b 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79  {.  do_test fkey
bec0: 32 2d 31 38 2e 31 20 7b 0a 20 20 20 20 65 78 65  2-18.1 {.    exe
bed0: 63 73 71 6c 20 7b 0a 20 20 20 20 20 20 43 52 45  csql {.      CRE
bee0: 41 54 45 20 54 41 42 4c 45 20 6c 6f 6e 67 28 61  ATE TABLE long(a
bef0: 2c 20 62 20 50 52 49 4d 41 52 59 20 4b 45 59 2c  , b PRIMARY KEY,
bf00: 20 63 29 3b 0a 20 20 20 20 20 20 43 52 45 41 54   c);.      CREAT
bf10: 45 20 54 41 42 4c 45 20 73 68 6f 72 74 28 64 2c  E TABLE short(d,
bf20: 20 65 2c 20 66 20 52 45 46 45 52 45 4e 43 45 53   e, f REFERENCES
bf30: 20 6c 6f 6e 67 29 3b 0a 20 20 20 20 20 20 43 52   long);.      CR
bf40: 45 41 54 45 20 54 41 42 4c 45 20 6d 69 64 28 67  EATE TABLE mid(g
bf50: 2c 20 68 2c 20 69 20 52 45 46 45 52 45 4e 43 45  , h, i REFERENCE
bf60: 53 20 6c 6f 6e 67 20 44 45 46 45 52 52 41 42 4c  S long DEFERRABL
bf70: 45 20 49 4e 49 54 49 41 4c 4c 59 20 44 45 46 45  E INITIALLY DEFE
bf80: 52 52 45 44 29 3b 0a 20 20 20 20 7d 0a 20 20 7d  RRED);.    }.  }
bf90: 20 7b 7d 0a 0a 20 20 70 72 6f 63 20 61 75 74 68   {}..  proc auth
bfa0: 20 7b 61 72 67 73 7d 20 7b 65 76 61 6c 20 6c 61   {args} {eval la
bfb0: 70 70 65 6e 64 20 3a 3a 61 75 74 68 61 72 67 73  ppend ::authargs
bfc0: 20 5b 6c 72 61 6e 67 65 20 24 61 72 67 73 20 30   [lrange $args 0
bfd0: 20 34 5d 3b 20 72 65 74 75 72 6e 20 53 51 4c 49   4]; return SQLI
bfe0: 54 45 5f 4f 4b 7d 0a 20 20 64 62 20 61 75 74 68  TE_OK}.  db auth
bff0: 20 61 75 74 68 0a 0a 20 20 23 20 41 6e 20 69 6e   auth..  # An in
c000: 73 65 72 74 20 6f 6e 20 74 68 65 20 70 61 72 65  sert on the pare
c010: 6e 74 20 74 61 62 6c 65 20 6d 75 73 74 20 72 65  nt table must re
c020: 61 64 20 74 68 65 20 63 68 69 6c 64 20 6b 65 79  ad the child key
c030: 20 6f 66 20 61 6e 79 20 64 65 66 65 72 72 65 64   of any deferred
c040: 0a 20 20 23 20 66 6f 72 65 69 67 6e 20 6b 65 79  .  # foreign key
c050: 20 63 6f 6e 73 74 72 61 69 6e 74 73 2e 20 42 75   constraints. Bu
c060: 74 20 6e 6f 74 20 74 68 65 20 63 68 69 6c 64 20  t not the child 
c070: 6b 65 79 20 6f 66 20 69 6d 6d 65 64 69 61 74 65  key of immediate
c080: 20 63 6f 6e 73 74 72 61 69 6e 74 73 2e 0a 20 20   constraints..  
c090: 73 65 74 20 61 75 74 68 61 72 67 73 20 7b 7d 0a  set authargs {}.
c0a0: 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d    do_test fkey2-
c0b0: 31 38 2e 32 20 7b 0a 20 20 20 20 65 78 65 63 73  18.2 {.    execs
c0c0: 71 6c 20 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f  ql { INSERT INTO
c0d0: 20 6c 6f 6e 67 20 56 41 4c 55 45 53 28 31 2c 20   long VALUES(1, 
c0e0: 32 2c 20 33 29 20 7d 0a 20 20 20 20 73 65 74 20  2, 3) }.    set 
c0f0: 61 75 74 68 61 72 67 73 0a 20 20 7d 20 7b 53 51  authargs.  } {SQ
c100: 4c 49 54 45 5f 49 4e 53 45 52 54 20 6c 6f 6e 67  LITE_INSERT long
c110: 20 7b 7d 20 6d 61 69 6e 20 7b 7d 20 53 51 4c 49   {} main {} SQLI
c120: 54 45 5f 52 45 41 44 20 6d 69 64 20 69 20 6d 61  TE_READ mid i ma
c130: 69 6e 20 7b 7d 7d 0a 0a 20 20 23 20 41 6e 20 69  in {}}..  # An i
c140: 6e 73 65 72 74 20 6f 6e 20 74 68 65 20 63 68 69  nsert on the chi
c150: 6c 64 20 74 61 62 6c 65 20 6f 66 20 61 6e 20 69  ld table of an i
c160: 6d 6d 65 64 69 61 74 65 20 63 6f 6e 73 74 72 61  mmediate constra
c170: 69 6e 74 20 6d 75 73 74 20 72 65 61 64 20 74 68  int must read th
c180: 65 0a 20 20 23 20 70 61 72 65 6e 74 20 6b 65 79  e.  # parent key
c190: 20 63 6f 6c 75 6d 6e 73 20 28 74 6f 20 73 65 65   columns (to see
c1a0: 20 69 66 20 69 74 20 69 73 20 61 20 76 69 6f 6c   if it is a viol
c1b0: 61 74 69 6f 6e 20 6f 72 20 6e 6f 74 29 2e 0a 20  ation or not).. 
c1c0: 20 73 65 74 20 61 75 74 68 61 72 67 73 20 7b 7d   set authargs {}
c1d0: 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  .  do_test fkey2
c1e0: 2d 31 38 2e 33 20 7b 0a 20 20 20 20 65 78 65 63  -18.3 {.    exec
c1f0: 73 71 6c 20 7b 20 49 4e 53 45 52 54 20 49 4e 54  sql { INSERT INT
c200: 4f 20 73 68 6f 72 74 20 56 41 4c 55 45 53 28 31  O short VALUES(1
c210: 2c 20 33 2c 20 32 29 20 7d 0a 20 20 20 20 73 65  , 3, 2) }.    se
c220: 74 20 61 75 74 68 61 72 67 73 0a 20 20 7d 20 7b  t authargs.  } {
c230: 53 51 4c 49 54 45 5f 49 4e 53 45 52 54 20 73 68  SQLITE_INSERT sh
c240: 6f 72 74 20 7b 7d 20 6d 61 69 6e 20 7b 7d 20 53  ort {} main {} S
c250: 51 4c 49 54 45 5f 52 45 41 44 20 6c 6f 6e 67 20  QLITE_READ long 
c260: 62 20 6d 61 69 6e 20 7b 7d 7d 0a 20 20 0a 20 20  b main {}}.  .  
c270: 23 20 41 73 20 6d 75 73 74 20 61 6e 20 69 6e 73  # As must an ins
c280: 65 72 74 20 6f 6e 20 74 68 65 20 63 68 69 6c 64  ert on the child
c290: 20 74 61 62 6c 65 20 6f 66 20 61 20 64 65 66 65   table of a defe
c2a0: 72 72 65 64 20 63 6f 6e 73 74 72 61 69 6e 74 2e  rred constraint.
c2b0: 0a 20 20 73 65 74 20 61 75 74 68 61 72 67 73 20  .  set authargs 
c2c0: 7b 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65  {}.  do_test fke
c2d0: 79 32 2d 31 38 2e 34 20 7b 0a 20 20 20 20 65 78  y2-18.4 {.    ex
c2e0: 65 63 73 71 6c 20 7b 20 49 4e 53 45 52 54 20 49  ecsql { INSERT I
c2f0: 4e 54 4f 20 6d 69 64 20 56 41 4c 55 45 53 28 31  NTO mid VALUES(1
c300: 2c 20 33 2c 20 32 29 20 7d 0a 20 20 20 20 73 65  , 3, 2) }.    se
c310: 74 20 61 75 74 68 61 72 67 73 0a 20 20 7d 20 7b  t authargs.  } {
c320: 53 51 4c 49 54 45 5f 49 4e 53 45 52 54 20 6d 69  SQLITE_INSERT mi
c330: 64 20 7b 7d 20 6d 61 69 6e 20 7b 7d 20 53 51 4c  d {} main {} SQL
c340: 49 54 45 5f 52 45 41 44 20 6c 6f 6e 67 20 62 20  ITE_READ long b 
c350: 6d 61 69 6e 20 7b 7d 7d 0a 0a 20 20 64 6f 5f 74  main {}}..  do_t
c360: 65 73 74 20 66 6b 65 79 32 2d 31 38 2e 35 20 7b  est fkey2-18.5 {
c370: 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20  .    execsql {. 
c380: 20 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c       CREATE TABL
c390: 45 20 6e 6f 75 67 68 74 28 61 2c 20 62 20 50 52  E nought(a, b PR
c3a0: 49 4d 41 52 59 20 4b 45 59 2c 20 63 29 3b 0a 20  IMARY KEY, c);. 
c3b0: 20 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c       CREATE TABL
c3c0: 45 20 63 72 6f 73 73 28 64 2c 20 65 2c 20 66 2c  E cross(d, e, f,
c3d0: 0a 20 20 20 20 20 20 20 20 46 4f 52 45 49 47 4e  .        FOREIGN
c3e0: 20 4b 45 59 28 65 29 20 52 45 46 45 52 45 4e 43   KEY(e) REFERENC
c3f0: 45 53 20 6e 6f 75 67 68 74 28 62 29 20 4f 4e 20  ES nought(b) ON 
c400: 55 50 44 41 54 45 20 43 41 53 43 41 44 45 0a 20  UPDATE CASCADE. 
c410: 20 20 20 20 20 29 3b 0a 20 20 20 20 7d 0a 20 20       );.    }.  
c420: 20 20 65 78 65 63 73 71 6c 20 7b 20 49 4e 53 45    execsql { INSE
c430: 52 54 20 49 4e 54 4f 20 6e 6f 75 67 68 74 20 56  RT INTO nought V
c440: 41 4c 55 45 53 28 32 2c 20 31 2c 20 32 29 20 7d  ALUES(2, 1, 2) }
c450: 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20 49  .    execsql { I
c460: 4e 53 45 52 54 20 49 4e 54 4f 20 63 72 6f 73 73  NSERT INTO cross
c470: 20 56 41 4c 55 45 53 28 30 2c 20 31 2c 20 30 29   VALUES(0, 1, 0)
c480: 20 7d 0a 20 20 20 20 73 65 74 20 61 75 74 68 61   }.    set autha
c490: 72 67 73 20 5b 6c 69 73 74 5d 0a 20 20 20 20 65  rgs [list].    e
c4a0: 78 65 63 73 71 6c 20 7b 20 55 50 44 41 54 45 20  xecsql { UPDATE 
c4b0: 6e 6f 75 67 68 74 20 53 45 54 20 62 20 3d 20 35  nought SET b = 5
c4c0: 20 7d 0a 20 20 20 20 73 65 74 20 61 75 74 68 61   }.    set autha
c4d0: 72 67 73 0a 20 20 7d 20 7b 53 51 4c 49 54 45 5f  rgs.  } {SQLITE_
c4e0: 55 50 44 41 54 45 20 6e 6f 75 67 68 74 20 62 20  UPDATE nought b 
c4f0: 6d 61 69 6e 20 7b 7d 20 53 51 4c 49 54 45 5f 52  main {} SQLITE_R
c500: 45 41 44 20 63 72 6f 73 73 20 65 20 6d 61 69 6e  EAD cross e main
c510: 20 7b 7d 20 53 51 4c 49 54 45 5f 52 45 41 44 20   {} SQLITE_READ 
c520: 63 72 6f 73 73 20 65 20 6d 61 69 6e 20 7b 7d 20  cross e main {} 
c530: 53 51 4c 49 54 45 5f 52 45 41 44 20 6e 6f 75 67  SQLITE_READ noug
c540: 68 74 20 62 20 6d 61 69 6e 20 7b 7d 20 53 51 4c  ht b main {} SQL
c550: 49 54 45 5f 52 45 41 44 20 6e 6f 75 67 68 74 20  ITE_READ nought 
c560: 62 20 6d 61 69 6e 20 7b 7d 20 53 51 4c 49 54 45  b main {} SQLITE
c570: 5f 52 45 41 44 20 6e 6f 75 67 68 74 20 62 20 6d  _READ nought b m
c580: 61 69 6e 20 7b 7d 20 53 51 4c 49 54 45 5f 55 50  ain {} SQLITE_UP
c590: 44 41 54 45 20 63 72 6f 73 73 20 65 20 6d 61 69  DATE cross e mai
c5a0: 6e 20 7b 7d 20 53 51 4c 49 54 45 5f 52 45 41 44  n {} SQLITE_READ
c5b0: 20 6e 6f 75 67 68 74 20 62 20 6d 61 69 6e 20 7b   nought b main {
c5c0: 7d 20 53 51 4c 49 54 45 5f 52 45 41 44 20 63 72  } SQLITE_READ cr
c5d0: 6f 73 73 20 65 20 6d 61 69 6e 20 7b 7d 20 53 51  oss e main {} SQ
c5e0: 4c 49 54 45 5f 52 45 41 44 20 6e 6f 75 67 68 74  LITE_READ nought
c5f0: 20 62 20 6d 61 69 6e 20 7b 7d 20 53 51 4c 49 54   b main {} SQLIT
c600: 45 5f 52 45 41 44 20 6e 6f 75 67 68 74 20 62 20  E_READ nought b 
c610: 6d 61 69 6e 20 7b 7d 7d 0a 0a 20 20 64 6f 5f 74  main {}}..  do_t
c620: 65 73 74 20 66 6b 65 79 32 2d 31 38 2e 36 20 7b  est fkey2-18.6 {
c630: 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 53 45  .    execsql {SE
c640: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 63 72 6f 73  LECT * FROM cros
c650: 73 7d 0a 20 20 7d 20 7b 30 20 35 20 30 7d 0a 0a  s}.  } {0 5 0}..
c660: 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d    do_test fkey2-
c670: 31 38 2e 37 20 7b 0a 20 20 20 20 65 78 65 63 73  18.7 {.    execs
c680: 71 6c 20 7b 0a 20 20 20 20 20 20 43 52 45 41 54  ql {.      CREAT
c690: 45 20 54 41 42 4c 45 20 6f 6e 65 28 61 20 49 4e  E TABLE one(a IN
c6a0: 54 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b 45  TEGER PRIMARY KE
c6b0: 59 2c 20 62 29 3b 0a 20 20 20 20 20 20 43 52 45  Y, b);.      CRE
c6c0: 41 54 45 20 54 41 42 4c 45 20 74 77 6f 28 62 2c  ATE TABLE two(b,
c6d0: 20 63 20 52 45 46 45 52 45 4e 43 45 53 20 6f 6e   c REFERENCES on
c6e0: 65 29 3b 0a 20 20 20 20 20 20 49 4e 53 45 52 54  e);.      INSERT
c6f0: 20 49 4e 54 4f 20 6f 6e 65 20 56 41 4c 55 45 53   INTO one VALUES
c700: 28 31 30 31 2c 20 31 30 32 29 3b 0a 20 20 20 20  (101, 102);.    
c710: 7d 0a 20 20 20 20 73 65 74 20 61 75 74 68 61 72  }.    set authar
c720: 67 73 20 5b 6c 69 73 74 5d 0a 20 20 20 20 65 78  gs [list].    ex
c730: 65 63 73 71 6c 20 7b 20 49 4e 53 45 52 54 20 49  ecsql { INSERT I
c740: 4e 54 4f 20 74 77 6f 20 56 41 4c 55 45 53 28 31  NTO two VALUES(1
c750: 30 30 2c 20 31 30 31 29 3b 20 7d 0a 20 20 20 20  00, 101); }.    
c760: 73 65 74 20 61 75 74 68 61 72 67 73 0a 20 20 7d  set authargs.  }
c770: 20 7b 53 51 4c 49 54 45 5f 49 4e 53 45 52 54 20   {SQLITE_INSERT 
c780: 74 77 6f 20 7b 7d 20 6d 61 69 6e 20 7b 7d 20 53  two {} main {} S
c790: 51 4c 49 54 45 5f 52 45 41 44 20 6f 6e 65 20 61  QLITE_READ one a
c7a0: 20 6d 61 69 6e 20 7b 7d 7d 0a 0a 20 20 23 20 52   main {}}..  # R
c7b0: 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 49 47 4e  eturn SQLITE_IGN
c7c0: 4f 52 45 20 74 6f 20 72 65 71 75 65 73 74 73 20  ORE to requests 
c7d0: 74 6f 20 72 65 61 64 20 66 72 6f 6d 20 74 68 65  to read from the
c7e0: 20 70 61 72 65 6e 74 20 74 61 62 6c 65 2e 20 54   parent table. T
c7f0: 68 69 73 0a 20 20 23 20 63 61 75 73 65 73 20 69  his.  # causes i
c800: 6e 73 65 72 74 73 20 6f 66 20 6e 6f 6e 2d 4e 55  nserts of non-NU
c810: 4c 4c 20 6b 65 79 73 20 69 6e 74 6f 20 74 68 65  LL keys into the
c820: 20 63 68 69 6c 64 20 74 61 62 6c 65 20 74 6f 20   child table to 
c830: 66 61 69 6c 2e 0a 20 20 23 0a 20 20 72 65 6e 61  fail..  #.  rena
c840: 6d 65 20 61 75 74 68 20 7b 7d 0a 20 20 70 72 6f  me auth {}.  pro
c850: 63 20 61 75 74 68 20 7b 61 72 67 73 7d 20 7b 0a  c auth {args} {.
c860: 20 20 20 20 69 66 20 7b 5b 6c 69 6e 64 65 78 20      if {[lindex 
c870: 24 61 72 67 73 20 31 5d 20 3d 3d 20 22 6c 6f 6e  $args 1] == "lon
c880: 67 22 7d 20 7b 72 65 74 75 72 6e 20 53 51 4c 49  g"} {return SQLI
c890: 54 45 5f 49 47 4e 4f 52 45 7d 0a 20 20 20 20 72  TE_IGNORE}.    r
c8a0: 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 0a  eturn SQLITE_OK.
c8b0: 20 20 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b    }.  do_test fk
c8c0: 65 79 32 2d 31 38 2e 38 20 7b 0a 20 20 20 20 63  ey2-18.8 {.    c
c8d0: 61 74 63 68 73 71 6c 20 7b 20 49 4e 53 45 52 54  atchsql { INSERT
c8e0: 20 49 4e 54 4f 20 73 68 6f 72 74 20 56 41 4c 55   INTO short VALU
c8f0: 45 53 28 31 2c 20 33 2c 20 32 29 20 7d 0a 20 20  ES(1, 3, 2) }.  
c900: 7d 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45  } {1 {FOREIGN KE
c910: 59 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69  Y constraint fai
c920: 6c 65 64 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20  led}}.  do_test 
c930: 66 6b 65 79 32 2d 31 38 2e 39 20 7b 0a 20 20 20  fkey2-18.9 {.   
c940: 20 65 78 65 63 73 71 6c 20 7b 20 49 4e 53 45 52   execsql { INSER
c950: 54 20 49 4e 54 4f 20 73 68 6f 72 74 20 56 41 4c  T INTO short VAL
c960: 55 45 53 28 31 2c 20 33 2c 20 4e 55 4c 4c 29 20  UES(1, 3, NULL) 
c970: 7d 0a 20 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74 65  }.  } {}.  do_te
c980: 73 74 20 66 6b 65 79 32 2d 31 38 2e 31 30 20 7b  st fkey2-18.10 {
c990: 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20 53  .    execsql { S
c9a0: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 73 68 6f  ELECT * FROM sho
c9b0: 72 74 20 7d 0a 20 20 7d 20 7b 31 20 33 20 32 20  rt }.  } {1 3 2 
c9c0: 31 20 33 20 7b 7d 7d 0a 20 20 64 6f 5f 74 65 73  1 3 {}}.  do_tes
c9d0: 74 20 66 6b 65 79 32 2d 31 38 2e 31 31 20 7b 0a  t fkey2-18.11 {.
c9e0: 20 20 20 20 63 61 74 63 68 73 71 6c 20 7b 20 55      catchsql { U
c9f0: 50 44 41 54 45 20 73 68 6f 72 74 20 53 45 54 20  PDATE short SET 
ca00: 66 20 3d 20 32 20 57 48 45 52 45 20 66 20 49 53  f = 2 WHERE f IS
ca10: 20 4e 55 4c 4c 20 7d 0a 20 20 7d 20 7b 31 20 7b   NULL }.  } {1 {
ca20: 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73  FOREIGN KEY cons
ca30: 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a  traint failed}}.
ca40: 0a 20 20 64 62 20 61 75 74 68 20 7b 7d 0a 20 20  .  db auth {}.  
ca50: 75 6e 73 65 74 20 61 75 74 68 61 72 67 73 0a 7d  unset authargs.}
ca60: 0a 0a 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  ...do_test fkey2
ca70: 2d 31 39 2e 31 20 7b 0a 20 20 65 78 65 63 73 71  -19.1 {.  execsq
ca80: 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54  l {.    CREATE T
ca90: 41 42 4c 45 20 6d 61 69 6e 28 69 64 20 49 4e 54  ABLE main(id INT
caa0: 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b 45 59  EGER PRIMARY KEY
cab0: 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41  );.    CREATE TA
cac0: 42 4c 45 20 73 75 62 28 69 64 20 49 4e 54 20 52  BLE sub(id INT R
cad0: 45 46 45 52 45 4e 43 45 53 20 6d 61 69 6e 28 69  EFERENCES main(i
cae0: 64 29 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  d));.    INSERT 
caf0: 49 4e 54 4f 20 6d 61 69 6e 20 56 41 4c 55 45 53  INTO main VALUES
cb00: 28 31 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  (1);.    INSERT 
cb10: 49 4e 54 4f 20 6d 61 69 6e 20 56 41 4c 55 45 53  INTO main VALUES
cb20: 28 32 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  (2);.    INSERT 
cb30: 49 4e 54 4f 20 73 75 62 20 56 41 4c 55 45 53 28  INTO sub VALUES(
cb40: 32 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f  2);.  }.} {}.do_
cb50: 74 65 73 74 20 66 6b 65 79 32 2d 31 39 2e 32 20  test fkey2-19.2 
cb60: 7b 0a 20 20 73 65 74 20 53 20 5b 73 71 6c 69 74  {.  set S [sqlit
cb70: 65 33 5f 70 72 65 70 61 72 65 5f 76 32 20 64 62  e3_prepare_v2 db
cb80: 20 22 44 45 4c 45 54 45 20 46 52 4f 4d 20 6d 61   "DELETE FROM ma
cb90: 69 6e 20 57 48 45 52 45 20 69 64 20 3d 20 3f 22  in WHERE id = ?"
cba0: 20 2d 31 20 64 75 6d 6d 79 5d 0a 20 20 73 71 6c   -1 dummy].  sql
cbb0: 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74 20 24 53  ite3_bind_int $S
cbc0: 20 31 20 32 0a 20 20 73 71 6c 69 74 65 33 5f 73   1 2.  sqlite3_s
cbd0: 74 65 70 20 24 53 0a 7d 20 7b 53 51 4c 49 54 45  tep $S.} {SQLITE
cbe0: 5f 43 4f 4e 53 54 52 41 49 4e 54 7d 0a 76 65 72  _CONSTRAINT}.ver
cbf0: 69 66 79 5f 65 78 5f 65 72 72 63 6f 64 65 20 66  ify_ex_errcode f
cc00: 6b 65 79 32 2d 31 39 2e 32 62 20 53 51 4c 49 54  key2-19.2b SQLIT
cc10: 45 5f 43 4f 4e 53 54 52 41 49 4e 54 5f 46 4f 52  E_CONSTRAINT_FOR
cc20: 45 49 47 4e 4b 45 59 0a 64 6f 5f 74 65 73 74 20  EIGNKEY.do_test 
cc30: 66 6b 65 79 32 2d 31 39 2e 33 20 7b 0a 20 20 73  fkey2-19.3 {.  s
cc40: 71 6c 69 74 65 33 5f 72 65 73 65 74 20 24 53 0a  qlite3_reset $S.
cc50: 7d 20 7b 53 51 4c 49 54 45 5f 43 4f 4e 53 54 52  } {SQLITE_CONSTR
cc60: 41 49 4e 54 7d 0a 76 65 72 69 66 79 5f 65 78 5f  AINT}.verify_ex_
cc70: 65 72 72 63 6f 64 65 20 66 6b 65 79 32 2d 31 39  errcode fkey2-19
cc80: 2e 33 62 20 53 51 4c 49 54 45 5f 43 4f 4e 53 54  .3b SQLITE_CONST
cc90: 52 41 49 4e 54 5f 46 4f 52 45 49 47 4e 4b 45 59  RAINT_FOREIGNKEY
cca0: 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31  .do_test fkey2-1
ccb0: 39 2e 34 20 7b 0a 20 20 73 71 6c 69 74 65 33 5f  9.4 {.  sqlite3_
ccc0: 62 69 6e 64 5f 69 6e 74 20 24 53 20 31 20 31 0a  bind_int $S 1 1.
ccd0: 20 20 73 71 6c 69 74 65 33 5f 73 74 65 70 20 24    sqlite3_step $
cce0: 53 0a 7d 20 7b 53 51 4c 49 54 45 5f 44 4f 4e 45  S.} {SQLITE_DONE
ccf0: 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d  }.do_test fkey2-
cd00: 31 39 2e 34 20 7b 0a 20 20 73 71 6c 69 74 65 33  19.4 {.  sqlite3
cd10: 5f 66 69 6e 61 6c 69 7a 65 20 24 53 0a 7d 20 7b  _finalize $S.} {
cd20: 53 51 4c 49 54 45 5f 4f 4b 7d 0a 0a 64 72 6f 70  SQLITE_OK}..drop
cd30: 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a 64 6f 5f 74  _all_tables.do_t
cd40: 65 73 74 20 66 6b 65 79 32 2d 32 30 2e 31 20 7b  est fkey2-20.1 {
cd50: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
cd60: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 70 70   CREATE TABLE pp
cd70: 28 61 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20  (a PRIMARY KEY, 
cd80: 62 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54  b);.    CREATE T
cd90: 41 42 4c 45 20 63 63 28 63 20 50 52 49 4d 41 52  ABLE cc(c PRIMAR
cda0: 59 20 4b 45 59 2c 20 64 20 52 45 46 45 52 45 4e  Y KEY, d REFEREN
cdb0: 43 45 53 20 70 70 29 3b 0a 20 20 7d 0a 7d 20 7b  CES pp);.  }.} {
cdc0: 7d 0a 0a 66 6f 72 65 61 63 68 20 7b 74 6e 20 69  }..foreach {tn i
cdd0: 6e 73 65 72 74 7d 20 7b 0a 20 20 31 20 22 49 4e  nsert} {.  1 "IN
cde0: 53 45 52 54 22 0a 20 20 32 20 22 49 4e 53 45 52  SERT".  2 "INSER
cdf0: 54 20 4f 52 20 49 47 4e 4f 52 45 22 0a 20 20 33  T OR IGNORE".  3
ce00: 20 22 49 4e 53 45 52 54 20 4f 52 20 41 42 4f 52   "INSERT OR ABOR
ce10: 54 22 0a 20 20 34 20 22 49 4e 53 45 52 54 20 4f  T".  4 "INSERT O
ce20: 52 20 52 4f 4c 4c 42 41 43 4b 22 0a 20 20 35 20  R ROLLBACK".  5 
ce30: 22 49 4e 53 45 52 54 20 4f 52 20 52 45 50 4c 41  "INSERT OR REPLA
ce40: 43 45 22 0a 20 20 36 20 22 49 4e 53 45 52 54 20  CE".  6 "INSERT 
ce50: 4f 52 20 46 41 49 4c 22 0a 7d 20 7b 0a 20 20 64  OR FAIL".} {.  d
ce60: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 32 30 2e  o_test fkey2-20.
ce70: 32 2e 24 74 6e 2e 31 20 7b 0a 20 20 20 20 63 61  2.$tn.1 {.    ca
ce80: 74 63 68 73 71 6c 20 22 24 69 6e 73 65 72 74 20  tchsql "$insert 
ce90: 49 4e 54 4f 20 63 63 20 56 41 4c 55 45 53 28 31  INTO cc VALUES(1
cea0: 2c 20 32 29 22 0a 20 20 7d 20 7b 31 20 7b 46 4f  , 2)".  } {1 {FO
ceb0: 52 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73 74 72  REIGN KEY constr
cec0: 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 20 20  aint failed}}.  
ced0: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 32 30  do_test fkey2-20
cee0: 2e 32 2e 24 74 6e 2e 32 20 7b 0a 20 20 20 20 65  .2.$tn.2 {.    e
cef0: 78 65 63 73 71 6c 20 7b 20 53 45 4c 45 43 54 20  xecsql { SELECT 
cf00: 2a 20 46 52 4f 4d 20 63 63 20 7d 0a 20 20 7d 20  * FROM cc }.  } 
cf10: 7b 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65  {}.  do_test fke
cf20: 79 32 2d 32 30 2e 32 2e 24 74 6e 2e 33 20 7b 0a  y2-20.2.$tn.3 {.
cf30: 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20      execsql {.  
cf40: 20 20 20 20 42 45 47 49 4e 3b 0a 20 20 20 20 20      BEGIN;.     
cf50: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 70     INSERT INTO p
cf60: 70 20 56 41 4c 55 45 53 28 32 2c 20 27 74 77 6f  p VALUES(2, 'two
cf70: 27 29 3b 0a 20 20 20 20 20 20 20 20 49 4e 53 45  ');.        INSE
cf80: 52 54 20 49 4e 54 4f 20 63 63 20 56 41 4c 55 45  RT INTO cc VALUE
cf90: 53 28 31 2c 20 32 29 3b 0a 20 20 20 20 7d 0a 20  S(1, 2);.    }. 
cfa0: 20 20 20 63 61 74 63 68 73 71 6c 20 22 24 69 6e     catchsql "$in
cfb0: 73 65 72 74 20 49 4e 54 4f 20 63 63 20 56 41 4c  sert INTO cc VAL
cfc0: 55 45 53 28 33 2c 20 34 29 22 0a 20 20 7d 20 7b  UES(3, 4)".  } {
cfd0: 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20 63  1 {FOREIGN KEY c
cfe0: 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64  onstraint failed
cff0: 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65  }}.  do_test fke
d000: 79 32 2d 32 30 2e 32 2e 24 74 6e 2e 34 20 7b 0a  y2-20.2.$tn.4 {.
d010: 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20 43 4f      execsql { CO
d020: 4d 4d 49 54 20 3b 20 53 45 4c 45 43 54 20 2a 20  MMIT ; SELECT * 
d030: 46 52 4f 4d 20 63 63 20 7d 0a 20 20 7d 20 7b 31  FROM cc }.  } {1
d040: 20 32 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b   2}.  do_test fk
d050: 65 79 32 2d 32 30 2e 32 2e 24 74 6e 2e 35 20 7b  ey2-20.2.$tn.5 {
d060: 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20 44  .    execsql { D
d070: 45 4c 45 54 45 20 46 52 4f 4d 20 63 63 20 3b 20  ELETE FROM cc ; 
d080: 44 45 4c 45 54 45 20 46 52 4f 4d 20 70 70 20 7d  DELETE FROM pp }
d090: 0a 20 20 7d 20 7b 7d 0a 7d 0a 0a 66 6f 72 65 61  .  } {}.}..forea
d0a0: 63 68 20 7b 74 6e 20 75 70 64 61 74 65 7d 20 7b  ch {tn update} {
d0b0: 0a 20 20 31 20 22 55 50 44 41 54 45 22 0a 20 20  .  1 "UPDATE".  
d0c0: 32 20 22 55 50 44 41 54 45 20 4f 52 20 49 47 4e  2 "UPDATE OR IGN
d0d0: 4f 52 45 22 0a 20 20 33 20 22 55 50 44 41 54 45  ORE".  3 "UPDATE
d0e0: 20 4f 52 20 41 42 4f 52 54 22 0a 20 20 34 20 22   OR ABORT".  4 "
d0f0: 55 50 44 41 54 45 20 4f 52 20 52 4f 4c 4c 42 41  UPDATE OR ROLLBA
d100: 43 4b 22 0a 20 20 35 20 22 55 50 44 41 54 45 20  CK".  5 "UPDATE 
d110: 4f 52 20 52 45 50 4c 41 43 45 22 0a 20 20 36 20  OR REPLACE".  6 
d120: 22 55 50 44 41 54 45 20 4f 52 20 46 41 49 4c 22  "UPDATE OR FAIL"
d130: 0a 7d 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20 66  .} {.  do_test f
d140: 6b 65 79 32 2d 32 30 2e 33 2e 24 74 6e 2e 31 20  key2-20.3.$tn.1 
d150: 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a  {.    execsql {.
d160: 20 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54        INSERT INT
d170: 4f 20 70 70 20 56 41 4c 55 45 53 28 32 2c 20 27  O pp VALUES(2, '
d180: 74 77 6f 27 29 3b 0a 20 20 20 20 20 20 49 4e 53  two');.      INS
d190: 45 52 54 20 49 4e 54 4f 20 63 63 20 56 41 4c 55  ERT INTO cc VALU
d1a0: 45 53 28 31 2c 20 32 29 3b 0a 20 20 20 20 7d 0a  ES(1, 2);.    }.
d1b0: 20 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74 65 73 74    } {}.  do_test
d1c0: 20 66 6b 65 79 32 2d 32 30 2e 33 2e 24 74 6e 2e   fkey2-20.3.$tn.
d1d0: 32 20 7b 0a 20 20 20 20 63 61 74 63 68 73 71 6c  2 {.    catchsql
d1e0: 20 22 24 75 70 64 61 74 65 20 70 70 20 53 45 54   "$update pp SET
d1f0: 20 61 20 3d 20 31 22 0a 20 20 7d 20 7b 31 20 7b   a = 1".  } {1 {
d200: 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73  FOREIGN KEY cons
d210: 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a  traint failed}}.
d220: 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d    do_test fkey2-
d230: 32 30 2e 33 2e 24 74 6e 2e 33 20 7b 0a 20 20 20  20.3.$tn.3 {.   
d240: 20 65 78 65 63 73 71 6c 20 7b 20 53 45 4c 45 43   execsql { SELEC
d250: 54 20 2a 20 46 52 4f 4d 20 70 70 20 7d 0a 20 20  T * FROM pp }.  
d260: 7d 20 7b 32 20 74 77 6f 7d 0a 20 20 64 6f 5f 74  } {2 two}.  do_t
d270: 65 73 74 20 66 6b 65 79 32 2d 32 30 2e 33 2e 24  est fkey2-20.3.$
d280: 74 6e 2e 34 20 7b 0a 20 20 20 20 63 61 74 63 68  tn.4 {.    catch
d290: 73 71 6c 20 22 24 75 70 64 61 74 65 20 63 63 20  sql "$update cc 
d2a0: 53 45 54 20 64 20 3d 20 31 22 0a 20 20 7d 20 7b  SET d = 1".  } {
d2b0: 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20 63  1 {FOREIGN KEY c
d2c0: 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64  onstraint failed
d2d0: 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65  }}.  do_test fke
d2e0: 79 32 2d 32 30 2e 33 2e 24 74 6e 2e 35 20 7b 0a  y2-20.3.$tn.5 {.
d2f0: 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20 53 45      execsql { SE
d300: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 63 63 20 7d  LECT * FROM cc }
d310: 0a 20 20 7d 20 7b 31 20 32 7d 0a 20 20 64 6f 5f  .  } {1 2}.  do_
d320: 74 65 73 74 20 66 6b 65 79 32 2d 32 30 2e 33 2e  test fkey2-20.3.
d330: 24 74 6e 2e 36 20 7b 0a 20 20 20 20 65 78 65 63  $tn.6 {.    exec
d340: 73 71 6c 20 7b 0a 20 20 20 20 20 20 42 45 47 49  sql {.      BEGI
d350: 4e 3b 0a 20 20 20 20 20 20 20 20 49 4e 53 45 52  N;.        INSER
d360: 54 20 49 4e 54 4f 20 70 70 20 56 41 4c 55 45 53  T INTO pp VALUES
d370: 28 33 2c 20 27 74 68 72 65 65 27 29 3b 0a 20 20  (3, 'three');.  
d380: 20 20 7d 0a 20 20 20 20 63 61 74 63 68 73 71 6c    }.    catchsql
d390: 20 22 24 75 70 64 61 74 65 20 70 70 20 53 45 54   "$update pp SET
d3a0: 20 61 20 3d 20 31 20 57 48 45 52 45 20 61 20 3d   a = 1 WHERE a =
d3b0: 20 32 22 0a 20 20 7d 20 7b 31 20 7b 46 4f 52 45   2".  } {1 {FORE
d3c0: 49 47 4e 20 4b 45 59 20 63 6f 6e 73 74 72 61 69  IGN KEY constrai
d3d0: 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 20 20 64 6f  nt failed}}.  do
d3e0: 5f 74 65 73 74 20 66 6b 65 79 32 2d 32 30 2e 33  _test fkey2-20.3
d3f0: 2e 24 74 6e 2e 37 20 7b 0a 20 20 20 20 65 78 65  .$tn.7 {.    exe
d400: 63 73 71 6c 20 7b 20 43 4f 4d 4d 49 54 20 3b 20  csql { COMMIT ; 
d410: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 70 70  SELECT * FROM pp
d420: 20 7d 0a 20 20 7d 20 7b 32 20 74 77 6f 20 33 20   }.  } {2 two 3 
d430: 74 68 72 65 65 7d 0a 20 20 64 6f 5f 74 65 73 74  three}.  do_test
d440: 20 66 6b 65 79 32 2d 32 30 2e 33 2e 24 74 6e 2e   fkey2-20.3.$tn.
d450: 38 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20  8 {.    execsql 
d460: 7b 0a 20 20 20 20 20 20 42 45 47 49 4e 3b 0a 20  {.      BEGIN;. 
d470: 20 20 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e         INSERT IN
d480: 54 4f 20 63 63 20 56 41 4c 55 45 53 28 32 2c 20  TO cc VALUES(2, 
d490: 32 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61  2);.    }.    ca
d4a0: 74 63 68 73 71 6c 20 22 24 75 70 64 61 74 65 20  tchsql "$update 
d4b0: 63 63 20 53 45 54 20 64 20 3d 20 31 20 57 48 45  cc SET d = 1 WHE
d4c0: 52 45 20 63 20 3d 20 31 22 0a 20 20 7d 20 7b 31  RE c = 1".  } {1
d4d0: 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f   {FOREIGN KEY co
d4e0: 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d  nstraint failed}
d4f0: 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79  }.  do_test fkey
d500: 32 2d 32 30 2e 33 2e 24 74 6e 2e 39 20 7b 0a 20  2-20.3.$tn.9 {. 
d510: 20 20 20 65 78 65 63 73 71 6c 20 7b 20 43 4f 4d     execsql { COM
d520: 4d 49 54 20 3b 20 53 45 4c 45 43 54 20 2a 20 46  MIT ; SELECT * F
d530: 52 4f 4d 20 63 63 20 7d 0a 20 20 7d 20 7b 31 20  ROM cc }.  } {1 
d540: 32 20 32 20 32 7d 0a 20 20 64 6f 5f 74 65 73 74  2 2 2}.  do_test
d550: 20 66 6b 65 79 32 2d 32 30 2e 33 2e 24 74 6e 2e   fkey2-20.3.$tn.
d560: 31 30 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c  10 {.    execsql
d570: 20 7b 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 63   { DELETE FROM c
d580: 63 20 3b 20 44 45 4c 45 54 45 20 46 52 4f 4d 20  c ; DELETE FROM 
d590: 70 70 20 7d 0a 20 20 7d 20 7b 7d 0a 7d 0a 0a 23  pp }.  } {}.}..#
d5a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
d5b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
d5c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
d5d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
d5e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 54 68 65 20  ---------.# The 
d5f0: 66 6f 6c 6c 6f 77 69 6e 67 20 62 6c 6f 63 6b 20  following block 
d600: 6f 66 20 74 65 73 74 73 2c 20 74 68 6f 73 65 20  of tests, those 
d610: 70 72 65 66 69 78 65 64 20 77 69 74 68 20 22 66  prefixed with "f
d620: 6b 65 79 32 2d 67 65 6e 66 6b 65 79 2e 22 2c 20  key2-genfkey.", 
d630: 61 72 65 20 0a 23 20 74 68 65 20 73 61 6d 65 20  are .# the same 
d640: 74 65 73 74 73 20 74 68 61 74 20 77 65 72 65 20  tests that were 
d650: 75 73 65 64 20 74 6f 20 74 65 73 74 20 74 68 65  used to test the
d660: 20 22 2e 67 65 6e 66 6b 65 79 22 20 63 6f 6d 6d   ".genfkey" comm
d670: 61 6e 64 20 70 72 6f 76 69 64 65 64 20 0a 23 20  and provided .# 
d680: 62 79 20 74 68 65 20 73 68 65 6c 6c 20 74 6f 6f  by the shell too
d690: 6c 2e 20 53 6f 20 74 68 65 73 65 20 74 65 73 74  l. So these test
d6a0: 73 20 73 68 6f 77 20 74 68 61 74 20 74 68 65 20  s show that the 
d6b0: 62 75 69 6c 74 2d 69 6e 20 66 6f 72 65 69 67 6e  built-in foreign
d6c0: 20 6b 65 79 20 0a 23 20 69 6d 70 6c 65 6d 65 6e   key .# implemen
d6d0: 74 61 74 69 6f 6e 20 69 73 20 6d 6f 72 65 20 6f  tation is more o
d6e0: 72 20 6c 65 73 73 20 63 6f 6d 70 61 74 69 62 6c  r less compatibl
d6f0: 65 20 77 69 74 68 20 74 68 65 20 74 72 69 67 67  e with the trigg
d700: 65 72 73 20 67 65 6e 65 72 61 74 65 64 20 0a 23  ers generated .#
d710: 20 62 79 20 67 65 6e 66 6b 65 79 2e 0a 23 0a 64   by genfkey..#.d
d720: 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a 64  rop_all_tables.d
d730: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 67 65 6e  o_test fkey2-gen
d740: 66 6b 65 79 2e 31 2e 31 20 7b 0a 20 20 65 78 65  fkey.1.1 {.  exe
d750: 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54  csql {.    CREAT
d760: 45 20 54 41 42 4c 45 20 74 31 28 61 20 49 4e 54  E TABLE t1(a INT
d770: 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b 45 59  EGER PRIMARY KEY
d780: 2c 20 62 2c 20 63 2c 20 55 4e 49 51 55 45 28 62  , b, c, UNIQUE(b
d790: 2c 20 63 29 29 3b 0a 20 20 20 20 43 52 45 41 54  , c));.    CREAT
d7a0: 45 20 54 41 42 4c 45 20 74 32 28 65 20 52 45 46  E TABLE t2(e REF
d7b0: 45 52 45 4e 43 45 53 20 74 31 2c 20 66 29 3b 0a  ERENCES t1, f);.
d7c0: 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45      CREATE TABLE
d7d0: 20 74 33 28 67 2c 20 68 2c 20 69 2c 20 46 4f 52   t3(g, h, i, FOR
d7e0: 45 49 47 4e 20 4b 45 59 20 28 68 2c 20 69 29 20  EIGN KEY (h, i) 
d7f0: 52 45 46 45 52 45 4e 43 45 53 20 74 31 28 62 2c  REFERENCES t1(b,
d800: 20 63 29 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64   c));.  }.} {}.d
d810: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 67 65 6e  o_test fkey2-gen
d820: 66 6b 65 79 2e 31 2e 32 20 7b 0a 20 20 63 61 74  fkey.1.2 {.  cat
d830: 63 68 73 71 6c 20 7b 20 49 4e 53 45 52 54 20 49  chsql { INSERT I
d840: 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28 31 2c  NTO t2 VALUES(1,
d850: 20 32 29 20 7d 0a 7d 20 7b 31 20 7b 46 4f 52 45   2) }.} {1 {FORE
d860: 49 47 4e 20 4b 45 59 20 63 6f 6e 73 74 72 61 69  IGN KEY constrai
d870: 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 64 6f 5f 74  nt failed}}.do_t
d880: 65 73 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b 65  est fkey2-genfke
d890: 79 2e 31 2e 33 20 7b 0a 20 20 65 78 65 63 73 71  y.1.3 {.  execsq
d8a0: 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  l {.    INSERT I
d8b0: 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 31 2c  NTO t1 VALUES(1,
d8c0: 20 32 2c 20 33 29 3b 0a 20 20 20 20 49 4e 53 45   2, 3);.    INSE
d8d0: 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55 45  RT INTO t2 VALUE
d8e0: 53 28 31 2c 20 32 29 3b 0a 20 20 7d 0a 7d 20 7b  S(1, 2);.  }.} {
d8f0: 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d  }.do_test fkey2-
d900: 67 65 6e 66 6b 65 79 2e 31 2e 34 20 7b 0a 20 20  genfkey.1.4 {.  
d910: 65 78 65 63 73 71 6c 20 7b 20 49 4e 53 45 52 54  execsql { INSERT
d920: 20 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28   INTO t2 VALUES(
d930: 4e 55 4c 4c 2c 20 33 29 20 7d 0a 7d 20 7b 7d 0a  NULL, 3) }.} {}.
d940: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 67 65  do_test fkey2-ge
d950: 6e 66 6b 65 79 2e 31 2e 35 20 7b 0a 20 20 63 61  nfkey.1.5 {.  ca
d960: 74 63 68 73 71 6c 20 7b 20 55 50 44 41 54 45 20  tchsql { UPDATE 
d970: 74 32 20 53 45 54 20 65 20 3d 20 35 20 57 48 45  t2 SET e = 5 WHE
d980: 52 45 20 65 20 49 53 20 4e 55 4c 4c 20 7d 0a 7d  RE e IS NULL }.}
d990: 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59   {1 {FOREIGN KEY
d9a0: 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c   constraint fail
d9b0: 65 64 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65  ed}}.do_test fke
d9c0: 79 32 2d 67 65 6e 66 6b 65 79 2e 31 2e 36 20 7b  y2-genfkey.1.6 {
d9d0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 55 50 44  .  execsql { UPD
d9e0: 41 54 45 20 74 32 20 53 45 54 20 65 20 3d 20 31  ATE t2 SET e = 1
d9f0: 20 57 48 45 52 45 20 65 20 49 53 20 4e 55 4c 4c   WHERE e IS NULL
da00: 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20   }.} {}.do_test 
da10: 66 6b 65 79 32 2d 67 65 6e 66 6b 65 79 2e 31 2e  fkey2-genfkey.1.
da20: 37 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 20  7 {.  execsql { 
da30: 55 50 44 41 54 45 20 74 32 20 53 45 54 20 65 20  UPDATE t2 SET e 
da40: 3d 20 4e 55 4c 4c 20 57 48 45 52 45 20 66 20 3d  = NULL WHERE f =
da50: 20 33 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73   3 }.} {}.do_tes
da60: 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b 65 79 2e  t fkey2-genfkey.
da70: 31 2e 38 20 7b 0a 20 20 63 61 74 63 68 73 71 6c  1.8 {.  catchsql
da80: 20 7b 20 55 50 44 41 54 45 20 74 31 20 53 45 54   { UPDATE t1 SET
da90: 20 61 20 3d 20 31 30 20 7d 0a 7d 20 7b 31 20 7b   a = 10 }.} {1 {
daa0: 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73  FOREIGN KEY cons
dab0: 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a  traint failed}}.
dac0: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 67 65  do_test fkey2-ge
dad0: 6e 66 6b 65 79 2e 31 2e 39 20 7b 0a 20 20 63 61  nfkey.1.9 {.  ca
dae0: 74 63 68 73 71 6c 20 7b 20 55 50 44 41 54 45 20  tchsql { UPDATE 
daf0: 74 31 20 53 45 54 20 61 20 3d 20 4e 55 4c 4c 20  t1 SET a = NULL 
db00: 7d 0a 7d 20 7b 31 20 7b 64 61 74 61 74 79 70 65  }.} {1 {datatype
db10: 20 6d 69 73 6d 61 74 63 68 7d 7d 0a 64 6f 5f 74   mismatch}}.do_t
db20: 65 73 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b 65  est fkey2-genfke
db30: 79 2e 31 2e 31 30 20 7b 0a 20 20 63 61 74 63 68  y.1.10 {.  catch
db40: 73 71 6c 20 7b 20 44 45 4c 45 54 45 20 46 52 4f  sql { DELETE FRO
db50: 4d 20 74 31 20 7d 0a 7d 20 7b 31 20 7b 46 4f 52  M t1 }.} {1 {FOR
db60: 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73 74 72 61  EIGN KEY constra
db70: 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 64 6f 5f  int failed}}.do_
db80: 74 65 73 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b  test fkey2-genfk
db90: 65 79 2e 31 2e 31 31 20 7b 0a 20 20 65 78 65 63  ey.1.11 {.  exec
dba0: 73 71 6c 20 7b 20 55 50 44 41 54 45 20 74 32 20  sql { UPDATE t2 
dbb0: 53 45 54 20 65 20 3d 20 4e 55 4c 4c 20 7d 0a 7d  SET e = NULL }.}
dbc0: 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79   {}.do_test fkey
dbd0: 32 2d 67 65 6e 66 6b 65 79 2e 31 2e 31 32 20 7b  2-genfkey.1.12 {
dbe0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 0a 20 20  .  execsql { .  
dbf0: 20 20 55 50 44 41 54 45 20 74 31 20 53 45 54 20    UPDATE t1 SET 
dc00: 61 20 3d 20 31 30 3b 0a 20 20 20 20 44 45 4c 45  a = 10;.    DELE
dc10: 54 45 20 46 52 4f 4d 20 74 31 3b 0a 20 20 20 20  TE FROM t1;.    
dc20: 44 45 4c 45 54 45 20 46 52 4f 4d 20 74 32 3b 0a  DELETE FROM t2;.
dc30: 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74    }.} {}.do_test
dc40: 20 66 6b 65 79 32 2d 67 65 6e 66 6b 65 79 2e 31   fkey2-genfkey.1
dc50: 2e 31 33 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  .13 {.  execsql 
dc60: 7b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  {.    INSERT INT
dc70: 4f 20 74 33 20 56 41 4c 55 45 53 28 31 2c 20 4e  O t3 VALUES(1, N
dc80: 55 4c 4c 2c 20 4e 55 4c 4c 29 3b 0a 20 20 20 20  ULL, NULL);.    
dc90: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 33 20 56  INSERT INTO t3 V
dca0: 41 4c 55 45 53 28 31 2c 20 32 2c 20 4e 55 4c 4c  ALUES(1, 2, NULL
dcb0: 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  );.    INSERT IN
dcc0: 54 4f 20 74 33 20 56 41 4c 55 45 53 28 31 2c 20  TO t3 VALUES(1, 
dcd0: 4e 55 4c 4c 2c 20 33 29 3b 0a 20 20 7d 0a 7d 20  NULL, 3);.  }.} 
dce0: 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  {}.do_test fkey2
dcf0: 2d 67 65 6e 66 6b 65 79 2e 31 2e 31 34 20 7b 0a  -genfkey.1.14 {.
dd00: 20 20 63 61 74 63 68 73 71 6c 20 7b 20 49 4e 53    catchsql { INS
dd10: 45 52 54 20 49 4e 54 4f 20 74 33 20 56 41 4c 55  ERT INTO t3 VALU
dd20: 45 53 28 33 2c 20 31 2c 20 34 29 20 7d 0a 7d 20  ES(3, 1, 4) }.} 
dd30: 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20  {1 {FOREIGN KEY 
dd40: 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65  constraint faile
dd50: 64 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79  d}}.do_test fkey
dd60: 32 2d 67 65 6e 66 6b 65 79 2e 31 2e 31 35 20 7b  2-genfkey.1.15 {
dd70: 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 0a 20 20  .  execsql { .  
dd80: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31    INSERT INTO t1
dd90: 20 56 41 4c 55 45 53 28 31 2c 20 31 2c 20 34 29   VALUES(1, 1, 4)
dda0: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
ddb0: 4f 20 74 33 20 56 41 4c 55 45 53 28 33 2c 20 31  O t3 VALUES(3, 1
ddc0: 2c 20 34 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64  , 4);.  }.} {}.d
ddd0: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 67 65 6e  o_test fkey2-gen
dde0: 66 6b 65 79 2e 31 2e 31 36 20 7b 0a 20 20 63 61  fkey.1.16 {.  ca
ddf0: 74 63 68 73 71 6c 20 7b 20 44 45 4c 45 54 45 20  tchsql { DELETE 
de00: 46 52 4f 4d 20 74 31 20 7d 0a 7d 20 7b 31 20 7b  FROM t1 }.} {1 {
de10: 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73  FOREIGN KEY cons
de20: 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a  traint failed}}.
de30: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 67 65  do_test fkey2-ge
de40: 6e 66 6b 65 79 2e 31 2e 31 37 20 7b 0a 20 20 63  nfkey.1.17 {.  c
de50: 61 74 63 68 73 71 6c 20 7b 20 55 50 44 41 54 45  atchsql { UPDATE
de60: 20 74 31 20 53 45 54 20 62 20 3d 20 31 30 7d 0a   t1 SET b = 10}.
de70: 7d 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45  } {1 {FOREIGN KE
de80: 59 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69  Y constraint fai
de90: 6c 65 64 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b  led}}.do_test fk
dea0: 65 79 32 2d 67 65 6e 66 6b 65 79 2e 31 2e 31 38  ey2-genfkey.1.18
deb0: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 55   {.  execsql { U
dec0: 50 44 41 54 45 20 74 31 20 53 45 54 20 61 20 3d  PDATE t1 SET a =
ded0: 20 31 30 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73   10}.} {}.do_tes
dee0: 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b 65 79 2e  t fkey2-genfkey.
def0: 31 2e 31 39 20 7b 0a 20 20 63 61 74 63 68 73 71  1.19 {.  catchsq
df00: 6c 20 7b 20 55 50 44 41 54 45 20 74 33 20 53 45  l { UPDATE t3 SE
df10: 54 20 68 20 3d 20 27 68 65 6c 6c 6f 27 20 57 48  T h = 'hello' WH
df20: 45 52 45 20 69 20 3d 20 33 7d 0a 7d 20 7b 31 20  ERE i = 3}.} {1 
df30: 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f 6e  {FOREIGN KEY con
df40: 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d  straint failed}}
df50: 0a 0a 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65  ..drop_all_table
df60: 73 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d  s.do_test fkey2-
df70: 67 65 6e 66 6b 65 79 2e 32 2e 31 20 7b 0a 20 20  genfkey.2.1 {.  
df80: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52  execsql {.    CR
df90: 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 61 20  EATE TABLE t1(a 
dfa0: 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59 20  INTEGER PRIMARY 
dfb0: 4b 45 59 2c 20 62 2c 20 63 2c 20 55 4e 49 51 55  KEY, b, c, UNIQU
dfc0: 45 28 62 2c 20 63 29 29 3b 0a 20 20 20 20 43 52  E(b, c));.    CR
dfd0: 45 41 54 45 20 54 41 42 4c 45 20 74 32 28 65 20  EATE TABLE t2(e 
dfe0: 52 45 46 45 52 45 4e 43 45 53 20 74 31 20 4f 4e  REFERENCES t1 ON
dff0: 20 55 50 44 41 54 45 20 43 41 53 43 41 44 45 20   UPDATE CASCADE 
e000: 4f 4e 20 44 45 4c 45 54 45 20 43 41 53 43 41 44  ON DELETE CASCAD
e010: 45 2c 20 66 29 3b 0a 20 20 20 20 43 52 45 41 54  E, f);.    CREAT
e020: 45 20 54 41 42 4c 45 20 74 33 28 67 2c 20 68 2c  E TABLE t3(g, h,
e030: 20 69 2c 20 0a 20 20 20 20 20 20 20 20 46 4f 52   i, .        FOR
e040: 45 49 47 4e 20 4b 45 59 20 28 68 2c 20 69 29 20  EIGN KEY (h, i) 
e050: 0a 20 20 20 20 20 20 20 20 52 45 46 45 52 45 4e  .        REFEREN
e060: 43 45 53 20 74 31 28 62 2c 20 63 29 20 4f 4e 20  CES t1(b, c) ON 
e070: 55 50 44 41 54 45 20 43 41 53 43 41 44 45 20 4f  UPDATE CASCADE O
e080: 4e 20 44 45 4c 45 54 45 20 43 41 53 43 41 44 45  N DELETE CASCADE
e090: 0a 20 20 20 20 29 3b 0a 20 20 7d 0a 7d 20 7b 7d  .    );.  }.} {}
e0a0: 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 67  .do_test fkey2-g
e0b0: 65 6e 66 6b 65 79 2e 32 2e 32 20 7b 0a 20 20 65  enfkey.2.2 {.  e
e0c0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53  xecsql {.    INS
e0d0: 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55  ERT INTO t1 VALU
e0e0: 45 53 28 31 2c 20 32 2c 20 33 29 3b 0a 20 20 20  ES(1, 2, 3);.   
e0f0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
e100: 56 41 4c 55 45 53 28 34 2c 20 35 2c 20 36 29 3b  VALUES(4, 5, 6);
e110: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
e120: 20 74 32 20 56 41 4c 55 45 53 28 31 2c 20 27 6f   t2 VALUES(1, 'o
e130: 6e 65 27 29 3b 0a 20 20 20 20 49 4e 53 45 52 54  ne');.    INSERT
e140: 20 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28   INTO t2 VALUES(
e150: 34 2c 20 27 66 6f 75 72 27 29 3b 0a 20 20 7d 0a  4, 'four');.  }.
e160: 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65  } {}.do_test fke
e170: 79 32 2d 67 65 6e 66 6b 65 79 2e 32 2e 33 20 7b  y2-genfkey.2.3 {
e180: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
e190: 20 55 50 44 41 54 45 20 74 31 20 53 45 54 20 61   UPDATE t1 SET a
e1a0: 20 3d 20 32 20 57 48 45 52 45 20 61 20 3d 20 31   = 2 WHERE a = 1
e1b0: 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  ;.    SELECT * F
e1c0: 52 4f 4d 20 74 32 3b 0a 20 20 7d 0a 7d 20 7b 32  ROM t2;.  }.} {2
e1d0: 20 6f 6e 65 20 34 20 66 6f 75 72 7d 0a 64 6f 5f   one 4 four}.do_
e1e0: 74 65 73 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b  test fkey2-genfk
e1f0: 65 79 2e 32 2e 34 20 7b 0a 20 20 65 78 65 63 73  ey.2.4 {.  execs
e200: 71 6c 20 7b 0a 20 20 20 20 44 45 4c 45 54 45 20  ql {.    DELETE 
e210: 46 52 4f 4d 20 74 31 20 57 48 45 52 45 20 61 20  FROM t1 WHERE a 
e220: 3d 20 34 3b 0a 20 20 20 20 53 45 4c 45 43 54 20  = 4;.    SELECT 
e230: 2a 20 46 52 4f 4d 20 74 32 3b 0a 20 20 7d 0a 7d  * FROM t2;.  }.}
e240: 20 7b 32 20 6f 6e 65 7d 0a 0a 64 6f 5f 74 65 73   {2 one}..do_tes
e250: 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b 65 79 2e  t fkey2-genfkey.
e260: 32 2e 35 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  2.5 {.  execsql 
e270: 7b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  {.    INSERT INT
e280: 4f 20 74 33 20 56 41 4c 55 45 53 28 27 68 65 6c  O t3 VALUES('hel
e290: 6c 6f 27 2c 20 32 2c 20 33 29 3b 0a 20 20 20 20  lo', 2, 3);.    
e2a0: 55 50 44 41 54 45 20 74 31 20 53 45 54 20 63 20  UPDATE t1 SET c 
e2b0: 3d 20 32 3b 0a 20 20 20 20 53 45 4c 45 43 54 20  = 2;.    SELECT 
e2c0: 2a 20 46 52 4f 4d 20 74 33 3b 0a 20 20 7d 0a 7d  * FROM t3;.  }.}
e2d0: 20 7b 68 65 6c 6c 6f 20 32 20 32 7d 0a 64 6f 5f   {hello 2 2}.do_
e2e0: 74 65 73 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b  test fkey2-genfk
e2f0: 65 79 2e 32 2e 36 20 7b 0a 20 20 65 78 65 63 73  ey.2.6 {.  execs
e300: 71 6c 20 7b 0a 20 20 20 20 44 45 4c 45 54 45 20  ql {.    DELETE 
e310: 46 52 4f 4d 20 74 31 3b 0a 20 20 20 20 53 45 4c  FROM t1;.    SEL
e320: 45 43 54 20 2a 20 46 52 4f 4d 20 74 33 3b 0a 20  ECT * FROM t3;. 
e330: 20 7d 0a 7d 20 7b 7d 0a 0a 64 72 6f 70 5f 61 6c   }.} {}..drop_al
e340: 6c 5f 74 61 62 6c 65 73 0a 64 6f 5f 74 65 73 74  l_tables.do_test
e350: 20 66 6b 65 79 32 2d 67 65 6e 66 6b 65 79 2e 33   fkey2-genfkey.3
e360: 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .1 {.  execsql {
e370: 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  .    CREATE TABL
e380: 45 20 74 31 28 61 20 49 4e 54 45 47 45 52 20 50  E t1(a INTEGER P
e390: 52 49 4d 41 52 59 20 4b 45 59 2c 20 62 2c 20 63  RIMARY KEY, b, c
e3a0: 2c 20 55 4e 49 51 55 45 28 63 2c 20 62 29 29 3b  , UNIQUE(c, b));
e3b0: 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  .    CREATE TABL
e3c0: 45 20 74 32 28 65 20 52 45 46 45 52 45 4e 43 45  E t2(e REFERENCE
e3d0: 53 20 74 31 20 4f 4e 20 55 50 44 41 54 45 20 53  S t1 ON UPDATE S
e3e0: 45 54 20 4e 55 4c 4c 20 4f 4e 20 44 45 4c 45 54  ET NULL ON DELET
e3f0: 45 20 53 45 54 20 4e 55 4c 4c 2c 20 66 29 3b 0a  E SET NULL, f);.
e400: 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45      CREATE TABLE
e410: 20 74 33 28 67 2c 20 68 2c 20 69 2c 20 0a 20 20   t3(g, h, i, .  
e420: 20 20 20 20 20 20 46 4f 52 45 49 47 4e 20 4b 45        FOREIGN KE
e430: 59 20 28 68 2c 20 69 29 20 0a 20 20 20 20 20 20  Y (h, i) .      
e440: 20 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 28    REFERENCES t1(
e450: 62 2c 20 63 29 20 4f 4e 20 55 50 44 41 54 45 20  b, c) ON UPDATE 
e460: 53 45 54 20 4e 55 4c 4c 20 4f 4e 20 44 45 4c 45  SET NULL ON DELE
e470: 54 45 20 53 45 54 20 4e 55 4c 4c 0a 20 20 20 20  TE SET NULL.    
e480: 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74  );.  }.} {}.do_t
e490: 65 73 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b 65  est fkey2-genfke
e4a0: 79 2e 33 2e 32 20 7b 0a 20 20 65 78 65 63 73 71  y.3.2 {.  execsq
e4b0: 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  l {.    INSERT I
e4c0: 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 31 2c  NTO t1 VALUES(1,
e4d0: 20 32 2c 20 33 29 3b 0a 20 20 20 20 49 4e 53 45   2, 3);.    INSE
e4e0: 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45  RT INTO t1 VALUE
e4f0: 53 28 34 2c 20 35 2c 20 36 29 3b 0a 20 20 20 20  S(4, 5, 6);.    
e500: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 20 56  INSERT INTO t2 V
e510: 41 4c 55 45 53 28 31 2c 20 27 6f 6e 65 27 29 3b  ALUES(1, 'one');
e520: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
e530: 20 74 32 20 56 41 4c 55 45 53 28 34 2c 20 27 66   t2 VALUES(4, 'f
e540: 6f 75 72 27 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a  our');.  }.} {}.
e550: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 67 65  do_test fkey2-ge
e560: 6e 66 6b 65 79 2e 33 2e 33 20 7b 0a 20 20 65 78  nfkey.3.3 {.  ex
e570: 65 63 73 71 6c 20 7b 0a 20 20 20 20 55 50 44 41  ecsql {.    UPDA
e580: 54 45 20 74 31 20 53 45 54 20 61 20 3d 20 32 20  TE t1 SET a = 2 
e590: 57 48 45 52 45 20 61 20 3d 20 31 3b 0a 20 20 20  WHERE a = 1;.   
e5a0: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
e5b0: 32 3b 0a 20 20 7d 0a 7d 20 7b 7b 7d 20 6f 6e 65  2;.  }.} {{} one
e5c0: 20 34 20 66 6f 75 72 7d 0a 64 6f 5f 74 65 73 74   4 four}.do_test
e5d0: 20 66 6b 65 79 32 2d 67 65 6e 66 6b 65 79 2e 33   fkey2-genfkey.3
e5e0: 2e 34 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .4 {.  execsql {
e5f0: 0a 20 20 20 20 44 45 4c 45 54 45 20 46 52 4f 4d  .    DELETE FROM
e600: 20 74 31 20 57 48 45 52 45 20 61 20 3d 20 34 3b   t1 WHERE a = 4;
e610: 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52  .    SELECT * FR
e620: 4f 4d 20 74 32 3b 0a 20 20 7d 0a 7d 20 7b 7b 7d  OM t2;.  }.} {{}
e630: 20 6f 6e 65 20 7b 7d 20 66 6f 75 72 7d 0a 64 6f   one {} four}.do
e640: 5f 74 65 73 74 20 66 6b 65 79 32 2d 67 65 6e 66  _test fkey2-genf
e650: 6b 65 79 2e 33 2e 35 20 7b 0a 20 20 65 78 65 63  key.3.5 {.  exec
e660: 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52 54  sql {.    INSERT
e670: 20 49 4e 54 4f 20 74 33 20 56 41 4c 55 45 53 28   INTO t3 VALUES(
e680: 27 68 65 6c 6c 6f 27 2c 20 32 2c 20 33 29 3b 0a  'hello', 2, 3);.
e690: 20 20 20 20 55 50 44 41 54 45 20 74 31 20 53 45      UPDATE t1 SE
e6a0: 54 20 63 20 3d 20 32 3b 0a 20 20 20 20 53 45 4c  T c = 2;.    SEL
e6b0: 45 43 54 20 2a 20 46 52 4f 4d 20 74 33 3b 0a 20  ECT * FROM t3;. 
e6c0: 20 7d 0a 7d 20 7b 68 65 6c 6c 6f 20 7b 7d 20 7b   }.} {hello {} {
e6d0: 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  }}.do_test fkey2
e6e0: 2d 67 65 6e 66 6b 65 79 2e 33 2e 36 20 7b 0a 20  -genfkey.3.6 {. 
e6f0: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 55   execsql {.    U
e700: 50 44 41 54 45 20 74 33 20 53 45 54 20 68 20 3d  PDATE t3 SET h =
e710: 20 32 2c 20 69 20 3d 20 32 3b 0a 20 20 20 20 44   2, i = 2;.    D
e720: 45 4c 45 54 45 20 46 52 4f 4d 20 74 31 3b 0a 20  ELETE FROM t1;. 
e730: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
e740: 20 74 33 3b 0a 20 20 7d 0a 7d 20 7b 68 65 6c 6c   t3;.  }.} {hell
e750: 6f 20 7b 7d 20 7b 7d 7d 0a 0a 23 2d 2d 2d 2d 2d  o {} {}}..#-----
e760: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
e770: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
e780: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
e790: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
e7a0: 2d 2d 2d 2d 0a 23 20 56 65 72 69 66 79 20 74 68  ----.# Verify th
e7b0: 61 74 20 74 69 63 6b 65 74 20 64 64 30 38 65 35  at ticket dd08e5
e7c0: 61 39 38 38 64 30 30 64 65 63 63 34 61 35 34 33  a988d00decc4a543
e7d0: 64 61 61 38 64 62 62 66 61 62 39 63 35 37 37 61  daa8dbbfab9c577a
e7e0: 64 38 20 68 61 73 20 62 65 65 6e 0a 23 20 66 69  d8 has been.# fi
e7f0: 78 65 64 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 66  xed..#.do_test f
e800: 6b 65 79 32 2d 64 64 30 38 65 35 2e 31 2e 31 20  key2-dd08e5.1.1 
e810: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
e820: 20 20 50 52 41 47 4d 41 20 66 6f 72 65 69 67 6e    PRAGMA foreign
e830: 5f 6b 65 79 73 3d 4f 4e 3b 0a 20 20 20 20 43 52  _keys=ON;.    CR
e840: 45 41 54 45 20 54 41 42 4c 45 20 74 64 64 30 38  EATE TABLE tdd08
e850: 28 61 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41  (a INTEGER PRIMA
e860: 52 59 20 4b 45 59 2c 20 62 29 3b 0a 20 20 20 20  RY KEY, b);.    
e870: 43 52 45 41 54 45 20 55 4e 49 51 55 45 20 49 4e  CREATE UNIQUE IN
e880: 44 45 58 20 69 64 64 30 38 20 4f 4e 20 74 64 64  DEX idd08 ON tdd
e890: 30 38 28 61 2c 62 29 3b 0a 20 20 20 20 49 4e 53  08(a,b);.    INS
e8a0: 45 52 54 20 49 4e 54 4f 20 74 64 64 30 38 20 56  ERT INTO tdd08 V
e8b0: 41 4c 55 45 53 28 32 30 30 2c 33 30 30 29 3b 0a  ALUES(200,300);.
e8c0: 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  .    CREATE TABL
e8d0: 45 20 74 64 64 30 38 5f 62 28 77 2c 78 2c 79 2c  E tdd08_b(w,x,y,
e8e0: 20 46 4f 52 45 49 47 4e 20 4b 45 59 28 78 2c 79   FOREIGN KEY(x,y
e8f0: 29 20 52 45 46 45 52 45 4e 43 45 53 20 74 64 64  ) REFERENCES tdd
e900: 30 38 28 61 2c 62 29 29 3b 0a 20 20 20 20 49 4e  08(a,b));.    IN
e910: 53 45 52 54 20 49 4e 54 4f 20 74 64 64 30 38 5f  SERT INTO tdd08_
e920: 62 20 56 41 4c 55 45 53 28 31 30 30 2c 32 30 30  b VALUES(100,200
e930: 2c 33 30 30 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a  ,300);.  }.} {}.
e940: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 64 64  do_test fkey2-dd
e950: 30 38 65 35 2e 31 2e 32 20 7b 0a 20 20 63 61 74  08e5.1.2 {.  cat
e960: 63 68 73 71 6c 20 7b 0a 20 20 20 20 44 45 4c 45  chsql {.    DELE
e970: 54 45 20 46 52 4f 4d 20 74 64 64 30 38 3b 0a 20  TE FROM tdd08;. 
e980: 20 7d 0a 7d 20 7b 31 20 7b 46 4f 52 45 49 47 4e   }.} {1 {FOREIGN
e990: 20 4b 45 59 20 63 6f 6e 73 74 72 61 69 6e 74 20   KEY constraint 
e9a0: 66 61 69 6c 65 64 7d 7d 0a 64 6f 5f 74 65 73 74  failed}}.do_test
e9b0: 20 66 6b 65 79 32 2d 64 64 30 38 65 35 2e 31 2e   fkey2-dd08e5.1.
e9c0: 33 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  3 {.  execsql {.
e9d0: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
e9e0: 4d 20 74 64 64 30 38 3b 0a 20 20 7d 0a 7d 20 7b  M tdd08;.  }.} {
e9f0: 32 30 30 20 33 30 30 7d 0a 64 6f 5f 74 65 73 74  200 300}.do_test
ea00: 20 66 6b 65 79 32 2d 64 64 30 38 65 35 2e 31 2e   fkey2-dd08e5.1.
ea10: 34 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b  4 {.  catchsql {
ea20: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
ea30: 20 74 64 64 30 38 5f 62 20 56 41 4c 55 45 53 28   tdd08_b VALUES(
ea40: 34 30 30 2c 35 30 30 2c 33 30 30 29 3b 0a 20 20  400,500,300);.  
ea50: 7d 0a 7d 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20  }.} {1 {FOREIGN 
ea60: 4b 45 59 20 63 6f 6e 73 74 72 61 69 6e 74 20 66  KEY constraint f
ea70: 61 69 6c 65 64 7d 7d 0a 64 6f 5f 74 65 73 74 20  ailed}}.do_test 
ea80: 66 6b 65 79 32 2d 64 64 30 38 65 35 2e 31 2e 35  fkey2-dd08e5.1.5
ea90: 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a   {.  catchsql {.
eaa0: 20 20 20 20 55 50 44 41 54 45 20 74 64 64 30 38      UPDATE tdd08
eab0: 5f 62 20 53 45 54 20 78 3d 78 2b 31 3b 0a 20 20  _b SET x=x+1;.  
eac0: 7d 0a 7d 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20  }.} {1 {FOREIGN 
ead0: 4b 45 59 20 63 6f 6e 73 74 72 61 69 6e 74 20 66  KEY constraint f
eae0: 61 69 6c 65 64 7d 7d 0a 64 6f 5f 74 65 73 74 20  ailed}}.do_test 
eaf0: 66 6b 65 79 32 2d 64 64 30 38 65 35 2e 31 2e 36  fkey2-dd08e5.1.6
eb00: 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a   {.  catchsql {.
eb10: 20 20 20 20 55 50 44 41 54 45 20 74 64 64 30 38      UPDATE tdd08
eb20: 20 53 45 54 20 61 3d 61 2b 31 3b 0a 20 20 7d 0a   SET a=a+1;.  }.
eb30: 7d 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45  } {1 {FOREIGN KE
eb40: 59 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69  Y constraint fai
eb50: 6c 65 64 7d 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d  led}}..#--------
eb60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
eb70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
eb80: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
eb90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
eba0: 2d 0a 23 20 56 65 72 69 66 79 20 74 68 61 74 20  -.# Verify that 
ebb0: 74 69 63 6b 65 74 20 63 65 37 63 31 33 33 65 61  ticket ce7c133ea
ebc0: 36 63 63 39 63 63 64 63 31 61 36 30 64 38 30 34  6cc9ccdc1a60d804
ebd0: 34 31 66 38 30 62 36 31 38 30 66 35 65 62 61 0a  41f80b6180f5eba.
ebe0: 23 20 66 69 78 65 64 2e 0a 23 0a 64 6f 5f 74 65  # fixed..#.do_te
ebf0: 73 74 20 66 6b 65 79 32 2d 63 65 37 63 31 33 2e  st fkey2-ce7c13.
ec00: 31 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  1.1 {.  execsql 
ec10: 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42  {.    CREATE TAB
ec20: 4c 45 20 74 63 65 37 31 28 61 20 49 4e 54 45 47  LE tce71(a INTEG
ec30: 45 52 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20  ER PRIMARY KEY, 
ec40: 62 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20 55  b);.    CREATE U
ec50: 4e 49 51 55 45 20 49 4e 44 45 58 20 69 63 65 37  NIQUE INDEX ice7
ec60: 31 20 4f 4e 20 74 63 65 37 31 28 61 2c 62 29 3b  1 ON tce71(a,b);
ec70: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
ec80: 20 74 63 65 37 31 20 56 41 4c 55 45 53 28 31 30   tce71 VALUES(10
ec90: 30 2c 32 30 30 29 3b 0a 20 20 20 20 43 52 45 41  0,200);.    CREA
eca0: 54 45 20 54 41 42 4c 45 20 74 63 65 37 32 28 77  TE TABLE tce72(w
ecb0: 2c 20 78 2c 20 79 2c 20 46 4f 52 45 49 47 4e 20  , x, y, FOREIGN 
ecc0: 4b 45 59 28 78 2c 79 29 20 52 45 46 45 52 45 4e  KEY(x,y) REFEREN
ecd0: 43 45 53 20 74 63 65 37 31 28 61 2c 62 29 29 3b  CES tce71(a,b));
ece0: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
ecf0: 20 74 63 65 37 32 20 56 41 4c 55 45 53 28 33 30   tce72 VALUES(30
ed00: 30 2c 31 30 30 2c 32 30 30 29 3b 0a 20 20 20 20  0,100,200);.    
ed10: 55 50 44 41 54 45 20 74 63 65 37 31 20 73 65 74  UPDATE tce71 set
ed20: 20 62 20 3d 20 32 30 30 20 77 68 65 72 65 20 61   b = 200 where a
ed30: 20 3d 20 31 30 30 3b 0a 20 20 20 20 53 45 4c 45   = 100;.    SELE
ed40: 43 54 20 2a 20 46 52 4f 4d 20 74 63 65 37 31 2c  CT * FROM tce71,
ed50: 20 74 63 65 37 32 3b 0a 20 20 7d 0a 7d 20 7b 31   tce72;.  }.} {1
ed60: 30 30 20 32 30 30 20 33 30 30 20 31 30 30 20 32  00 200 300 100 2
ed70: 30 30 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79  00}.do_test fkey
ed80: 32 2d 63 65 37 63 31 33 2e 31 2e 32 20 7b 0a 20  2-ce7c13.1.2 {. 
ed90: 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20   catchsql {.    
eda0: 55 50 44 41 54 45 20 74 63 65 37 31 20 73 65 74  UPDATE tce71 set
edb0: 20 62 20 3d 20 32 30 31 20 77 68 65 72 65 20 61   b = 201 where a
edc0: 20 3d 20 31 30 30 3b 0a 20 20 7d 0a 7d 20 7b 31   = 100;.  }.} {1
edd0: 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f   {FOREIGN KEY co
ede0: 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d  nstraint failed}
edf0: 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d  }.do_test fkey2-
ee00: 63 65 37 63 31 33 2e 31 2e 33 20 7b 0a 20 20 63  ce7c13.1.3 {.  c
ee10: 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 55 50  atchsql {.    UP
ee20: 44 41 54 45 20 74 63 65 37 31 20 73 65 74 20 61  DATE tce71 set a
ee30: 20 3d 20 31 30 31 20 77 68 65 72 65 20 61 20 3d   = 101 where a =
ee40: 20 31 30 30 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b   100;.  }.} {1 {
ee50: 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73  FOREIGN KEY cons
ee60: 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a  traint failed}}.
ee70: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 63 65  do_test fkey2-ce
ee80: 37 63 31 33 2e 31 2e 34 20 7b 0a 20 20 65 78 65  7c13.1.4 {.  exe
ee90: 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54  csql {.    CREAT
eea0: 45 20 54 41 42 4c 45 20 74 63 65 37 33 28 61 20  E TABLE tce73(a 
eeb0: 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59 20  INTEGER PRIMARY 
eec0: 4b 45 59 2c 20 62 2c 20 55 4e 49 51 55 45 28 61  KEY, b, UNIQUE(a
eed0: 2c 62 29 29 3b 0a 20 20 20 20 49 4e 53 45 52 54  ,b));.    INSERT
eee0: 20 49 4e 54 4f 20 74 63 65 37 33 20 56 41 4c 55   INTO tce73 VALU
eef0: 45 53 28 31 30 30 2c 32 30 30 29 3b 0a 20 20 20  ES(100,200);.   
ef00: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 63   CREATE TABLE tc
ef10: 65 37 34 28 77 2c 20 78 2c 20 79 2c 20 46 4f 52  e74(w, x, y, FOR
ef20: 45 49 47 4e 20 4b 45 59 28 78 2c 79 29 20 52 45  EIGN KEY(x,y) RE
ef30: 46 45 52 45 4e 43 45 53 20 74 63 65 37 33 28 61  FERENCES tce73(a
ef40: 2c 62 29 29 3b 0a 20 20 20 20 49 4e 53 45 52 54  ,b));.    INSERT
ef50: 20 49 4e 54 4f 20 74 63 65 37 34 20 56 41 4c 55   INTO tce74 VALU
ef60: 45 53 28 33 30 30 2c 31 30 30 2c 32 30 30 29 3b  ES(300,100,200);
ef70: 0a 20 20 20 20 55 50 44 41 54 45 20 74 63 65 37  .    UPDATE tce7
ef80: 33 20 73 65 74 20 62 20 3d 20 32 30 30 20 77 68  3 set b = 200 wh
ef90: 65 72 65 20 61 20 3d 20 31 30 30 3b 0a 20 20 20  ere a = 100;.   
efa0: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
efb0: 63 65 37 33 2c 20 74 63 65 37 34 3b 0a 20 20 7d  ce73, tce74;.  }
efc0: 0a 7d 20 7b 31 30 30 20 32 30 30 20 33 30 30 20  .} {100 200 300 
efd0: 31 30 30 20 32 30 30 7d 0a 64 6f 5f 74 65 73 74  100 200}.do_test
efe0: 20 66 6b 65 79 32 2d 63 65 37 63 31 33 2e 31 2e   fkey2-ce7c13.1.
eff0: 35 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b  5 {.  catchsql {
f000: 0a 20 20 20 20 55 50 44 41 54 45 20 74 63 65 37  .    UPDATE tce7
f010: 33 20 73 65 74 20 62 20 3d 20 32 30 31 20 77 68  3 set b = 201 wh
f020: 65 72 65 20 61 20 3d 20 31 30 30 3b 0a 20 20 7d  ere a = 100;.  }
f030: 0a 7d 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b  .} {1 {FOREIGN K
f040: 45 59 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61  EY constraint fa
f050: 69 6c 65 64 7d 7d 0a 64 6f 5f 74 65 73 74 20 66  iled}}.do_test f
f060: 6b 65 79 32 2d 63 65 37 63 31 33 2e 31 2e 36 20  key2-ce7c13.1.6 
f070: 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20  {.  catchsql {. 
f080: 20 20 20 55 50 44 41 54 45 20 74 63 65 37 33 20     UPDATE tce73 
f090: 73 65 74 20 61 20 3d 20 31 30 31 20 77 68 65 72  set a = 101 wher
f0a0: 65 20 61 20 3d 20 31 30 30 3b 0a 20 20 7d 0a 7d  e a = 100;.  }.}
f0b0: 20 7b 31 20 7b 46 4f 52 45 49 47 4e 20 4b 45 59   {1 {FOREIGN KEY
f0c0: 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c   constraint fail
f0d0: 65 64 7d 7d 0a 0a 23 20 32 30 31 35 2d 30 34 2d  ed}}..# 2015-04-
f0e0: 31 36 3a 20 20 46 6f 72 65 69 67 6e 20 6b 65 79  16:  Foreign key
f0f0: 20 65 72 72 6f 72 73 20 70 72 6f 70 61 67 61 74   errors propagat
f100: 65 20 62 61 63 6b 20 75 70 20 74 6f 20 74 68 65  e back up to the
f110: 20 70 61 72 73 65 72 2e 0a 23 0a 64 6f 5f 74 65   parser..#.do_te
f120: 73 74 20 66 6b 65 79 32 2d 32 30 31 35 30 34 31  st fkey2-2015041
f130: 36 2d 31 30 30 20 7b 0a 20 20 64 62 20 63 6c 6f  6-100 {.  db clo
f140: 73 65 0a 20 20 73 71 6c 69 74 65 33 20 64 62 20  se.  sqlite3 db 
f150: 3a 6d 65 6d 6f 72 79 3a 0a 20 20 63 61 74 63 68  :memory:.  catch
f160: 73 71 6c 20 7b 0a 20 20 20 20 50 52 41 47 4d 41  sql {.    PRAGMA
f170: 20 66 6f 72 65 69 67 6e 5f 6b 65 79 73 3d 31 3b   foreign_keys=1;
f180: 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  .    CREATE TABL
f190: 45 20 74 31 28 78 20 50 52 49 4d 41 52 59 20 4b  E t1(x PRIMARY K
f1a0: 45 59 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20  EY);.    CREATE 
f1b0: 54 41 42 4c 45 20 74 28 79 20 52 45 46 45 52 45  TABLE t(y REFERE
f1c0: 4e 43 45 53 20 74 30 28 78 29 4f 4e 20 44 45 4c  NCES t0(x)ON DEL
f1d0: 45 54 45 20 53 45 54 20 44 45 46 41 55 4c 54 29  ETE SET DEFAULT)
f1e0: 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42  ;.    CREATE TAB
f1f0: 4c 45 20 74 30 28 79 20 52 45 46 45 52 45 4e 43  LE t0(y REFERENC
f200: 45 53 20 74 31 20 4f 4e 20 44 45 4c 45 54 45 20  ES t1 ON DELETE 
f210: 53 45 54 20 4e 55 4c 4c 29 3b 0a 20 20 20 20 52  SET NULL);.    R
f220: 45 50 4c 41 43 45 20 49 4e 54 4f 20 74 31 20 53  EPLACE INTO t1 S
f230: 45 4c 45 43 54 28 30 29 3b 43 52 45 41 54 45 20  ELECT(0);CREATE 
f240: 54 41 42 4c 45 20 74 32 28 78 29 3b 43 52 45 41  TABLE t2(x);CREA
f250: 54 45 20 54 41 42 4c 45 20 74 33 3b 0a 20 20 7d  TE TABLE t3;.  }
f260: 0a 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b  .} {1 {foreign k
f270: 65 79 20 6d 69 73 6d 61 74 63 68 20 2d 20 22 74  ey mismatch - "t
f280: 22 20 72 65 66 65 72 65 6e 63 69 6e 67 20 22 74  " referencing "t
f290: 30 22 7d 7d 0a 0a 66 69 6e 69 73 68 5f 74 65 73  0"}}..finish_tes
f2a0: 74 0a                                            t.