/ Hex Artifact Content
Login

Artifact 080969fe219b3b082b0e097ac18c6af2e5b0631f:


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 66 6f 72 65 69 67 6e 20 6b 65 79 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 66 6f 72 65 69 67 6e 20 6b 65 79 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 66 6f 72 65 69 67 6e 20 6b 65 79 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 66 6f 72 65 69 67 6e 20 6b 65 79 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 66 6f 72 65 69 67 6e 20 6b 65 79 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 66 6f 72 65 69 67 6e 20 6b 65 79 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 66 6f 72 65 69 67 6e 20 6b 65 79 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 66 6f 72 65 69 67 6e 20 6b 65 79 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 66 6f 72 65 69 67 6e 20 6b 65 79 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 66 6f 72 65 69 67 6e 20 6b 65 79 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 66 6f 72 65 69 67 6e 20 6b 65 79 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: 66 6f 72 65 69 67 6e 20 6b 65 79 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 66 6f            {1 {fo
1490: 72 65 69 67 6e 20 6b 65 79 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 66 6f 72 65          {1 {fore
14e0: 69 67 6e 20 6b 65 79 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 20 20 20 7b 31 20 7b 66 6f 72 65  3)"     {1 {fore
15b0: 69 67 6e 20 6b 65 79 20 6d 69 73 6d 61 74 63 68  ign key mismatch
15c0: 7d 7d 0a 7d 0a 0a 64 6f 5f 74 65 73 74 20 66 6b  }}.}..do_test fk
15d0: 65 79 32 2d 31 2e 31 2e 30 20 7b 0a 20 20 65 78  ey2-1.1.0 {.  ex
15e0: 65 63 73 71 6c 20 5b 73 74 72 69 6e 67 20 6d 61  ecsql [string ma
15f0: 70 20 7b 2f 44 2f 20 7b 7d 7d 20 24 46 6b 65 79  p {/D/ {}} $Fkey
1600: 53 69 6d 70 6c 65 53 63 68 65 6d 61 5d 0a 7d 20  SimpleSchema].} 
1610: 7b 7d 0a 66 6f 72 65 61 63 68 20 7b 74 6e 20 7a  {}.foreach {tn z
1620: 53 71 6c 20 72 65 73 7d 20 24 46 6b 65 79 53 69  Sql res} $FkeySi
1630: 6d 70 6c 65 54 65 73 74 73 20 7b 0a 20 20 64 6f  mpleTests {.  do
1640: 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 2e 31 2e  _test fkey2-1.1.
1650: 24 74 6e 20 7b 20 63 61 74 63 68 73 71 6c 20 24  $tn { catchsql $
1660: 7a 53 71 6c 20 7d 20 24 72 65 73 0a 7d 0a 64 72  zSql } $res.}.dr
1670: 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a 0a 64  op_all_tables..d
1680: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 2e 32  o_test fkey2-1.2
1690: 2e 30 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 5b  .0 {.  execsql [
16a0: 73 74 72 69 6e 67 20 6d 61 70 20 7b 2f 44 2f 20  string map {/D/ 
16b0: 7b 44 45 46 45 52 52 41 42 4c 45 20 49 4e 49 54  {DEFERRABLE INIT
16c0: 49 41 4c 4c 59 20 44 45 46 45 52 52 45 44 7d 7d  IALLY DEFERRED}}
16d0: 20 24 46 6b 65 79 53 69 6d 70 6c 65 53 63 68 65   $FkeySimpleSche
16e0: 6d 61 5d 0a 7d 20 7b 7d 0a 66 6f 72 65 61 63 68  ma].} {}.foreach
16f0: 20 7b 74 6e 20 7a 53 71 6c 20 72 65 73 7d 20 24   {tn zSql res} $
1700: 46 6b 65 79 53 69 6d 70 6c 65 54 65 73 74 73 20  FkeySimpleTests 
1710: 7b 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79  {.  do_test fkey
1720: 32 2d 31 2e 32 2e 24 74 6e 20 7b 20 63 61 74 63  2-1.2.$tn { catc
1730: 68 73 71 6c 20 24 7a 53 71 6c 20 7d 20 24 72 65  hsql $zSql } $re
1740: 73 0a 7d 0a 64 72 6f 70 5f 61 6c 6c 5f 74 61 62  s.}.drop_all_tab
1750: 6c 65 73 0a 0a 64 6f 5f 74 65 73 74 20 66 6b 65  les..do_test fke
1760: 79 32 2d 31 2e 33 2e 30 20 7b 0a 20 20 65 78 65  y2-1.3.0 {.  exe
1770: 63 73 71 6c 20 5b 73 74 72 69 6e 67 20 6d 61 70  csql [string map
1780: 20 7b 2f 44 2f 20 7b 7d 7d 20 24 46 6b 65 79 53   {/D/ {}} $FkeyS
1790: 69 6d 70 6c 65 53 63 68 65 6d 61 5d 0a 20 20 65  impleSchema].  e
17a0: 78 65 63 73 71 6c 20 7b 20 50 52 41 47 4d 41 20  xecsql { PRAGMA 
17b0: 63 6f 75 6e 74 5f 63 68 61 6e 67 65 73 20 3d 20  count_changes = 
17c0: 31 20 7d 0a 7d 20 7b 7d 0a 66 6f 72 65 61 63 68  1 }.} {}.foreach
17d0: 20 7b 74 6e 20 7a 53 71 6c 20 72 65 73 7d 20 24   {tn zSql res} $
17e0: 46 6b 65 79 53 69 6d 70 6c 65 54 65 73 74 73 20  FkeySimpleTests 
17f0: 7b 0a 20 20 69 66 20 7b 24 72 65 73 20 3d 3d 20  {.  if {$res == 
1800: 22 30 20 7b 7d 22 7d 20 7b 20 73 65 74 20 72 65  "0 {}"} { set re
1810: 73 20 7b 30 20 31 7d 20 7d 0a 20 20 64 6f 5f 74  s {0 1} }.  do_t
1820: 65 73 74 20 66 6b 65 79 32 2d 31 2e 33 2e 24 74  est fkey2-1.3.$t
1830: 6e 20 7b 20 63 61 74 63 68 73 71 6c 20 24 7a 53  n { catchsql $zS
1840: 71 6c 20 7d 20 24 72 65 73 0a 7d 0a 65 78 65 63  ql } $res.}.exec
1850: 73 71 6c 20 7b 20 50 52 41 47 4d 41 20 63 6f 75  sql { PRAGMA cou
1860: 6e 74 5f 63 68 61 6e 67 65 73 20 3d 20 30 20 7d  nt_changes = 0 }
1870: 0a 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73  .drop_all_tables
1880: 0a 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d  ..do_test fkey2-
1890: 31 2e 34 2e 30 20 7b 0a 20 20 65 78 65 63 73 71  1.4.0 {.  execsq
18a0: 6c 20 5b 73 74 72 69 6e 67 20 6d 61 70 20 7b 2f  l [string map {/
18b0: 44 2f 20 7b 7d 7d 20 24 46 6b 65 79 53 69 6d 70  D/ {}} $FkeySimp
18c0: 6c 65 53 63 68 65 6d 61 5d 0a 20 20 65 78 65 63  leSchema].  exec
18d0: 73 71 6c 20 7b 20 50 52 41 47 4d 41 20 63 6f 75  sql { PRAGMA cou
18e0: 6e 74 5f 63 68 61 6e 67 65 73 20 3d 20 31 20 7d  nt_changes = 1 }
18f0: 0a 7d 20 7b 7d 0a 66 6f 72 65 61 63 68 20 7b 74  .} {}.foreach {t
1900: 6e 20 7a 53 71 6c 20 72 65 73 7d 20 24 46 6b 65  n zSql res} $Fke
1910: 79 53 69 6d 70 6c 65 54 65 73 74 73 20 7b 0a 20  ySimpleTests {. 
1920: 20 69 66 20 7b 24 72 65 73 20 3d 3d 20 22 30 20   if {$res == "0 
1930: 7b 7d 22 7d 20 7b 20 73 65 74 20 72 65 73 20 7b  {}"} { set res {
1940: 30 20 31 7d 20 7d 0a 20 20 65 78 65 63 73 71 6c  0 1} }.  execsql
1950: 20 42 45 47 49 4e 0a 20 20 64 6f 5f 74 65 73 74   BEGIN.  do_test
1960: 20 66 6b 65 79 32 2d 31 2e 34 2e 24 74 6e 20 7b   fkey2-1.4.$tn {
1970: 20 63 61 74 63 68 73 71 6c 20 24 7a 53 71 6c 20   catchsql $zSql 
1980: 7d 20 24 72 65 73 0a 20 20 65 78 65 63 73 71 6c  } $res.  execsql
1990: 20 43 4f 4d 4d 49 54 0a 7d 0a 65 78 65 63 73 71   COMMIT.}.execsq
19a0: 6c 20 7b 20 50 52 41 47 4d 41 20 63 6f 75 6e 74  l { PRAGMA count
19b0: 5f 63 68 61 6e 67 65 73 20 3d 20 30 20 7d 0a 64  _changes = 0 }.d
19c0: 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a 0a  rop_all_tables..
19d0: 23 20 53 70 65 63 69 61 6c 20 74 65 73 74 3a 20  # Special test: 
19e0: 57 68 65 6e 20 74 68 65 20 70 61 72 65 6e 74 20  When the parent 
19f0: 6b 65 79 20 69 73 20 61 6e 20 49 50 4b 2c 20 6d  key is an IPK, m
1a00: 61 6b 65 20 73 75 72 65 20 74 68 65 20 61 66 66  ake sure the aff
1a10: 69 6e 69 74 79 20 6f 66 0a 23 20 74 68 65 20 49  inity of.# the I
1a20: 50 4b 20 69 73 20 6e 6f 74 20 61 70 70 6c 69 65  PK is not applie
1a30: 64 20 74 6f 20 74 68 65 20 63 68 69 6c 64 20 6b  d to the child k
1a40: 65 79 20 76 61 6c 75 65 20 62 65 66 6f 72 65 20  ey value before 
1a50: 69 74 20 69 73 20 69 6e 73 65 72 74 65 64 0a 23  it is inserted.#
1a60: 20 69 6e 74 6f 20 74 68 65 20 63 68 69 6c 64 20   into the child 
1a70: 74 61 62 6c 65 2e 0a 64 6f 5f 74 65 73 74 20 66  table..do_test f
1a80: 6b 65 79 32 2d 31 2e 35 2e 31 20 7b 0a 20 20 65  key2-1.5.1 {.  e
1a90: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45  xecsql {.    CRE
1aa0: 41 54 45 20 54 41 42 4c 45 20 69 28 69 20 49 4e  ATE TABLE i(i IN
1ab0: 54 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b 45  TEGER PRIMARY KE
1ac0: 59 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54  Y);.    CREATE T
1ad0: 41 42 4c 45 20 6a 28 6a 20 52 45 46 45 52 45 4e  ABLE j(j REFEREN
1ae0: 43 45 53 20 69 29 3b 0a 20 20 20 20 49 4e 53 45  CES i);.    INSE
1af0: 52 54 20 49 4e 54 4f 20 69 20 56 41 4c 55 45 53  RT INTO i VALUES
1b00: 28 33 35 29 3b 0a 20 20 20 20 49 4e 53 45 52 54  (35);.    INSERT
1b10: 20 49 4e 54 4f 20 6a 20 56 41 4c 55 45 53 28 27   INTO j VALUES('
1b20: 33 35 2e 30 27 29 3b 0a 20 20 20 20 53 45 4c 45  35.0');.    SELE
1b30: 43 54 20 6a 2c 20 74 79 70 65 6f 66 28 6a 29 20  CT j, typeof(j) 
1b40: 46 52 4f 4d 20 6a 3b 0a 20 20 7d 0a 7d 20 7b 33  FROM j;.  }.} {3
1b50: 35 2e 30 20 74 65 78 74 7d 0a 64 6f 5f 74 65 73  5.0 text}.do_tes
1b60: 74 20 66 6b 65 79 32 2d 31 2e 35 2e 32 20 7b 0a  t fkey2-1.5.2 {.
1b70: 20 20 63 61 74 63 68 73 71 6c 20 7b 20 44 45 4c    catchsql { DEL
1b80: 45 54 45 20 46 52 4f 4d 20 69 20 7d 0a 7d 20 7b  ETE FROM i }.} {
1b90: 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65 79 20 63  1 {foreign key c
1ba0: 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64  onstraint failed
1bb0: 7d 7d 0a 0a 23 20 53 61 6d 65 20 74 65 73 74 20  }}..# Same test 
1bc0: 75 73 69 6e 67 20 61 20 72 65 67 75 6c 61 72 20  using a regular 
1bd0: 70 72 69 6d 61 72 79 20 6b 65 79 20 77 69 74 68  primary key with
1be0: 20 69 6e 74 65 67 65 72 20 61 66 66 69 6e 69 74   integer affinit
1bf0: 79 2e 0a 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c  y..drop_all_tabl
1c00: 65 73 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  es.do_test fkey2
1c10: 2d 31 2e 36 2e 31 20 7b 0a 20 20 65 78 65 63 73  -1.6.1 {.  execs
1c20: 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  ql {.    CREATE 
1c30: 54 41 42 4c 45 20 69 28 69 20 49 4e 54 20 55 4e  TABLE i(i INT UN
1c40: 49 51 55 45 29 3b 0a 20 20 20 20 43 52 45 41 54  IQUE);.    CREAT
1c50: 45 20 54 41 42 4c 45 20 6a 28 6a 20 52 45 46 45  E TABLE j(j REFE
1c60: 52 45 4e 43 45 53 20 69 28 69 29 29 3b 0a 20 20  RENCES i(i));.  
1c70: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 69 20    INSERT INTO i 
1c80: 56 41 4c 55 45 53 28 27 33 35 2e 30 27 29 3b 0a  VALUES('35.0');.
1c90: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
1ca0: 6a 20 56 41 4c 55 45 53 28 27 33 35 2e 30 27 29  j VALUES('35.0')
1cb0: 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 6a 2c 20  ;.    SELECT j, 
1cc0: 74 79 70 65 6f 66 28 6a 29 20 46 52 4f 4d 20 6a  typeof(j) FROM j
1cd0: 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 69 2c 20  ;.    SELECT i, 
1ce0: 74 79 70 65 6f 66 28 69 29 20 46 52 4f 4d 20 69  typeof(i) FROM i
1cf0: 3b 0a 20 20 7d 0a 7d 20 7b 33 35 2e 30 20 74 65  ;.  }.} {35.0 te
1d00: 78 74 20 33 35 20 69 6e 74 65 67 65 72 7d 0a 64  xt 35 integer}.d
1d10: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 2e 36  o_test fkey2-1.6
1d20: 2e 32 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20  .2 {.  catchsql 
1d30: 7b 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 69 20  { DELETE FROM i 
1d40: 7d 0a 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e 20  }.} {1 {foreign 
1d50: 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e 74 20 66  key constraint f
1d60: 61 69 6c 65 64 7d 7d 0a 0a 23 20 55 73 65 20 61  ailed}}..# Use a
1d70: 20 63 6f 6c 6c 61 74 69 6f 6e 20 73 65 71 75 65   collation seque
1d80: 6e 63 65 20 6f 6e 20 74 68 65 20 70 61 72 65 6e  nce on the paren
1d90: 74 20 6b 65 79 2e 0a 64 72 6f 70 5f 61 6c 6c 5f  t key..drop_all_
1da0: 74 61 62 6c 65 73 0a 64 6f 5f 74 65 73 74 20 66  tables.do_test f
1db0: 6b 65 79 32 2d 31 2e 37 2e 31 20 7b 0a 20 20 65  key2-1.7.1 {.  e
1dc0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45  xecsql {.    CRE
1dd0: 41 54 45 20 54 41 42 4c 45 20 69 28 69 20 54 45  ATE TABLE i(i TE
1de0: 58 54 20 43 4f 4c 4c 41 54 45 20 6e 6f 63 61 73  XT COLLATE nocas
1df0: 65 20 50 52 49 4d 41 52 59 20 4b 45 59 29 3b 0a  e PRIMARY KEY);.
1e00: 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45      CREATE TABLE
1e10: 20 6a 28 6a 20 54 45 58 54 20 43 4f 4c 4c 41 54   j(j TEXT COLLAT
1e20: 45 20 62 69 6e 61 72 79 20 52 45 46 45 52 45 4e  E binary REFEREN
1e30: 43 45 53 20 69 28 69 29 29 3b 0a 20 20 20 20 49  CES i(i));.    I
1e40: 4e 53 45 52 54 20 49 4e 54 4f 20 69 20 56 41 4c  NSERT INTO i VAL
1e50: 55 45 53 28 27 53 51 4c 69 74 65 27 29 3b 0a 20  UES('SQLite');. 
1e60: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 6a     INSERT INTO j
1e70: 20 56 41 4c 55 45 53 28 27 73 71 6c 69 74 65 27   VALUES('sqlite'
1e80: 29 3b 0a 20 20 7d 0a 20 20 63 61 74 63 68 73 71  );.  }.  catchsq
1e90: 6c 20 7b 20 44 45 4c 45 54 45 20 46 52 4f 4d 20  l { DELETE FROM 
1ea0: 69 20 7d 0a 7d 20 7b 31 20 7b 66 6f 72 65 69 67  i }.} {1 {foreig
1eb0: 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e 74  n key constraint
1ec0: 20 66 61 69 6c 65 64 7d 7d 0a 0a 23 20 55 73 65   failed}}..# Use
1ed0: 20 74 68 65 20 70 61 72 65 6e 74 20 6b 65 79 20   the parent key 
1ee0: 63 6f 6c 6c 61 74 69 6f 6e 20 65 76 65 6e 20 69  collation even i
1ef0: 66 20 69 74 20 69 73 20 64 65 66 61 75 6c 74 20  f it is default 
1f00: 61 6e 64 20 74 68 65 20 63 68 69 6c 64 20 6b 65  and the child ke
1f10: 79 0a 23 20 68 61 73 20 61 6e 20 65 78 70 6c 69  y.# has an expli
1f20: 63 69 74 20 76 61 6c 75 65 2e 0a 64 72 6f 70 5f  cit value..drop_
1f30: 61 6c 6c 5f 74 61 62 6c 65 73 0a 64 6f 5f 74 65  all_tables.do_te
1f40: 73 74 20 66 6b 65 79 32 2d 31 2e 37 2e 32 20 7b  st fkey2-1.7.2 {
1f50: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
1f60: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 69 28   CREATE TABLE i(
1f70: 69 20 54 45 58 54 20 50 52 49 4d 41 52 59 20 4b  i TEXT PRIMARY K
1f80: 45 59 29 3b 20 20 20 20 20 20 20 20 2d 2d 20 43  EY);        -- C
1f90: 6f 6c 73 65 71 20 69 73 20 22 42 49 4e 41 52 59  olseq is "BINARY
1fa0: 22 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42  ".    CREATE TAB
1fb0: 4c 45 20 6a 28 6a 20 54 45 58 54 20 43 4f 4c 4c  LE j(j TEXT COLL
1fc0: 41 54 45 20 6e 6f 63 61 73 65 20 52 45 46 45 52  ATE nocase REFER
1fd0: 45 4e 43 45 53 20 69 28 69 29 29 3b 0a 20 20 20  ENCES i(i));.   
1fe0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 69 20 56   INSERT INTO i V
1ff0: 41 4c 55 45 53 28 27 53 51 4c 69 74 65 27 29 3b  ALUES('SQLite');
2000: 0a 20 20 7d 0a 20 20 63 61 74 63 68 73 71 6c 20  .  }.  catchsql 
2010: 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 6a 20  { INSERT INTO j 
2020: 56 41 4c 55 45 53 28 27 73 71 6c 69 74 65 27 29  VALUES('sqlite')
2030: 20 7d 0a 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e   }.} {1 {foreign
2040: 20 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e 74 20   key constraint 
2050: 66 61 69 6c 65 64 7d 7d 0a 64 6f 5f 74 65 73 74  failed}}.do_test
2060: 20 66 6b 65 79 32 2d 31 2e 37 2e 33 20 7b 0a 20   fkey2-1.7.3 {. 
2070: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 49   execsql {.    I
2080: 4e 53 45 52 54 20 49 4e 54 4f 20 69 20 56 41 4c  NSERT INTO i VAL
2090: 55 45 53 28 27 73 71 6c 69 74 65 27 29 3b 0a 20  UES('sqlite');. 
20a0: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 6a     INSERT INTO j
20b0: 20 56 41 4c 55 45 53 28 27 73 71 6c 69 74 65 27   VALUES('sqlite'
20c0: 29 3b 0a 20 20 20 20 44 45 4c 45 54 45 20 46 52  );.    DELETE FR
20d0: 4f 4d 20 69 20 57 48 45 52 45 20 69 20 3d 20 27  OM i WHERE i = '
20e0: 53 51 4c 69 74 65 27 3b 0a 20 20 7d 0a 20 20 63  SQLite';.  }.  c
20f0: 61 74 63 68 73 71 6c 20 7b 20 44 45 4c 45 54 45  atchsql { DELETE
2100: 20 46 52 4f 4d 20 69 20 57 48 45 52 45 20 69 20   FROM i WHERE i 
2110: 3d 20 27 73 71 6c 69 74 65 27 20 7d 0a 7d 20 7b  = 'sqlite' }.} {
2120: 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65 79 20 63  1 {foreign key c
2130: 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64  onstraint failed
2140: 7d 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  }}..#-----------
2150: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2160: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2170: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2180: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23  --------------.#
2190: 20 54 68 69 73 20 73 65 63 74 69 6f 6e 20 28 74   This section (t
21a0: 65 73 74 20 63 61 73 65 73 20 66 6b 65 79 32 2d  est cases fkey2-
21b0: 32 2e 2a 29 20 63 6f 6e 74 61 69 6e 73 20 74 65  2.*) contains te
21c0: 73 74 73 20 74 6f 20 63 68 65 63 6b 20 74 68 61  sts to check tha
21d0: 74 20 74 68 65 0a 23 20 64 65 66 65 72 72 65 64  t the.# deferred
21e0: 20 66 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e   foreign key con
21f0: 73 74 72 61 69 6e 74 20 6c 6f 67 69 63 20 77 6f  straint logic wo
2200: 72 6b 73 2e 0a 23 0a 70 72 6f 63 20 66 6b 65 79  rks..#.proc fkey
2210: 32 2d 32 2d 74 65 73 74 20 7b 74 6e 20 6e 6f 63  2-2-test {tn noc
2220: 6f 6d 6d 69 74 20 73 71 6c 20 7b 72 65 73 20 7b  ommit sql {res {
2230: 7d 7d 7d 20 7b 0a 20 20 69 66 20 7b 24 72 65 73  }}} {.  if {$res
2240: 20 65 71 20 22 46 4b 56 22 7d 20 7b 0a 20 20 20   eq "FKV"} {.   
2250: 20 73 65 74 20 65 78 70 65 63 74 65 64 20 7b 31   set expected {1
2260: 20 7b 66 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f   {foreign key co
2270: 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d  nstraint failed}
2280: 7d 0a 20 20 7d 20 65 6c 73 65 20 7b 0a 20 20 20  }.  } else {.   
2290: 20 73 65 74 20 65 78 70 65 63 74 65 64 20 5b 6c   set expected [l
22a0: 69 73 74 20 30 20 24 72 65 73 5d 0a 20 20 7d 0a  ist 0 $res].  }.
22b0: 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d    do_test fkey2-
22c0: 32 2e 24 74 6e 20 5b 6c 69 73 74 20 63 61 74 63  2.$tn [list catc
22d0: 68 73 71 6c 20 24 73 71 6c 5d 20 24 65 78 70 65  hsql $sql] $expe
22e0: 63 74 65 64 0a 20 20 69 66 20 7b 24 6e 6f 63 6f  cted.  if {$noco
22f0: 6d 6d 69 74 7d 20 7b 0a 20 20 20 20 64 6f 5f 74  mmit} {.    do_t
2300: 65 73 74 20 66 6b 65 79 32 2d 32 2e 24 7b 74 6e  est fkey2-2.${tn
2310: 7d 63 20 7b 0a 20 20 20 20 20 20 63 61 74 63 68  }c {.      catch
2320: 73 71 6c 20 43 4f 4d 4d 49 54 0a 20 20 20 20 7d  sql COMMIT.    }
2330: 20 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65 79   {1 {foreign key
2340: 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c   constraint fail
2350: 65 64 7d 7d 0a 20 20 7d 0a 7d 0a 0a 66 6b 65 79  ed}}.  }.}..fkey
2360: 32 2d 32 2d 74 65 73 74 20 31 20 30 20 7b 0a 20  2-2-test 1 0 {. 
2370: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 6e 6f   CREATE TABLE no
2380: 64 65 28 0a 20 20 20 20 6e 6f 64 65 69 64 20 50  de(.    nodeid P
2390: 52 49 4d 41 52 59 20 4b 45 59 2c 0a 20 20 20 20  RIMARY KEY,.    
23a0: 70 61 72 65 6e 74 20 52 45 46 45 52 45 4e 43 45  parent REFERENCE
23b0: 53 20 6e 6f 64 65 20 44 45 46 45 52 52 41 42 4c  S node DEFERRABL
23c0: 45 20 49 4e 49 54 49 41 4c 4c 59 20 44 45 46 45  E INITIALLY DEFE
23d0: 52 52 45 44 0a 20 20 29 3b 0a 20 20 43 52 45 41  RRED.  );.  CREA
23e0: 54 45 20 54 41 42 4c 45 20 6c 65 61 66 28 0a 20  TE TABLE leaf(. 
23f0: 20 20 20 63 65 6c 6c 69 64 20 50 52 49 4d 41 52     cellid PRIMAR
2400: 59 20 4b 45 59 2c 0a 20 20 20 20 70 61 72 65 6e  Y KEY,.    paren
2410: 74 20 52 45 46 45 52 45 4e 43 45 53 20 6e 6f 64  t REFERENCES nod
2420: 65 20 44 45 46 45 52 52 41 42 4c 45 20 49 4e 49  e DEFERRABLE INI
2430: 54 49 41 4c 4c 59 20 44 45 46 45 52 52 45 44 0a  TIALLY DEFERRED.
2440: 20 20 29 3b 0a 7d 0a 0a 66 6b 65 79 32 2d 32 2d    );.}..fkey2-2-
2450: 74 65 73 74 20 31 20 20 30 20 22 49 4e 53 45 52  test 1  0 "INSER
2460: 54 20 49 4e 54 4f 20 6e 6f 64 65 20 56 41 4c 55  T INTO node VALU
2470: 45 53 28 31 2c 20 30 29 22 20 20 20 20 20 20 20  ES(1, 0)"       
2480: 46 4b 56 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74  FKV.fkey2-2-test
2490: 20 32 20 20 30 20 22 42 45 47 49 4e 22 0a 66 6b   2  0 "BEGIN".fk
24a0: 65 79 32 2d 32 2d 74 65 73 74 20 33 20 20 31 20  ey2-2-test 3  1 
24b0: 20 20 22 49 4e 53 45 52 54 20 49 4e 54 4f 20 6e    "INSERT INTO n
24c0: 6f 64 65 20 56 41 4c 55 45 53 28 31 2c 20 30 29  ode VALUES(1, 0)
24d0: 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 34  ".fkey2-2-test 4
24e0: 20 20 30 20 20 20 22 55 50 44 41 54 45 20 6e 6f    0   "UPDATE no
24f0: 64 65 20 53 45 54 20 70 61 72 65 6e 74 20 3d 20  de SET parent = 
2500: 4e 55 4c 4c 22 0a 66 6b 65 79 32 2d 32 2d 74 65  NULL".fkey2-2-te
2510: 73 74 20 35 20 20 30 20 22 43 4f 4d 4d 49 54 22  st 5  0 "COMMIT"
2520: 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 36 20  .fkey2-2-test 6 
2530: 20 30 20 22 53 45 4c 45 43 54 20 2a 20 46 52 4f   0 "SELECT * FRO
2540: 4d 20 6e 6f 64 65 22 20 7b 31 20 7b 7d 7d 0a 0a  M node" {1 {}}..
2550: 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 37 20 20  fkey2-2-test 7  
2560: 30 20 22 42 45 47 49 4e 22 0a 66 6b 65 79 32 2d  0 "BEGIN".fkey2-
2570: 32 2d 74 65 73 74 20 38 20 20 31 20 20 20 22 49  2-test 8  1   "I
2580: 4e 53 45 52 54 20 49 4e 54 4f 20 6c 65 61 66 20  NSERT INTO leaf 
2590: 56 41 4c 55 45 53 28 27 61 27 2c 20 32 29 22 0a  VALUES('a', 2)".
25a0: 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 39 20 20  fkey2-2-test 9  
25b0: 31 20 20 20 22 49 4e 53 45 52 54 20 49 4e 54 4f  1   "INSERT INTO
25c0: 20 6e 6f 64 65 20 56 41 4c 55 45 53 28 32 2c 20   node VALUES(2, 
25d0: 30 29 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74  0)".fkey2-2-test
25e0: 20 31 30 20 30 20 20 20 22 55 50 44 41 54 45 20   10 0   "UPDATE 
25f0: 6e 6f 64 65 20 53 45 54 20 70 61 72 65 6e 74 20  node SET parent 
2600: 3d 20 31 20 57 48 45 52 45 20 6e 6f 64 65 69 64  = 1 WHERE nodeid
2610: 20 3d 20 32 22 0a 66 6b 65 79 32 2d 32 2d 74 65   = 2".fkey2-2-te
2620: 73 74 20 31 31 20 30 20 22 43 4f 4d 4d 49 54 22  st 11 0 "COMMIT"
2630: 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 31 32  .fkey2-2-test 12
2640: 20 30 20 22 53 45 4c 45 43 54 20 2a 20 46 52 4f   0 "SELECT * FRO
2650: 4d 20 6e 6f 64 65 22 20 7b 31 20 7b 7d 20 32 20  M node" {1 {} 2 
2660: 31 7d 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20  1}.fkey2-2-test 
2670: 31 33 20 30 20 22 53 45 4c 45 43 54 20 2a 20 46  13 0 "SELECT * F
2680: 52 4f 4d 20 6c 65 61 66 22 20 7b 61 20 32 7d 0a  ROM leaf" {a 2}.
2690: 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 31 34  .fkey2-2-test 14
26a0: 20 30 20 22 42 45 47 49 4e 22 0a 66 6b 65 79 32   0 "BEGIN".fkey2
26b0: 2d 32 2d 74 65 73 74 20 31 35 20 31 20 20 20 22  -2-test 15 1   "
26c0: 44 45 4c 45 54 45 20 46 52 4f 4d 20 6e 6f 64 65  DELETE FROM node
26d0: 20 57 48 45 52 45 20 6e 6f 64 65 69 64 20 3d 20   WHERE nodeid = 
26e0: 32 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20  2".fkey2-2-test 
26f0: 31 36 20 30 20 20 20 22 49 4e 53 45 52 54 20 49  16 0   "INSERT I
2700: 4e 54 4f 20 6e 6f 64 65 20 56 41 4c 55 45 53 28  NTO node VALUES(
2710: 32 2c 20 4e 55 4c 4c 29 22 0a 66 6b 65 79 32 2d  2, NULL)".fkey2-
2720: 32 2d 74 65 73 74 20 31 37 20 30 20 22 43 4f 4d  2-test 17 0 "COM
2730: 4d 49 54 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73  MIT".fkey2-2-tes
2740: 74 20 31 38 20 30 20 22 53 45 4c 45 43 54 20 2a  t 18 0 "SELECT *
2750: 20 46 52 4f 4d 20 6e 6f 64 65 22 20 7b 31 20 7b   FROM node" {1 {
2760: 7d 20 32 20 7b 7d 7d 0a 66 6b 65 79 32 2d 32 2d  } 2 {}}.fkey2-2-
2770: 74 65 73 74 20 31 39 20 30 20 22 53 45 4c 45 43  test 19 0 "SELEC
2780: 54 20 2a 20 46 52 4f 4d 20 6c 65 61 66 22 20 7b  T * FROM leaf" {
2790: 61 20 32 7d 0a 0a 66 6b 65 79 32 2d 32 2d 74 65  a 2}..fkey2-2-te
27a0: 73 74 20 32 30 20 30 20 22 42 45 47 49 4e 22 0a  st 20 0 "BEGIN".
27b0: 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 32 31 20  fkey2-2-test 21 
27c0: 30 20 20 20 22 49 4e 53 45 52 54 20 49 4e 54 4f  0   "INSERT INTO
27d0: 20 6c 65 61 66 20 56 41 4c 55 45 53 28 27 62 27   leaf VALUES('b'
27e0: 2c 20 31 29 22 0a 66 6b 65 79 32 2d 32 2d 74 65  , 1)".fkey2-2-te
27f0: 73 74 20 32 32 20 30 20 20 20 22 53 41 56 45 50  st 22 0   "SAVEP
2800: 4f 49 4e 54 20 73 61 76 65 22 0a 66 6b 65 79 32  OINT save".fkey2
2810: 2d 32 2d 74 65 73 74 20 32 33 20 30 20 20 20 20  -2-test 23 0    
2820: 20 22 44 45 4c 45 54 45 20 46 52 4f 4d 20 6e 6f   "DELETE FROM no
2830: 64 65 20 57 48 45 52 45 20 6e 6f 64 65 69 64 20  de WHERE nodeid 
2840: 3d 20 31 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73  = 1".fkey2-2-tes
2850: 74 20 32 34 20 30 20 20 20 22 52 4f 4c 4c 42 41  t 24 0   "ROLLBA
2860: 43 4b 20 54 4f 20 73 61 76 65 22 0a 66 6b 65 79  CK TO save".fkey
2870: 32 2d 32 2d 74 65 73 74 20 32 35 20 30 20 22 43  2-2-test 25 0 "C
2880: 4f 4d 4d 49 54 22 0a 66 6b 65 79 32 2d 32 2d 74  OMMIT".fkey2-2-t
2890: 65 73 74 20 32 36 20 30 20 22 53 45 4c 45 43 54  est 26 0 "SELECT
28a0: 20 2a 20 46 52 4f 4d 20 6e 6f 64 65 22 20 7b 31   * FROM node" {1
28b0: 20 7b 7d 20 32 20 7b 7d 7d 0a 66 6b 65 79 32 2d   {} 2 {}}.fkey2-
28c0: 32 2d 74 65 73 74 20 32 37 20 30 20 22 53 45 4c  2-test 27 0 "SEL
28d0: 45 43 54 20 2a 20 46 52 4f 4d 20 6c 65 61 66 22  ECT * FROM leaf"
28e0: 20 7b 61 20 32 20 62 20 31 7d 0a 0a 66 6b 65 79   {a 2 b 1}..fkey
28f0: 32 2d 32 2d 74 65 73 74 20 32 38 20 30 20 22 42  2-2-test 28 0 "B
2900: 45 47 49 4e 22 0a 66 6b 65 79 32 2d 32 2d 74 65  EGIN".fkey2-2-te
2910: 73 74 20 32 39 20 30 20 20 20 22 49 4e 53 45 52  st 29 0   "INSER
2920: 54 20 49 4e 54 4f 20 6c 65 61 66 20 56 41 4c 55  T INTO leaf VALU
2930: 45 53 28 27 63 27 2c 20 31 29 22 0a 66 6b 65 79  ES('c', 1)".fkey
2940: 32 2d 32 2d 74 65 73 74 20 33 30 20 30 20 20 20  2-2-test 30 0   
2950: 22 53 41 56 45 50 4f 49 4e 54 20 73 61 76 65 22  "SAVEPOINT save"
2960: 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 33 31  .fkey2-2-test 31
2970: 20 30 20 20 20 20 20 22 44 45 4c 45 54 45 20 46   0     "DELETE F
2980: 52 4f 4d 20 6e 6f 64 65 20 57 48 45 52 45 20 6e  ROM node WHERE n
2990: 6f 64 65 69 64 20 3d 20 31 22 0a 66 6b 65 79 32  odeid = 1".fkey2
29a0: 2d 32 2d 74 65 73 74 20 33 32 20 31 20 20 20 22  -2-test 32 1   "
29b0: 52 45 4c 45 41 53 45 20 73 61 76 65 22 0a 66 6b  RELEASE save".fk
29c0: 65 79 32 2d 32 2d 74 65 73 74 20 33 33 20 31 20  ey2-2-test 33 1 
29d0: 20 20 22 44 45 4c 45 54 45 20 46 52 4f 4d 20 6c    "DELETE FROM l
29e0: 65 61 66 20 57 48 45 52 45 20 63 65 6c 6c 69 64  eaf WHERE cellid
29f0: 20 3d 20 27 62 27 22 0a 66 6b 65 79 32 2d 32 2d   = 'b'".fkey2-2-
2a00: 74 65 73 74 20 33 34 20 30 20 20 20 22 44 45 4c  test 34 0   "DEL
2a10: 45 54 45 20 46 52 4f 4d 20 6c 65 61 66 20 57 48  ETE FROM leaf WH
2a20: 45 52 45 20 63 65 6c 6c 69 64 20 3d 20 27 63 27  ERE cellid = 'c'
2a30: 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 33  ".fkey2-2-test 3
2a40: 35 20 30 20 22 43 4f 4d 4d 49 54 22 0a 66 6b 65  5 0 "COMMIT".fke
2a50: 79 32 2d 32 2d 74 65 73 74 20 33 36 20 30 20 22  y2-2-test 36 0 "
2a60: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 6e 6f  SELECT * FROM no
2a70: 64 65 22 20 7b 32 20 7b 7d 7d 20 0a 66 6b 65 79  de" {2 {}} .fkey
2a80: 32 2d 32 2d 74 65 73 74 20 33 37 20 30 20 22 53  2-2-test 37 0 "S
2a90: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 6c 65 61  ELECT * FROM lea
2aa0: 66 22 20 7b 61 20 32 7d 0a 0a 66 6b 65 79 32 2d  f" {a 2}..fkey2-
2ab0: 32 2d 74 65 73 74 20 33 38 20 30 20 22 53 41 56  2-test 38 0 "SAV
2ac0: 45 50 4f 49 4e 54 20 6f 75 74 65 72 22 0a 66 6b  EPOINT outer".fk
2ad0: 65 79 32 2d 32 2d 74 65 73 74 20 33 39 20 31 20  ey2-2-test 39 1 
2ae0: 20 20 22 49 4e 53 45 52 54 20 49 4e 54 4f 20 6c    "INSERT INTO l
2af0: 65 61 66 20 56 41 4c 55 45 53 28 27 64 27 2c 20  eaf VALUES('d', 
2b00: 33 29 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74  3)".fkey2-2-test
2b10: 20 34 30 20 31 20 22 52 45 4c 45 41 53 45 20 6f   40 1 "RELEASE o
2b20: 75 74 65 72 22 20 20 20 20 46 4b 56 0a 66 6b 65  uter"    FKV.fke
2b30: 79 32 2d 32 2d 74 65 73 74 20 34 31 20 31 20 20  y2-2-test 41 1  
2b40: 20 22 49 4e 53 45 52 54 20 49 4e 54 4f 20 6c 65   "INSERT INTO le
2b50: 61 66 20 56 41 4c 55 45 53 28 27 65 27 2c 20 33  af VALUES('e', 3
2b60: 29 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20  )".fkey2-2-test 
2b70: 34 32 20 30 20 20 20 22 49 4e 53 45 52 54 20 49  42 0   "INSERT I
2b80: 4e 54 4f 20 6e 6f 64 65 20 56 41 4c 55 45 53 28  NTO node VALUES(
2b90: 33 2c 20 32 29 22 0a 66 6b 65 79 32 2d 32 2d 74  3, 2)".fkey2-2-t
2ba0: 65 73 74 20 34 33 20 30 20 22 52 45 4c 45 41 53  est 43 0 "RELEAS
2bb0: 45 20 6f 75 74 65 72 22 0a 0a 66 6b 65 79 32 2d  E outer"..fkey2-
2bc0: 32 2d 74 65 73 74 20 34 34 20 30 20 22 53 41 56  2-test 44 0 "SAV
2bd0: 45 50 4f 49 4e 54 20 6f 75 74 65 72 22 0a 66 6b  EPOINT outer".fk
2be0: 65 79 32 2d 32 2d 74 65 73 74 20 34 35 20 31 20  ey2-2-test 45 1 
2bf0: 20 20 22 44 45 4c 45 54 45 20 46 52 4f 4d 20 6e    "DELETE FROM n
2c00: 6f 64 65 20 57 48 45 52 45 20 6e 6f 64 65 69 64  ode WHERE nodeid
2c10: 3d 33 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74  =3".fkey2-2-test
2c20: 20 34 37 20 30 20 20 20 22 49 4e 53 45 52 54 20   47 0   "INSERT 
2c30: 49 4e 54 4f 20 6e 6f 64 65 20 56 41 4c 55 45 53  INTO node VALUES
2c40: 28 33 2c 20 32 29 22 0a 66 6b 65 79 32 2d 32 2d  (3, 2)".fkey2-2-
2c50: 74 65 73 74 20 34 38 20 30 20 22 52 4f 4c 4c 42  test 48 0 "ROLLB
2c60: 41 43 4b 20 54 4f 20 6f 75 74 65 72 22 0a 66 6b  ACK TO outer".fk
2c70: 65 79 32 2d 32 2d 74 65 73 74 20 34 39 20 30 20  ey2-2-test 49 0 
2c80: 22 52 45 4c 45 41 53 45 20 6f 75 74 65 72 22 0a  "RELEASE outer".
2c90: 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 35 30  .fkey2-2-test 50
2ca0: 20 30 20 22 53 41 56 45 50 4f 49 4e 54 20 6f 75   0 "SAVEPOINT ou
2cb0: 74 65 72 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73  ter".fkey2-2-tes
2cc0: 74 20 35 31 20 31 20 20 20 22 49 4e 53 45 52 54  t 51 1   "INSERT
2cd0: 20 49 4e 54 4f 20 6c 65 61 66 20 56 41 4c 55 45   INTO leaf VALUE
2ce0: 53 28 27 66 27 2c 20 34 29 22 0a 66 6b 65 79 32  S('f', 4)".fkey2
2cf0: 2d 32 2d 74 65 73 74 20 35 32 20 31 20 20 20 22  -2-test 52 1   "
2d00: 53 41 56 45 50 4f 49 4e 54 20 69 6e 6e 65 72 22  SAVEPOINT inner"
2d10: 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 35 33  .fkey2-2-test 53
2d20: 20 31 20 20 20 20 20 22 49 4e 53 45 52 54 20 49   1     "INSERT I
2d30: 4e 54 4f 20 6c 65 61 66 20 56 41 4c 55 45 53 28  NTO leaf VALUES(
2d40: 27 67 27 2c 20 34 29 22 0a 66 6b 65 79 32 2d 32  'g', 4)".fkey2-2
2d50: 2d 74 65 73 74 20 35 34 20 31 20 20 22 52 45 4c  -test 54 1  "REL
2d60: 45 41 53 45 20 6f 75 74 65 72 22 20 20 20 46 4b  EASE outer"   FK
2d70: 56 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 35  V.fkey2-2-test 5
2d80: 35 20 31 20 20 20 22 52 4f 4c 4c 42 41 43 4b 20  5 1   "ROLLBACK 
2d90: 54 4f 20 69 6e 6e 65 72 22 0a 66 6b 65 79 32 2d  TO inner".fkey2-
2da0: 32 2d 74 65 73 74 20 35 36 20 30 20 20 22 43 4f  2-test 56 0  "CO
2db0: 4d 4d 49 54 22 20 20 20 20 20 20 20 20 20 20 46  MMIT"          F
2dc0: 4b 56 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20  KV.fkey2-2-test 
2dd0: 35 37 20 30 20 20 20 22 49 4e 53 45 52 54 20 49  57 0   "INSERT I
2de0: 4e 54 4f 20 6e 6f 64 65 20 56 41 4c 55 45 53 28  NTO node VALUES(
2df0: 34 2c 20 4e 55 4c 4c 29 22 0a 66 6b 65 79 32 2d  4, NULL)".fkey2-
2e00: 32 2d 74 65 73 74 20 35 38 20 30 20 22 52 45 4c  2-test 58 0 "REL
2e10: 45 41 53 45 20 6f 75 74 65 72 22 0a 66 6b 65 79  EASE outer".fkey
2e20: 32 2d 32 2d 74 65 73 74 20 35 39 20 30 20 22 53  2-2-test 59 0 "S
2e30: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 6e 6f 64  ELECT * FROM nod
2e40: 65 22 20 7b 32 20 7b 7d 20 33 20 32 20 34 20 7b  e" {2 {} 3 2 4 {
2e50: 7d 7d 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20  }}.fkey2-2-test 
2e60: 36 30 20 30 20 22 53 45 4c 45 43 54 20 2a 20 46  60 0 "SELECT * F
2e70: 52 4f 4d 20 6c 65 61 66 22 20 7b 61 20 32 20 64  ROM leaf" {a 2 d
2e80: 20 33 20 65 20 33 20 66 20 34 7d 0a 0a 23 20 54   3 e 3 f 4}..# T
2e90: 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 73 65 74  he following set
2ea0: 20 6f 66 20 74 65 73 74 73 20 63 68 65 63 6b 20   of tests check 
2eb0: 74 68 61 74 20 69 66 20 61 20 73 74 61 74 65 6d  that if a statem
2ec0: 65 6e 74 20 74 68 61 74 20 61 66 66 65 63 74 73  ent that affects
2ed0: 20 0a 23 20 6d 75 6c 74 69 70 6c 65 20 72 6f 77   .# multiple row
2ee0: 73 20 76 69 6f 6c 61 74 65 73 20 73 6f 6d 65 20  s violates some 
2ef0: 66 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73  foreign key cons
2f00: 74 72 61 69 6e 74 73 2c 20 74 68 65 6e 20 73 74  traints, then st
2f10: 72 69 6b 65 73 20 61 20 0a 23 20 63 6f 6e 73 74  rikes a .# const
2f20: 72 61 69 6e 74 20 74 68 61 74 20 63 61 75 73 65  raint that cause
2f30: 73 20 74 68 65 20 73 74 61 74 65 6d 65 6e 74 2d  s the statement-
2f40: 74 72 61 6e 73 61 63 74 69 6f 6e 20 74 6f 20 62  transaction to b
2f50: 65 20 72 6f 6c 6c 65 64 20 62 61 63 6b 2c 20 0a  e rolled back, .
2f60: 23 20 74 68 65 20 64 65 66 65 72 72 65 64 20 63  # the deferred c
2f70: 6f 6e 73 74 72 61 69 6e 74 20 63 6f 75 6e 74 65  onstraint counte
2f80: 72 20 69 73 20 63 6f 72 72 65 63 74 6c 79 20 72  r is correctly r
2f90: 65 73 65 74 20 74 6f 20 74 68 65 20 76 61 6c 75  eset to the valu
2fa0: 65 20 69 74 20 0a 23 20 68 61 64 20 62 65 66 6f  e it .# had befo
2fb0: 72 65 20 74 68 65 20 73 74 61 74 65 6d 65 6e 74  re the statement
2fc0: 2d 74 72 61 6e 73 61 63 74 69 6f 6e 20 77 61 73  -transaction was
2fd0: 20 6f 70 65 6e 65 64 2e 0a 23 0a 66 6b 65 79 32   opened..#.fkey2
2fe0: 2d 32 2d 74 65 73 74 20 36 31 20 30 20 22 42 45  -2-test 61 0 "BE
2ff0: 47 49 4e 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73  GIN".fkey2-2-tes
3000: 74 20 36 32 20 30 20 20 20 22 44 45 4c 45 54 45  t 62 0   "DELETE
3010: 20 46 52 4f 4d 20 6c 65 61 66 22 0a 66 6b 65 79   FROM leaf".fkey
3020: 32 2d 32 2d 74 65 73 74 20 36 33 20 30 20 20 20  2-2-test 63 0   
3030: 22 44 45 4c 45 54 45 20 46 52 4f 4d 20 6e 6f 64  "DELETE FROM nod
3040: 65 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20  e".fkey2-2-test 
3050: 36 34 20 31 20 20 20 22 49 4e 53 45 52 54 20 49  64 1   "INSERT I
3060: 4e 54 4f 20 6c 65 61 66 20 56 41 4c 55 45 53 28  NTO leaf VALUES(
3070: 27 61 27 2c 20 31 29 22 0a 66 6b 65 79 32 2d 32  'a', 1)".fkey2-2
3080: 2d 74 65 73 74 20 36 35 20 31 20 20 20 22 49 4e  -test 65 1   "IN
3090: 53 45 52 54 20 49 4e 54 4f 20 6c 65 61 66 20 56  SERT INTO leaf V
30a0: 41 4c 55 45 53 28 27 62 27 2c 20 32 29 22 0a 66  ALUES('b', 2)".f
30b0: 6b 65 79 32 2d 32 2d 74 65 73 74 20 36 36 20 31  key2-2-test 66 1
30c0: 20 20 20 22 49 4e 53 45 52 54 20 49 4e 54 4f 20     "INSERT INTO 
30d0: 6c 65 61 66 20 56 41 4c 55 45 53 28 27 63 27 2c  leaf VALUES('c',
30e0: 20 31 29 22 0a 64 6f 5f 74 65 73 74 20 66 6b 65   1)".do_test fke
30f0: 79 32 2d 32 2d 74 65 73 74 2d 36 37 20 7b 0a 20  y2-2-test-67 {. 
3100: 20 63 61 74 63 68 73 71 6c 20 20 20 20 20 20 20   catchsql       
3110: 20 20 20 22 49 4e 53 45 52 54 20 49 4e 54 4f 20     "INSERT INTO 
3120: 6e 6f 64 65 20 53 45 4c 45 43 54 20 70 61 72 65  node SELECT pare
3130: 6e 74 2c 20 33 20 46 52 4f 4d 20 6c 65 61 66 22  nt, 3 FROM leaf"
3140: 0a 7d 20 7b 31 20 7b 63 6f 6c 75 6d 6e 20 6e 6f  .} {1 {column no
3150: 64 65 69 64 20 69 73 20 6e 6f 74 20 75 6e 69 71  deid is not uniq
3160: 75 65 7d 7d 0a 66 6b 65 79 32 2d 32 2d 74 65 73  ue}}.fkey2-2-tes
3170: 74 20 36 38 20 30 20 22 43 4f 4d 4d 49 54 22 20  t 68 0 "COMMIT" 
3180: 20 20 20 20 20 20 20 20 20 20 46 4b 56 0a 66 6b            FKV.fk
3190: 65 79 32 2d 32 2d 74 65 73 74 20 36 39 20 31 20  ey2-2-test 69 1 
31a0: 20 20 22 49 4e 53 45 52 54 20 49 4e 54 4f 20 6e    "INSERT INTO n
31b0: 6f 64 65 20 56 41 4c 55 45 53 28 31 2c 20 4e 55  ode VALUES(1, NU
31c0: 4c 4c 29 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73  LL)".fkey2-2-tes
31d0: 74 20 37 30 20 30 20 20 20 22 49 4e 53 45 52 54  t 70 0   "INSERT
31e0: 20 49 4e 54 4f 20 6e 6f 64 65 20 56 41 4c 55 45   INTO node VALUE
31f0: 53 28 32 2c 20 4e 55 4c 4c 29 22 0a 66 6b 65 79  S(2, NULL)".fkey
3200: 32 2d 32 2d 74 65 73 74 20 37 31 20 30 20 22 43  2-2-test 71 0 "C
3210: 4f 4d 4d 49 54 22 0a 0a 66 6b 65 79 32 2d 32 2d  OMMIT"..fkey2-2-
3220: 74 65 73 74 20 37 32 20 30 20 22 42 45 47 49 4e  test 72 0 "BEGIN
3230: 22 0a 66 6b 65 79 32 2d 32 2d 74 65 73 74 20 37  ".fkey2-2-test 7
3240: 33 20 31 20 20 20 22 44 45 4c 45 54 45 20 46 52  3 1   "DELETE FR
3250: 4f 4d 20 6e 6f 64 65 22 0a 66 6b 65 79 32 2d 32  OM node".fkey2-2
3260: 2d 74 65 73 74 20 37 34 20 30 20 20 20 22 49 4e  -test 74 0   "IN
3270: 53 45 52 54 20 49 4e 54 4f 20 6e 6f 64 65 28 6e  SERT INTO node(n
3280: 6f 64 65 69 64 29 20 53 45 4c 45 43 54 20 44 49  odeid) SELECT DI
3290: 53 54 49 4e 43 54 20 70 61 72 65 6e 74 20 46 52  STINCT parent FR
32a0: 4f 4d 20 6c 65 61 66 22 0a 66 6b 65 79 32 2d 32  OM leaf".fkey2-2
32b0: 2d 74 65 73 74 20 37 35 20 30 20 22 43 4f 4d 4d  -test 75 0 "COMM
32c0: 49 54 22 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  IT"..#----------
32d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
32e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
32f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3300: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a  ---------------.
3310: 23 20 54 65 73 74 20 63 61 73 65 73 20 66 6b 65  # Test cases fke
3320: 79 32 2d 33 2e 2a 20 74 65 73 74 20 74 68 61 74  y2-3.* test that
3330: 20 61 20 70 72 6f 67 72 61 6d 20 74 68 61 74 20   a program that 
3340: 65 78 65 63 75 74 65 73 20 66 6f 72 65 69 67 6e  executes foreign
3350: 20 6b 65 79 0a 23 20 61 63 74 69 6f 6e 73 20 28   key.# actions (
3360: 43 41 53 43 41 44 45 2c 20 53 45 54 20 44 45 46  CASCADE, SET DEF
3370: 41 55 4c 54 2c 20 53 45 54 20 4e 55 4c 4c 20 65  AULT, SET NULL e
3380: 74 63 2e 29 20 6f 72 20 74 65 73 74 73 20 46 4b  tc.) or tests FK
3390: 20 63 6f 6e 73 74 72 61 69 6e 74 73 0a 23 20 6f   constraints.# o
33a0: 70 65 6e 73 20 61 20 73 74 61 74 65 6d 65 6e 74  pens a statement
33b0: 20 74 72 61 6e 73 61 63 74 69 6f 6e 20 69 66 20   transaction if 
33c0: 72 65 71 75 69 72 65 64 2e 0a 23 0a 23 20 66 6b  required..#.# fk
33d0: 65 79 32 2d 33 2e 31 2e 2a 3a 20 54 65 73 74 20  ey2-3.1.*: Test 
33e0: 55 50 44 41 54 45 20 73 74 61 74 65 6d 65 6e 74  UPDATE statement
33f0: 73 2e 0a 23 20 66 6b 65 79 32 2d 33 2e 32 2e 2a  s..# fkey2-3.2.*
3400: 3a 20 54 65 73 74 20 44 45 4c 45 54 45 20 73 74  : Test DELETE st
3410: 61 74 65 6d 65 6e 74 73 2e 0a 23 0a 64 72 6f 70  atements..#.drop
3420: 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a 64 6f 5f 74  _all_tables.do_t
3430: 65 73 74 20 66 6b 65 79 32 2d 33 2e 31 2e 31 20  est fkey2-3.1.1 
3440: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
3450: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 61    CREATE TABLE a
3460: 62 28 61 20 50 52 49 4d 41 52 59 20 4b 45 59 2c  b(a PRIMARY KEY,
3470: 20 62 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20   b);.    CREATE 
3480: 54 41 42 4c 45 20 63 64 28 0a 20 20 20 20 20 20  TABLE cd(.      
3490: 63 20 50 52 49 4d 41 52 59 20 4b 45 59 20 52 45  c PRIMARY KEY RE
34a0: 46 45 52 45 4e 43 45 53 20 61 62 20 4f 4e 20 55  FERENCES ab ON U
34b0: 50 44 41 54 45 20 43 41 53 43 41 44 45 20 4f 4e  PDATE CASCADE ON
34c0: 20 44 45 4c 45 54 45 20 43 41 53 43 41 44 45 2c   DELETE CASCADE,
34d0: 20 0a 20 20 20 20 20 20 64 0a 20 20 20 20 29 3b   .      d.    );
34e0: 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  .    CREATE TABL
34f0: 45 20 65 66 28 0a 20 20 20 20 20 20 65 20 52 45  E ef(.      e RE
3500: 46 45 52 45 4e 43 45 53 20 63 64 20 4f 4e 20 55  FERENCES cd ON U
3510: 50 44 41 54 45 20 43 41 53 43 41 44 45 2c 20 0a  PDATE CASCADE, .
3520: 20 20 20 20 20 20 66 2c 20 43 48 45 43 4b 20 28        f, CHECK (
3530: 65 21 3d 35 29 0a 20 20 20 20 29 3b 0a 20 20 7d  e!=5).    );.  }
3540: 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b  .} {}.do_test fk
3550: 65 79 32 2d 33 2e 31 2e 32 20 7b 0a 20 20 65 78  ey2-3.1.2 {.  ex
3560: 65 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45  ecsql {.    INSE
3570: 52 54 20 49 4e 54 4f 20 61 62 20 56 41 4c 55 45  RT INTO ab VALUE
3580: 53 28 31 2c 20 27 62 27 29 3b 0a 20 20 20 20 49  S(1, 'b');.    I
3590: 4e 53 45 52 54 20 49 4e 54 4f 20 63 64 20 56 41  NSERT INTO cd VA
35a0: 4c 55 45 53 28 31 2c 20 27 64 27 29 3b 0a 20 20  LUES(1, 'd');.  
35b0: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 65 66    INSERT INTO ef
35c0: 20 56 41 4c 55 45 53 28 31 2c 20 27 65 27 29 3b   VALUES(1, 'e');
35d0: 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73  .  }.} {}.do_tes
35e0: 74 20 66 6b 65 79 32 2d 33 2e 31 2e 33 20 7b 0a  t fkey2-3.1.3 {.
35f0: 20 20 63 61 74 63 68 73 71 6c 20 7b 20 55 50 44    catchsql { UPD
3600: 41 54 45 20 61 62 20 53 45 54 20 61 20 3d 20 35  ATE ab SET a = 5
3610: 20 7d 0a 7d 20 7b 31 20 7b 63 6f 6e 73 74 72 61   }.} {1 {constra
3620: 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 64 6f 5f  int failed}}.do_
3630: 74 65 73 74 20 66 6b 65 79 32 2d 33 2e 31 2e 34  test fkey2-3.1.4
3640: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 53   {.  execsql { S
3650: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 61 62 20  ELECT * FROM ab 
3660: 7d 0a 7d 20 7b 31 20 62 7d 0a 64 6f 5f 74 65 73  }.} {1 b}.do_tes
3670: 74 20 66 6b 65 79 32 2d 33 2e 31 2e 34 20 7b 0a  t fkey2-3.1.4 {.
3680: 20 20 65 78 65 63 73 71 6c 20 42 45 47 49 4e 3b    execsql BEGIN;
3690: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 20 55 50  .  catchsql { UP
36a0: 44 41 54 45 20 61 62 20 53 45 54 20 61 20 3d 20  DATE ab SET a = 
36b0: 35 20 7d 0a 7d 20 7b 31 20 7b 63 6f 6e 73 74 72  5 }.} {1 {constr
36c0: 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 64 6f  aint failed}}.do
36d0: 5f 74 65 73 74 20 66 6b 65 79 32 2d 33 2e 31 2e  _test fkey2-3.1.
36e0: 35 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 43 4f  5 {.  execsql CO
36f0: 4d 4d 49 54 3b 0a 20 20 65 78 65 63 73 71 6c 20  MMIT;.  execsql 
3700: 7b 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  { SELECT * FROM 
3710: 61 62 3b 20 53 45 4c 45 43 54 20 2a 20 46 52 4f  ab; SELECT * FRO
3720: 4d 20 63 64 3b 20 53 45 4c 45 43 54 20 2a 20 46  M cd; SELECT * F
3730: 52 4f 4d 20 65 66 20 7d 0a 7d 20 7b 31 20 62 20  ROM ef }.} {1 b 
3740: 31 20 64 20 31 20 65 7d 0a 0a 64 6f 5f 74 65 73  1 d 1 e}..do_tes
3750: 74 20 66 6b 65 79 32 2d 33 2e 32 2e 31 20 7b 0a  t fkey2-3.2.1 {.
3760: 20 20 65 78 65 63 73 71 6c 20 42 45 47 49 4e 3b    execsql BEGIN;
3770: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 20 44 45  .  catchsql { DE
3780: 4c 45 54 45 20 46 52 4f 4d 20 61 62 20 7d 0a 7d  LETE FROM ab }.}
3790: 20 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65 79   {1 {foreign key
37a0: 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c   constraint fail
37b0: 65 64 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65  ed}}.do_test fke
37c0: 79 32 2d 33 2e 32 2e 32 20 7b 0a 20 20 65 78 65  y2-3.2.2 {.  exe
37d0: 63 73 71 6c 20 43 4f 4d 4d 49 54 0a 20 20 65 78  csql COMMIT.  ex
37e0: 65 63 73 71 6c 20 7b 20 53 45 4c 45 43 54 20 2a  ecsql { SELECT *
37f0: 20 46 52 4f 4d 20 61 62 3b 20 53 45 4c 45 43 54   FROM ab; SELECT
3800: 20 2a 20 46 52 4f 4d 20 63 64 3b 20 53 45 4c 45   * FROM cd; SELE
3810: 43 54 20 2a 20 46 52 4f 4d 20 65 66 20 7d 0a 7d  CT * FROM ef }.}
3820: 20 7b 31 20 62 20 31 20 64 20 31 20 65 7d 0a 0a   {1 b 1 d 1 e}..
3830: 23 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 2d 2d  ----------------
3860: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3870: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 54 65 73  ----------.# Tes
3880: 74 20 63 61 73 65 73 20 66 6b 65 79 32 2d 34 2e  t cases fkey2-4.
3890: 2a 20 74 65 73 74 20 74 68 61 74 20 72 65 63 75  * test that recu
38a0: 72 73 69 76 65 20 66 6f 72 65 69 67 6e 20 6b 65  rsive foreign ke
38b0: 79 20 61 63 74 69 6f 6e 73 20 0a 23 20 28 69 2e  y actions .# (i.
38c0: 65 2e 20 43 41 53 43 41 44 45 29 20 61 72 65 20  e. CASCADE) are 
38d0: 61 6c 6c 6f 77 65 64 20 65 76 65 6e 20 69 66 20  allowed even if 
38e0: 72 65 63 75 72 73 69 76 65 20 74 72 69 67 67 65  recursive trigge
38f0: 72 73 20 61 72 65 20 64 69 73 61 62 6c 65 64 2e  rs are disabled.
3900: 0a 23 0a 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c  .#.drop_all_tabl
3910: 65 73 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  es.do_test fkey2
3920: 2d 34 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c  -4.1 {.  execsql
3930: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41   {.    CREATE TA
3940: 42 4c 45 20 74 31 28 0a 20 20 20 20 20 20 6e 6f  BLE t1(.      no
3950: 64 65 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20  de PRIMARY KEY, 
3960: 0a 20 20 20 20 20 20 70 61 72 65 6e 74 20 52 45  .      parent RE
3970: 46 45 52 45 4e 43 45 53 20 74 31 20 4f 4e 20 44  FERENCES t1 ON D
3980: 45 4c 45 54 45 20 43 41 53 43 41 44 45 0a 20 20  ELETE CASCADE.  
3990: 20 20 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20    );.    CREATE 
39a0: 54 41 42 4c 45 20 74 32 28 6e 6f 64 65 20 50 52  TABLE t2(node PR
39b0: 49 4d 41 52 59 20 4b 45 59 2c 20 70 61 72 65 6e  IMARY KEY, paren
39c0: 74 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54  t);.    CREATE T
39d0: 52 49 47 47 45 52 20 74 32 74 20 41 46 54 45 52  RIGGER t2t AFTER
39e0: 20 44 45 4c 45 54 45 20 4f 4e 20 74 32 20 42 45   DELETE ON t2 BE
39f0: 47 49 4e 0a 20 20 20 20 20 20 44 45 4c 45 54 45  GIN.      DELETE
3a00: 20 46 52 4f 4d 20 74 32 20 57 48 45 52 45 20 70   FROM t2 WHERE p
3a10: 61 72 65 6e 74 20 3d 20 6f 6c 64 2e 6e 6f 64 65  arent = old.node
3a20: 3b 0a 20 20 20 20 45 4e 44 3b 0a 20 20 20 20 49  ;.    END;.    I
3a30: 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41  NSERT INTO t1 VA
3a40: 4c 55 45 53 28 31 2c 20 4e 55 4c 4c 29 3b 0a 20  LUES(1, NULL);. 
3a50: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
3a60: 31 20 56 41 4c 55 45 53 28 32 2c 20 31 29 3b 0a  1 VALUES(2, 1);.
3a70: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
3a80: 74 31 20 56 41 4c 55 45 53 28 33 2c 20 31 29 3b  t1 VALUES(3, 1);
3a90: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
3aa0: 20 74 31 20 56 41 4c 55 45 53 28 34 2c 20 32 29   t1 VALUES(4, 2)
3ab0: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
3ac0: 4f 20 74 31 20 56 41 4c 55 45 53 28 35 2c 20 32  O t1 VALUES(5, 2
3ad0: 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  );.    INSERT IN
3ae0: 54 4f 20 74 31 20 56 41 4c 55 45 53 28 36 2c 20  TO t1 VALUES(6, 
3af0: 33 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  3);.    INSERT I
3b00: 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 37 2c  NTO t1 VALUES(7,
3b10: 20 33 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20   3);.    INSERT 
3b20: 49 4e 54 4f 20 74 32 20 53 45 4c 45 43 54 20 2a  INTO t2 SELECT *
3b30: 20 46 52 4f 4d 20 74 31 3b 0a 20 20 7d 0a 7d 20   FROM t1;.  }.} 
3b40: 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  {}.do_test fkey2
3b50: 2d 34 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c  -4.2 {.  execsql
3b60: 20 7b 20 50 52 41 47 4d 41 20 72 65 63 75 72 73   { PRAGMA recurs
3b70: 69 76 65 5f 74 72 69 67 67 65 72 73 20 3d 20 6f  ive_triggers = o
3b80: 66 66 20 7d 0a 20 20 65 78 65 63 73 71 6c 20 7b  ff }.  execsql {
3b90: 20 0a 20 20 20 20 42 45 47 49 4e 3b 0a 20 20 20   .    BEGIN;.   
3ba0: 20 20 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 74     DELETE FROM t
3bb0: 31 20 57 48 45 52 45 20 6e 6f 64 65 20 3d 20 31  1 WHERE node = 1
3bc0: 3b 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 6e  ;.      SELECT n
3bd0: 6f 64 65 20 46 52 4f 4d 20 74 31 3b 0a 20 20 7d  ode FROM t1;.  }
3be0: 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b  .} {}.do_test fk
3bf0: 65 79 32 2d 34 2e 33 20 7b 0a 20 20 65 78 65 63  ey2-4.3 {.  exec
3c00: 73 71 6c 20 7b 20 0a 20 20 20 20 20 20 44 45 4c  sql { .      DEL
3c10: 45 54 45 20 46 52 4f 4d 20 74 32 20 57 48 45 52  ETE FROM t2 WHER
3c20: 45 20 6e 6f 64 65 20 3d 20 31 3b 0a 20 20 20 20  E node = 1;.    
3c30: 20 20 53 45 4c 45 43 54 20 6e 6f 64 65 20 46 52    SELECT node FR
3c40: 4f 4d 20 74 32 3b 0a 20 20 20 20 52 4f 4c 4c 42  OM t2;.    ROLLB
3c50: 41 43 4b 3b 0a 20 20 7d 0a 7d 20 7b 34 20 35 20  ACK;.  }.} {4 5 
3c60: 36 20 37 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65  6 7}.do_test fke
3c70: 79 32 2d 34 2e 34 20 7b 0a 20 20 65 78 65 63 73  y2-4.4 {.  execs
3c80: 71 6c 20 7b 20 50 52 41 47 4d 41 20 72 65 63 75  ql { PRAGMA recu
3c90: 72 73 69 76 65 5f 74 72 69 67 67 65 72 73 20 3d  rsive_triggers =
3ca0: 20 6f 6e 20 7d 0a 20 20 65 78 65 63 73 71 6c 20   on }.  execsql 
3cb0: 7b 20 0a 20 20 20 20 42 45 47 49 4e 3b 0a 20 20  { .    BEGIN;.  
3cc0: 20 20 20 20 44 45 4c 45 54 45 20 46 52 4f 4d 20      DELETE FROM 
3cd0: 74 31 20 57 48 45 52 45 20 6e 6f 64 65 20 3d 20  t1 WHERE node = 
3ce0: 31 3b 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20  1;.      SELECT 
3cf0: 6e 6f 64 65 20 46 52 4f 4d 20 74 31 3b 0a 20 20  node FROM t1;.  
3d00: 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66  }.} {}.do_test f
3d10: 6b 65 79 32 2d 34 2e 33 20 7b 0a 20 20 65 78 65  key2-4.3 {.  exe
3d20: 63 73 71 6c 20 7b 20 0a 20 20 20 20 20 20 44 45  csql { .      DE
3d30: 4c 45 54 45 20 46 52 4f 4d 20 74 32 20 57 48 45  LETE FROM t2 WHE
3d40: 52 45 20 6e 6f 64 65 20 3d 20 31 3b 0a 20 20 20  RE node = 1;.   
3d50: 20 20 20 53 45 4c 45 43 54 20 6e 6f 64 65 20 46     SELECT node F
3d60: 52 4f 4d 20 74 32 3b 0a 20 20 20 20 52 4f 4c 4c  ROM t2;.    ROLL
3d70: 42 41 43 4b 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 0a  BACK;.  }.} {}..
3d80: 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  #---------------
3d90: 2d 2d 2d 2d 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 0a 23 20 54 65 73  ----------.# Tes
3dd0: 74 20 63 61 73 65 73 20 66 6b 65 79 32 2d 35 2e  t cases fkey2-5.
3de0: 2a 20 76 65 72 69 66 79 20 74 68 61 74 20 74 68  * verify that th
3df0: 65 20 69 6e 63 72 65 6d 65 6e 74 61 6c 20 62 6c  e incremental bl
3e00: 6f 62 20 41 50 49 20 6d 61 79 20 6e 6f 74 0a 23  ob API may not.#
3e10: 20 77 72 69 74 65 20 74 6f 20 61 20 66 6f 72 65   write to a fore
3e20: 69 67 6e 20 6b 65 79 20 63 6f 6c 75 6d 6e 20 77  ign key column w
3e30: 68 69 6c 65 20 66 6f 72 65 69 67 6e 2d 6b 65 79  hile foreign-key
3e40: 73 20 61 72 65 20 65 6e 61 62 6c 65 64 2e 0a 23  s are enabled..#
3e50: 0a 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73  .drop_all_tables
3e60: 0a 69 66 63 61 70 61 62 6c 65 20 69 6e 63 72 62  .ifcapable incrb
3e70: 6c 6f 62 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20  lob {.  do_test 
3e80: 66 6b 65 79 32 2d 35 2e 31 20 7b 0a 20 20 20 20  fkey2-5.1 {.    
3e90: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 20 20  execsql {.      
3ea0: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28  CREATE TABLE t1(
3eb0: 61 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62  a PRIMARY KEY, b
3ec0: 29 3b 0a 20 20 20 20 20 20 43 52 45 41 54 45 20  );.      CREATE 
3ed0: 54 41 42 4c 45 20 74 32 28 61 20 50 52 49 4d 41  TABLE t2(a PRIMA
3ee0: 52 59 20 4b 45 59 2c 20 62 20 52 45 46 45 52 45  RY KEY, b REFERE
3ef0: 4e 43 45 53 20 74 31 28 61 29 29 3b 0a 20 20 20  NCES t1(a));.   
3f00: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
3f10: 31 20 56 41 4c 55 45 53 28 27 68 65 6c 6c 6f 27  1 VALUES('hello'
3f20: 2c 20 27 77 6f 72 6c 64 27 29 3b 0a 20 20 20 20  , 'world');.    
3f30: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32    INSERT INTO t2
3f40: 20 56 41 4c 55 45 53 28 27 6b 65 79 27 2c 20 27   VALUES('key', '
3f50: 68 65 6c 6c 6f 27 29 3b 0a 20 20 20 20 7d 0a 20  hello');.    }. 
3f60: 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74 65 73 74 20   } {}.  do_test 
3f70: 66 6b 65 79 32 2d 35 2e 32 20 7b 0a 20 20 20 20  fkey2-5.2 {.    
3f80: 73 65 74 20 72 63 20 5b 63 61 74 63 68 20 7b 20  set rc [catch { 
3f90: 73 65 74 20 66 64 20 5b 64 62 20 69 6e 63 72 62  set fd [db incrb
3fa0: 6c 6f 62 20 74 32 20 62 20 31 5d 20 7d 20 6d 73  lob t2 b 1] } ms
3fb0: 67 5d 0a 20 20 20 20 6c 69 73 74 20 24 72 63 20  g].    list $rc 
3fc0: 24 6d 73 67 0a 20 20 7d 20 7b 31 20 7b 63 61 6e  $msg.  } {1 {can
3fd0: 6e 6f 74 20 6f 70 65 6e 20 66 6f 72 65 69 67 6e  not open foreign
3fe0: 20 6b 65 79 20 63 6f 6c 75 6d 6e 20 66 6f 72 20   key column for 
3ff0: 77 72 69 74 69 6e 67 7d 7d 0a 20 20 64 6f 5f 74  writing}}.  do_t
4000: 65 73 74 20 66 6b 65 79 32 2d 35 2e 33 20 7b 0a  est fkey2-5.3 {.
4010: 20 20 20 20 73 65 74 20 72 63 20 5b 63 61 74 63      set rc [catc
4020: 68 20 7b 20 73 65 74 20 66 64 20 5b 64 62 20 69  h { set fd [db i
4030: 6e 63 72 62 6c 6f 62 20 2d 72 65 61 64 6f 6e 6c  ncrblob -readonl
4040: 79 20 74 32 20 62 20 31 5d 20 7d 20 6d 73 67 5d  y t2 b 1] } msg]
4050: 0a 20 20 20 20 63 6c 6f 73 65 20 24 66 64 0a 20  .    close $fd. 
4060: 20 20 20 73 65 74 20 72 63 0a 20 20 7d 20 7b 30     set rc.  } {0
4070: 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79  }.  do_test fkey
4080: 32 2d 35 2e 34 20 7b 0a 20 20 20 20 65 78 65 63  2-5.4 {.    exec
4090: 73 71 6c 20 7b 20 50 52 41 47 4d 41 20 66 6f 72  sql { PRAGMA for
40a0: 65 69 67 6e 5f 6b 65 79 73 20 3d 20 6f 66 66 20  eign_keys = off 
40b0: 7d 0a 20 20 20 20 73 65 74 20 72 63 20 5b 63 61  }.    set rc [ca
40c0: 74 63 68 20 7b 20 73 65 74 20 66 64 20 5b 64 62  tch { set fd [db
40d0: 20 69 6e 63 72 62 6c 6f 62 20 74 32 20 62 20 31   incrblob t2 b 1
40e0: 5d 20 7d 20 6d 73 67 5d 0a 20 20 20 20 63 6c 6f  ] } msg].    clo
40f0: 73 65 20 24 66 64 0a 20 20 20 20 73 65 74 20 72  se $fd.    set r
4100: 63 0a 20 20 7d 20 7b 30 7d 0a 20 20 64 6f 5f 74  c.  } {0}.  do_t
4110: 65 73 74 20 66 6b 65 79 32 2d 35 2e 35 20 7b 0a  est fkey2-5.5 {.
4120: 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20 50 52      execsql { PR
4130: 41 47 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79  AGMA foreign_key
4140: 73 20 3d 20 6f 6e 20 7d 0a 20 20 7d 20 7b 7d 0a  s = on }.  } {}.
4150: 7d 0a 0a 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c  }..drop_all_tabl
4160: 65 73 0a 69 66 63 61 70 61 62 6c 65 20 76 61 63  es.ifcapable vac
4170: 75 75 6d 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20  uum {.  do_test 
4180: 66 6b 65 79 32 2d 36 2e 31 20 7b 0a 20 20 20 20  fkey2-6.1 {.    
4190: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 20 20  execsql {.      
41a0: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28  CREATE TABLE t1(
41b0: 61 20 52 45 46 45 52 45 4e 43 45 53 20 74 32 28  a REFERENCES t2(
41c0: 63 29 2c 20 62 29 3b 0a 20 20 20 20 20 20 43 52  c), b);.      CR
41d0: 45 41 54 45 20 54 41 42 4c 45 20 74 32 28 63 20  EATE TABLE t2(c 
41e0: 55 4e 49 51 55 45 2c 20 62 29 3b 0a 20 20 20 20  UNIQUE, b);.    
41f0: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32    INSERT INTO t2
4200: 20 56 41 4c 55 45 53 28 31 2c 20 32 29 3b 0a 20   VALUES(1, 2);. 
4210: 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f       INSERT INTO
4220: 20 74 31 20 56 41 4c 55 45 53 28 31 2c 20 32 29   t1 VALUES(1, 2)
4230: 3b 0a 20 20 20 20 20 20 56 41 43 55 55 4d 3b 0a  ;.      VACUUM;.
4240: 20 20 20 20 7d 0a 20 20 7d 20 7b 7d 0a 7d 0a 0a      }.  } {}.}..
4250: 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  #---------------
4260: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4270: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4280: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4290: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 54 65 73  ----------.# Tes
42a0: 74 20 74 68 61 74 20 69 74 20 69 73 20 70 6f 73  t that it is pos
42b0: 73 69 62 6c 65 20 74 6f 20 75 73 65 20 61 6e 20  sible to use an 
42c0: 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59 20  INTEGER PRIMARY 
42d0: 4b 45 59 20 61 73 20 74 68 65 20 63 68 69 6c 64  KEY as the child
42e0: 20 6b 65 79 0a 23 20 6f 66 20 61 20 66 6f 72 65   key.# of a fore
42f0: 69 67 6e 20 63 6f 6e 73 74 72 61 69 6e 74 2e 0a  ign constraint..
4300: 23 20 0a 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c  # .drop_all_tabl
4310: 65 73 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  es.do_test fkey2
4320: 2d 37 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c  -7.1 {.  execsql
4330: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41   {.    CREATE TA
4340: 42 4c 45 20 74 31 28 61 20 50 52 49 4d 41 52 59  BLE t1(a PRIMARY
4350: 20 4b 45 59 2c 20 62 29 3b 0a 20 20 20 20 43 52   KEY, b);.    CR
4360: 45 41 54 45 20 54 41 42 4c 45 20 74 32 28 63 20  EATE TABLE t2(c 
4370: 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59 20  INTEGER PRIMARY 
4380: 4b 45 59 20 52 45 46 45 52 45 4e 43 45 53 20 74  KEY REFERENCES t
4390: 31 2c 20 62 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a  1, b);.  }.} {}.
43a0: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 37 2e  do_test fkey2-7.
43b0: 32 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b  2 {.  catchsql {
43c0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 20   INSERT INTO t2 
43d0: 56 41 4c 55 45 53 28 31 2c 20 27 41 27 29 3b 20  VALUES(1, 'A'); 
43e0: 7d 0a 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e 20  }.} {1 {foreign 
43f0: 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e 74 20 66  key constraint f
4400: 61 69 6c 65 64 7d 7d 0a 64 6f 5f 74 65 73 74 20  ailed}}.do_test 
4410: 66 6b 65 79 32 2d 37 2e 33 20 7b 0a 20 20 65 78  fkey2-7.3 {.  ex
4420: 65 63 73 71 6c 20 7b 20 0a 20 20 20 20 49 4e 53  ecsql { .    INS
4430: 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55  ERT INTO t1 VALU
4440: 45 53 28 31 2c 20 32 29 3b 0a 20 20 20 20 49 4e  ES(1, 2);.    IN
4450: 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c  SERT INTO t1 VAL
4460: 55 45 53 28 32 2c 20 33 29 3b 0a 20 20 20 20 49  UES(2, 3);.    I
4470: 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 20 56 41  NSERT INTO t2 VA
4480: 4c 55 45 53 28 31 2c 20 27 41 27 29 3b 0a 20 20  LUES(1, 'A');.  
4490: 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66  }.} {}.do_test f
44a0: 6b 65 79 32 2d 37 2e 34 20 7b 0a 20 20 65 78 65  key2-7.4 {.  exe
44b0: 63 73 71 6c 20 7b 20 55 50 44 41 54 45 20 74 32  csql { UPDATE t2
44c0: 20 53 45 54 20 63 20 3d 20 32 20 7d 0a 7d 20 7b   SET c = 2 }.} {
44d0: 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d  }.do_test fkey2-
44e0: 37 2e 35 20 7b 0a 20 20 63 61 74 63 68 73 71 6c  7.5 {.  catchsql
44f0: 20 7b 20 55 50 44 41 54 45 20 74 32 20 53 45 54   { UPDATE t2 SET
4500: 20 63 20 3d 20 33 20 7d 0a 7d 20 7b 31 20 7b 66   c = 3 }.} {1 {f
4510: 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73 74  oreign key const
4520: 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 64  raint failed}}.d
4530: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 37 2e 36  o_test fkey2-7.6
4540: 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 20   {.  catchsql { 
4550: 44 45 4c 45 54 45 20 46 52 4f 4d 20 74 31 20 57  DELETE FROM t1 W
4560: 48 45 52 45 20 61 20 3d 20 32 20 7d 0a 7d 20 7b  HERE a = 2 }.} {
4570: 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65 79 20 63  1 {foreign key c
4580: 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64  onstraint failed
4590: 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  }}.do_test fkey2
45a0: 2d 37 2e 37 20 7b 0a 20 20 65 78 65 63 73 71 6c  -7.7 {.  execsql
45b0: 20 7b 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 74   { DELETE FROM t
45c0: 31 20 57 48 45 52 45 20 61 20 3d 20 31 20 7d 0a  1 WHERE a = 1 }.
45d0: 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65  } {}.do_test fke
45e0: 79 32 2d 37 2e 38 20 7b 0a 20 20 63 61 74 63 68  y2-7.8 {.  catch
45f0: 73 71 6c 20 7b 20 55 50 44 41 54 45 20 74 31 20  sql { UPDATE t1 
4600: 53 45 54 20 61 20 3d 20 33 20 7d 0a 7d 20 7b 31  SET a = 3 }.} {1
4610: 20 7b 66 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f   {foreign key co
4620: 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d  nstraint failed}
4630: 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d  }.do_test fkey2-
4640: 37 2e 39 20 7b 0a 20 20 63 61 74 63 68 73 71 6c  7.9 {.  catchsql
4650: 20 7b 20 55 50 44 41 54 45 20 74 32 20 53 45 54   { UPDATE t2 SET
4660: 20 72 6f 77 69 64 20 3d 20 33 20 7d 0a 7d 20 7b   rowid = 3 }.} {
4670: 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65 79 20 63  1 {foreign key c
4680: 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64  onstraint failed
4690: 7d 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  }}..#-----------
46a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
46b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
46c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
46d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23  --------------.#
46e0: 20 54 65 73 74 20 74 68 61 74 20 69 74 20 69 73   Test that it is
46f0: 20 6e 6f 74 20 70 6f 73 73 69 62 6c 65 20 74 6f   not possible to
4700: 20 65 6e 61 62 6c 65 2f 64 69 73 61 62 6c 65 20   enable/disable 
4710: 46 4b 20 73 75 70 70 6f 72 74 20 77 68 69 6c 65  FK support while
4720: 20 61 0a 23 20 74 72 61 6e 73 61 63 74 69 6f 6e   a.# transaction
4730: 20 69 73 20 6f 70 65 6e 2e 0a 23 20 0a 64 72 6f   is open..# .dro
4740: 70 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a 70 72 6f  p_all_tables.pro
4750: 63 20 66 6b 65 79 32 2d 38 2d 74 65 73 74 20 7b  c fkey2-8-test {
4760: 74 6e 20 7a 53 71 6c 20 76 61 6c 75 65 7d 20 7b  tn zSql value} {
4770: 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 2d  .  do_test fkey-
4780: 32 2e 38 2e 24 74 6e 2e 31 20 5b 6c 69 73 74 20  2.8.$tn.1 [list 
4790: 65 78 65 63 73 71 6c 20 24 7a 53 71 6c 5d 20 7b  execsql $zSql] {
47a0: 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79  }.  do_test fkey
47b0: 2d 32 2e 38 2e 24 74 6e 2e 32 20 7b 20 65 78 65  -2.8.$tn.2 { exe
47c0: 63 73 71 6c 20 22 50 52 41 47 4d 41 20 66 6f 72  csql "PRAGMA for
47d0: 65 69 67 6e 5f 6b 65 79 73 22 20 7d 20 24 76 61  eign_keys" } $va
47e0: 6c 75 65 0a 7d 0a 66 6b 65 79 32 2d 38 2d 74 65  lue.}.fkey2-8-te
47f0: 73 74 20 20 31 20 7b 20 50 52 41 47 4d 41 20 66  st  1 { PRAGMA f
4800: 6f 72 65 69 67 6e 5f 6b 65 79 73 20 3d 20 30 20  oreign_keys = 0 
4810: 20 20 20 20 7d 20 30 0a 66 6b 65 79 32 2d 38 2d      } 0.fkey2-8-
4820: 74 65 73 74 20 20 32 20 7b 20 50 52 41 47 4d 41  test  2 { PRAGMA
4830: 20 66 6f 72 65 69 67 6e 5f 6b 65 79 73 20 3d 20   foreign_keys = 
4840: 31 20 20 20 20 20 7d 20 31 0a 66 6b 65 79 32 2d  1     } 1.fkey2-
4850: 38 2d 74 65 73 74 20 20 33 20 7b 20 42 45 47 49  8-test  3 { BEGI
4860: 4e 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  N               
4870: 20 20 20 20 20 20 20 20 7d 20 31 0a 66 6b 65 79          } 1.fkey
4880: 32 2d 38 2d 74 65 73 74 20 20 34 20 7b 20 50 52  2-8-test  4 { PR
4890: 41 47 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79  AGMA foreign_key
48a0: 73 20 3d 20 30 20 20 20 20 20 7d 20 31 0a 66 6b  s = 0     } 1.fk
48b0: 65 79 32 2d 38 2d 74 65 73 74 20 20 35 20 7b 20  ey2-8-test  5 { 
48c0: 43 4f 4d 4d 49 54 20 20 20 20 20 20 20 20 20 20  COMMIT          
48d0: 20 20 20 20 20 20 20 20 20 20 20 20 7d 20 31 0a              } 1.
48e0: 66 6b 65 79 32 2d 38 2d 74 65 73 74 20 20 36 20  fkey2-8-test  6 
48f0: 7b 20 50 52 41 47 4d 41 20 66 6f 72 65 69 67 6e  { PRAGMA foreign
4900: 5f 6b 65 79 73 20 3d 20 30 20 20 20 20 20 7d 20  _keys = 0     } 
4910: 30 0a 66 6b 65 79 32 2d 38 2d 74 65 73 74 20 20  0.fkey2-8-test  
4920: 37 20 7b 20 42 45 47 49 4e 20 20 20 20 20 20 20  7 { BEGIN       
4930: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4940: 7d 20 30 0a 66 6b 65 79 32 2d 38 2d 74 65 73 74  } 0.fkey2-8-test
4950: 20 20 38 20 7b 20 50 52 41 47 4d 41 20 66 6f 72    8 { PRAGMA for
4960: 65 69 67 6e 5f 6b 65 79 73 20 3d 20 31 20 20 20  eign_keys = 1   
4970: 20 20 7d 20 30 0a 66 6b 65 79 32 2d 38 2d 74 65    } 0.fkey2-8-te
4980: 73 74 20 20 39 20 7b 20 43 4f 4d 4d 49 54 20 20  st  9 { COMMIT  
4990: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
49a0: 20 20 20 20 7d 20 30 0a 66 6b 65 79 32 2d 38 2d      } 0.fkey2-8-
49b0: 74 65 73 74 20 31 30 20 7b 20 50 52 41 47 4d 41  test 10 { PRAGMA
49c0: 20 66 6f 72 65 69 67 6e 5f 6b 65 79 73 20 3d 20   foreign_keys = 
49d0: 31 20 20 20 20 20 7d 20 31 0a 66 6b 65 79 32 2d  1     } 1.fkey2-
49e0: 38 2d 74 65 73 74 20 31 31 20 7b 20 50 52 41 47  8-test 11 { PRAG
49f0: 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79 73 20  MA foreign_keys 
4a00: 3d 20 6f 66 66 20 20 20 7d 20 30 0a 66 6b 65 79  = off   } 0.fkey
4a10: 32 2d 38 2d 74 65 73 74 20 31 32 20 7b 20 50 52  2-8-test 12 { PR
4a20: 41 47 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79  AGMA foreign_key
4a30: 73 20 3d 20 6f 6e 20 20 20 20 7d 20 31 0a 66 6b  s = on    } 1.fk
4a40: 65 79 32 2d 38 2d 74 65 73 74 20 31 33 20 7b 20  ey2-8-test 13 { 
4a50: 50 52 41 47 4d 41 20 66 6f 72 65 69 67 6e 5f 6b  PRAGMA foreign_k
4a60: 65 79 73 20 3d 20 6e 6f 20 20 20 20 7d 20 30 0a  eys = no    } 0.
4a70: 66 6b 65 79 32 2d 38 2d 74 65 73 74 20 31 34 20  fkey2-8-test 14 
4a80: 7b 20 50 52 41 47 4d 41 20 66 6f 72 65 69 67 6e  { PRAGMA foreign
4a90: 5f 6b 65 79 73 20 3d 20 79 65 73 20 20 20 7d 20  _keys = yes   } 
4aa0: 31 0a 66 6b 65 79 32 2d 38 2d 74 65 73 74 20 31  1.fkey2-8-test 1
4ab0: 35 20 7b 20 50 52 41 47 4d 41 20 66 6f 72 65 69  5 { PRAGMA forei
4ac0: 67 6e 5f 6b 65 79 73 20 3d 20 66 61 6c 73 65 20  gn_keys = false 
4ad0: 7d 20 30 0a 66 6b 65 79 32 2d 38 2d 74 65 73 74  } 0.fkey2-8-test
4ae0: 20 31 36 20 7b 20 50 52 41 47 4d 41 20 66 6f 72   16 { PRAGMA for
4af0: 65 69 67 6e 5f 6b 65 79 73 20 3d 20 74 72 75 65  eign_keys = true
4b00: 20 20 7d 20 31 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d    } 1..#--------
4b10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4b20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4b30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4b40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
4b50: 2d 0a 23 20 54 68 65 20 66 6f 6c 6c 6f 77 69 6e  -.# The followin
4b60: 67 20 74 65 73 74 73 2c 20 66 6b 65 79 32 2d 39  g tests, fkey2-9
4b70: 2e 2a 2c 20 74 65 73 74 20 53 45 54 20 44 45 46  .*, test SET DEF
4b80: 41 55 4c 54 20 61 63 74 69 6f 6e 73 2e 0a 23 0a  AULT actions..#.
4b90: 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a  drop_all_tables.
4ba0: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 39 2e  do_test fkey2-9.
4bb0: 31 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  1.1 {.  execsql 
4bc0: 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42  {.    CREATE TAB
4bd0: 4c 45 20 74 31 28 61 20 49 4e 54 45 47 45 52 20  LE t1(a INTEGER 
4be0: 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62 29 3b  PRIMARY KEY, b);
4bf0: 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  .    CREATE TABL
4c00: 45 20 74 32 28 0a 20 20 20 20 20 20 63 20 49 4e  E t2(.      c IN
4c10: 54 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b 45  TEGER PRIMARY KE
4c20: 59 2c 0a 20 20 20 20 20 20 64 20 49 4e 54 45 47  Y,.      d INTEG
4c30: 45 52 20 44 45 46 41 55 4c 54 20 31 20 52 45 46  ER DEFAULT 1 REF
4c40: 45 52 45 4e 43 45 53 20 74 31 20 4f 4e 20 44 45  ERENCES t1 ON DE
4c50: 4c 45 54 45 20 53 45 54 20 44 45 46 41 55 4c 54  LETE SET DEFAULT
4c60: 0a 20 20 20 20 29 3b 0a 20 20 20 20 44 45 4c 45  .    );.    DELE
4c70: 54 45 20 46 52 4f 4d 20 74 31 3b 0a 20 20 7d 0a  TE FROM t1;.  }.
4c80: 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65  } {}.do_test fke
4c90: 79 32 2d 39 2e 31 2e 32 20 7b 0a 20 20 65 78 65  y2-9.1.2 {.  exe
4ca0: 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52  csql {.    INSER
4cb0: 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53  T INTO t1 VALUES
4cc0: 28 31 2c 20 27 6f 6e 65 27 29 3b 0a 20 20 20 20  (1, 'one');.    
4cd0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56  INSERT INTO t1 V
4ce0: 41 4c 55 45 53 28 32 2c 20 27 74 77 6f 27 29 3b  ALUES(2, 'two');
4cf0: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
4d00: 20 74 32 20 56 41 4c 55 45 53 28 31 2c 20 32 29   t2 VALUES(1, 2)
4d10: 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  ;.    SELECT * F
4d20: 52 4f 4d 20 74 32 3b 0a 20 20 20 20 44 45 4c 45  ROM t2;.    DELE
4d30: 54 45 20 46 52 4f 4d 20 74 31 20 57 48 45 52 45  TE FROM t1 WHERE
4d40: 20 61 20 3d 20 32 3b 0a 20 20 20 20 53 45 4c 45   a = 2;.    SELE
4d50: 43 54 20 2a 20 46 52 4f 4d 20 74 32 3b 0a 20 20  CT * FROM t2;.  
4d60: 7d 0a 7d 20 7b 31 20 32 20 31 20 31 7d 0a 64 6f  }.} {1 2 1 1}.do
4d70: 5f 74 65 73 74 20 66 6b 65 79 32 2d 39 2e 31 2e  _test fkey2-9.1.
4d80: 33 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  3 {.  execsql {.
4d90: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
4da0: 74 31 20 56 41 4c 55 45 53 28 32 2c 20 27 74 77  t1 VALUES(2, 'tw
4db0: 6f 27 29 3b 0a 20 20 20 20 55 50 44 41 54 45 20  o');.    UPDATE 
4dc0: 74 32 20 53 45 54 20 64 20 3d 20 32 3b 0a 20 20  t2 SET d = 2;.  
4dd0: 20 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 74 31    DELETE FROM t1
4de0: 20 57 48 45 52 45 20 61 20 3d 20 31 3b 0a 20 20   WHERE a = 1;.  
4df0: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
4e00: 74 32 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 7d 0a  t2;.  }.} {1 2}.
4e10: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 39 2e  do_test fkey2-9.
4e20: 31 2e 34 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  1.4 {.  execsql 
4e30: 7b 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  { SELECT * FROM 
4e40: 74 31 20 7d 0a 7d 20 7b 32 20 74 77 6f 7d 0a 64  t1 }.} {2 two}.d
4e50: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 39 2e 31  o_test fkey2-9.1
4e60: 2e 35 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20  .5 {.  catchsql 
4e70: 7b 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 74 31  { DELETE FROM t1
4e80: 20 7d 0a 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e   }.} {1 {foreign
4e90: 20 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e 74 20   key constraint 
4ea0: 66 61 69 6c 65 64 7d 7d 0a 0a 64 6f 5f 74 65 73  failed}}..do_tes
4eb0: 74 20 66 6b 65 79 32 2d 39 2e 32 2e 31 20 7b 0a  t fkey2-9.2.1 {.
4ec0: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
4ed0: 43 52 45 41 54 45 20 54 41 42 4c 45 20 70 70 28  CREATE TABLE pp(
4ee0: 61 2c 20 62 2c 20 63 2c 20 50 52 49 4d 41 52 59  a, b, c, PRIMARY
4ef0: 20 4b 45 59 28 62 2c 20 63 29 29 3b 0a 20 20 20   KEY(b, c));.   
4f00: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 63 63   CREATE TABLE cc
4f10: 28 64 20 44 45 46 41 55 4c 54 20 33 2c 20 65 20  (d DEFAULT 3, e 
4f20: 44 45 46 41 55 4c 54 20 31 2c 20 66 20 44 45 46  DEFAULT 1, f DEF
4f30: 41 55 4c 54 20 32 2c 0a 20 20 20 20 20 20 20 20  AULT 2,.        
4f40: 46 4f 52 45 49 47 4e 20 4b 45 59 28 66 2c 20 64  FOREIGN KEY(f, d
4f50: 29 20 52 45 46 45 52 45 4e 43 45 53 20 70 70 20  ) REFERENCES pp 
4f60: 0a 20 20 20 20 20 20 20 20 4f 4e 20 55 50 44 41  .        ON UPDA
4f70: 54 45 20 53 45 54 20 44 45 46 41 55 4c 54 20 0a  TE SET DEFAULT .
4f80: 20 20 20 20 20 20 20 20 4f 4e 20 44 45 4c 45 54          ON DELET
4f90: 45 20 53 45 54 20 4e 55 4c 4c 0a 20 20 20 20 29  E SET NULL.    )
4fa0: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
4fb0: 4f 20 70 70 20 56 41 4c 55 45 53 28 31 2c 20 32  O pp VALUES(1, 2
4fc0: 2c 20 33 29 3b 0a 20 20 20 20 49 4e 53 45 52 54  , 3);.    INSERT
4fd0: 20 49 4e 54 4f 20 70 70 20 56 41 4c 55 45 53 28   INTO pp VALUES(
4fe0: 34 2c 20 35 2c 20 36 29 3b 0a 20 20 20 20 49 4e  4, 5, 6);.    IN
4ff0: 53 45 52 54 20 49 4e 54 4f 20 70 70 20 56 41 4c  SERT INTO pp VAL
5000: 55 45 53 28 37 2c 20 38 2c 20 39 29 3b 0a 20 20  UES(7, 8, 9);.  
5010: 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66  }.} {}.do_test f
5020: 6b 65 79 32 2d 39 2e 32 2e 32 20 7b 0a 20 20 65  key2-9.2.2 {.  e
5030: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53  xecsql {.    INS
5040: 45 52 54 20 49 4e 54 4f 20 63 63 20 56 41 4c 55  ERT INTO cc VALU
5050: 45 53 28 36 2c 20 27 41 27 2c 20 35 29 3b 0a 20  ES(6, 'A', 5);. 
5060: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 63     INSERT INTO c
5070: 63 20 56 41 4c 55 45 53 28 36 2c 20 27 42 27 2c  c VALUES(6, 'B',
5080: 20 35 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20   5);.    INSERT 
5090: 49 4e 54 4f 20 63 63 20 56 41 4c 55 45 53 28 39  INTO cc VALUES(9
50a0: 2c 20 27 41 27 2c 20 38 29 3b 0a 20 20 20 20 49  , 'A', 8);.    I
50b0: 4e 53 45 52 54 20 49 4e 54 4f 20 63 63 20 56 41  NSERT INTO cc VA
50c0: 4c 55 45 53 28 39 2c 20 27 42 27 2c 20 38 29 3b  LUES(9, 'B', 8);
50d0: 0a 20 20 20 20 55 50 44 41 54 45 20 70 70 20 53  .    UPDATE pp S
50e0: 45 54 20 62 20 3d 20 31 20 57 48 45 52 45 20 61  ET b = 1 WHERE a
50f0: 20 3d 20 37 3b 0a 20 20 20 20 53 45 4c 45 43 54   = 7;.    SELECT
5100: 20 2a 20 46 52 4f 4d 20 63 63 3b 0a 20 20 7d 0a   * FROM cc;.  }.
5110: 7d 20 7b 36 20 41 20 35 20 36 20 42 20 35 20 33  } {6 A 5 6 B 5 3
5120: 20 41 20 32 20 33 20 42 20 32 7d 0a 64 6f 5f 74   A 2 3 B 2}.do_t
5130: 65 73 74 20 66 6b 65 79 32 2d 39 2e 32 2e 33 20  est fkey2-9.2.3 
5140: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
5150: 20 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 70 70    DELETE FROM pp
5160: 20 57 48 45 52 45 20 61 20 3d 20 34 3b 0a 20 20   WHERE a = 4;.  
5170: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
5180: 63 63 3b 0a 20 20 7d 0a 7d 20 7b 7b 7d 20 41 20  cc;.  }.} {{} A 
5190: 7b 7d 20 7b 7d 20 42 20 7b 7d 20 33 20 41 20 32  {} {} B {} 3 A 2
51a0: 20 33 20 42 20 32 7d 0a 0a 23 2d 2d 2d 2d 2d 2d   3 B 2}..#------
51b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
51c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
51d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
51e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
51f0: 2d 2d 2d 0a 23 20 54 68 65 20 66 6f 6c 6c 6f 77  ---.# The follow
5200: 69 6e 67 20 74 65 73 74 73 2c 20 66 6b 65 79 32  ing tests, fkey2
5210: 2d 31 30 2e 2a 2c 20 74 65 73 74 20 22 66 6f 72  -10.*, test "for
5220: 65 69 67 6e 20 6b 65 79 20 6d 69 73 6d 61 74 63  eign key mismatc
5230: 68 22 20 61 6e 64 20 0a 23 20 6f 74 68 65 72 20  h" and .# other 
5240: 65 72 72 6f 72 73 2e 0a 23 0a 73 65 74 20 74 6e  errors..#.set tn
5250: 20 30 0a 66 6f 72 65 61 63 68 20 7a 53 71 6c 20   0.foreach zSql 
5260: 5b 6c 69 73 74 20 7b 0a 20 20 43 52 45 41 54 45  [list {.  CREATE
5270: 20 54 41 42 4c 45 20 70 28 61 20 50 52 49 4d 41   TABLE p(a PRIMA
5280: 52 59 20 4b 45 59 2c 20 62 29 3b 0a 20 20 43 52  RY KEY, b);.  CR
5290: 45 41 54 45 20 54 41 42 4c 45 20 63 28 78 20 52  EATE TABLE c(x R
52a0: 45 46 45 52 45 4e 43 45 53 20 70 28 63 29 29 3b  EFERENCES p(c));
52b0: 0a 7d 20 7b 0a 20 20 43 52 45 41 54 45 20 54 41  .} {.  CREATE TA
52c0: 42 4c 45 20 63 28 78 20 52 45 46 45 52 45 4e 43  BLE c(x REFERENC
52d0: 45 53 20 76 28 79 29 29 3b 0a 20 20 43 52 45 41  ES v(y));.  CREA
52e0: 54 45 20 56 49 45 57 20 76 20 41 53 20 53 45 4c  TE VIEW v AS SEL
52f0: 45 43 54 20 78 20 41 53 20 79 20 46 52 4f 4d 20  ECT x AS y FROM 
5300: 63 3b 0a 7d 20 7b 0a 20 20 43 52 45 41 54 45 20  c;.} {.  CREATE 
5310: 54 41 42 4c 45 20 70 28 61 2c 20 62 2c 20 50 52  TABLE p(a, b, PR
5320: 49 4d 41 52 59 20 4b 45 59 28 61 2c 20 62 29 29  IMARY KEY(a, b))
5330: 3b 0a 20 20 43 52 45 41 54 45 20 54 41 42 4c 45  ;.  CREATE TABLE
5340: 20 63 28 78 20 52 45 46 45 52 45 4e 43 45 53 20   c(x REFERENCES 
5350: 70 29 3b 0a 7d 20 7b 0a 20 20 43 52 45 41 54 45  p);.} {.  CREATE
5360: 20 54 41 42 4c 45 20 70 28 61 20 43 4f 4c 4c 41   TABLE p(a COLLA
5370: 54 45 20 62 69 6e 61 72 79 2c 20 62 29 3b 0a 20  TE binary, b);. 
5380: 20 43 52 45 41 54 45 20 55 4e 49 51 55 45 20 49   CREATE UNIQUE I
5390: 4e 44 45 58 20 69 20 4f 4e 20 70 28 61 20 43 4f  NDEX i ON p(a CO
53a0: 4c 4c 41 54 45 20 6e 6f 63 61 73 65 29 3b 0a 20  LLATE nocase);. 
53b0: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 63 28   CREATE TABLE c(
53c0: 78 20 52 45 46 45 52 45 4e 43 45 53 20 70 28 61  x REFERENCES p(a
53d0: 29 29 3b 0a 7d 5d 20 7b 0a 20 20 64 72 6f 70 5f  ));.}] {.  drop_
53e0: 61 6c 6c 5f 74 61 62 6c 65 73 0a 20 20 64 6f 5f  all_tables.  do_
53f0: 74 65 73 74 20 66 6b 65 79 32 2d 31 30 2e 31 2e  test fkey2-10.1.
5400: 5b 69 6e 63 72 20 74 6e 5d 20 7b 0a 20 20 20 20  [incr tn] {.    
5410: 65 78 65 63 73 71 6c 20 24 7a 53 71 6c 0a 20 20  execsql $zSql.  
5420: 20 20 63 61 74 63 68 73 71 6c 20 7b 20 49 4e 53    catchsql { INS
5430: 45 52 54 20 49 4e 54 4f 20 63 20 44 45 46 41 55  ERT INTO c DEFAU
5440: 4c 54 20 56 41 4c 55 45 53 20 7d 0a 20 20 7d 20  LT VALUES }.  } 
5450: 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65 79 20  {1 {foreign key 
5460: 6d 69 73 6d 61 74 63 68 7d 7d 0a 7d 0a 0a 23 20  mismatch}}.}..# 
5470: 22 72 6f 77 69 64 22 20 63 61 6e 6e 6f 74 20 62  "rowid" cannot b
5480: 65 20 75 73 65 64 20 61 73 20 70 61 72 74 20 6f  e used as part o
5490: 66 20 61 20 63 68 69 6c 64 20 6f 72 20 70 61 72  f a child or par
54a0: 65 6e 74 20 6b 65 79 20 64 65 66 69 6e 69 74 69  ent key definiti
54b0: 6f 6e 20 0a 23 20 75 6e 6c 65 73 73 20 69 74 20  on .# unless it 
54c0: 68 61 70 70 65 6e 73 20 74 6f 20 62 65 20 74 68  happens to be th
54d0: 65 20 6e 61 6d 65 20 6f 66 20 61 6e 20 65 78 70  e name of an exp
54e0: 6c 69 63 69 74 6c 79 20 64 65 63 6c 61 72 65 64  licitly declared
54f0: 20 63 6f 6c 75 6d 6e 2e 0a 23 0a 64 6f 5f 74 65   column..#.do_te
5500: 73 74 20 66 6b 65 79 32 2d 31 30 2e 32 2e 31 20  st fkey2-10.2.1 
5510: 7b 0a 20 20 64 72 6f 70 5f 61 6c 6c 5f 74 61 62  {.  drop_all_tab
5520: 6c 65 73 0a 20 20 63 61 74 63 68 73 71 6c 20 7b  les.  catchsql {
5530: 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  .    CREATE TABL
5540: 45 20 74 31 28 61 20 50 52 49 4d 41 52 59 20 4b  E t1(a PRIMARY K
5550: 45 59 2c 20 62 29 3b 0a 20 20 20 20 43 52 45 41  EY, b);.    CREA
5560: 54 45 20 54 41 42 4c 45 20 74 32 28 63 2c 20 64  TE TABLE t2(c, d
5570: 2c 20 46 4f 52 45 49 47 4e 20 4b 45 59 28 72 6f  , FOREIGN KEY(ro
5580: 77 69 64 29 20 52 45 46 45 52 45 4e 43 45 53 20  wid) REFERENCES 
5590: 74 31 28 61 29 29 3b 0a 20 20 7d 0a 7d 20 7b 31  t1(a));.  }.} {1
55a0: 20 7b 75 6e 6b 6e 6f 77 6e 20 63 6f 6c 75 6d 6e   {unknown column
55b0: 20 22 72 6f 77 69 64 22 20 69 6e 20 66 6f 72 65   "rowid" in fore
55c0: 69 67 6e 20 6b 65 79 20 64 65 66 69 6e 69 74 69  ign key definiti
55d0: 6f 6e 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65  on}}.do_test fke
55e0: 79 32 2d 31 30 2e 32 2e 32 20 7b 0a 20 20 64 72  y2-10.2.2 {.  dr
55f0: 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a 20 20  op_all_tables.  
5600: 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 43  catchsql {.    C
5610: 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 61  REATE TABLE t1(a
5620: 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62 29   PRIMARY KEY, b)
5630: 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42  ;.    CREATE TAB
5640: 4c 45 20 74 32 28 72 6f 77 69 64 2c 20 64 2c 20  LE t2(rowid, d, 
5650: 46 4f 52 45 49 47 4e 20 4b 45 59 28 72 6f 77 69  FOREIGN KEY(rowi
5660: 64 29 20 52 45 46 45 52 45 4e 43 45 53 20 74 31  d) REFERENCES t1
5670: 28 61 29 29 3b 0a 20 20 7d 0a 7d 20 7b 30 20 7b  (a));.  }.} {0 {
5680: 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  }}.do_test fkey2
5690: 2d 31 30 2e 32 2e 31 20 7b 0a 20 20 64 72 6f 70  -10.2.1 {.  drop
56a0: 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a 20 20 63 61  _all_tables.  ca
56b0: 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 43 52 45  tchsql {.    CRE
56c0: 41 54 45 20 54 41 42 4c 45 20 74 31 28 61 2c 20  ATE TABLE t1(a, 
56d0: 62 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54  b);.    CREATE T
56e0: 41 42 4c 45 20 74 32 28 63 2c 20 64 2c 20 46 4f  ABLE t2(c, d, FO
56f0: 52 45 49 47 4e 20 4b 45 59 28 63 29 20 52 45 46  REIGN KEY(c) REF
5700: 45 52 45 4e 43 45 53 20 74 31 28 72 6f 77 69 64  ERENCES t1(rowid
5710: 29 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  ));.    INSERT I
5720: 4e 54 4f 20 74 31 28 72 6f 77 69 64 2c 20 61 2c  NTO t1(rowid, a,
5730: 20 62 29 20 56 41 4c 55 45 53 28 31 2c 20 31 2c   b) VALUES(1, 1,
5740: 20 31 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20   1);.    INSERT 
5750: 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28 31  INTO t2 VALUES(1
5760: 2c 20 31 29 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b  , 1);.  }.} {1 {
5770: 66 6f 72 65 69 67 6e 20 6b 65 79 20 6d 69 73 6d  foreign key mism
5780: 61 74 63 68 7d 7d 0a 64 6f 5f 74 65 73 74 20 66  atch}}.do_test f
5790: 6b 65 79 32 2d 31 30 2e 32 2e 32 20 7b 0a 20 20  key2-10.2.2 {.  
57a0: 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a  drop_all_tables.
57b0: 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20    catchsql {.   
57c0: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31   CREATE TABLE t1
57d0: 28 72 6f 77 69 64 20 50 52 49 4d 41 52 59 20 4b  (rowid PRIMARY K
57e0: 45 59 2c 20 62 29 3b 0a 20 20 20 20 43 52 45 41  EY, b);.    CREA
57f0: 54 45 20 54 41 42 4c 45 20 74 32 28 63 2c 20 64  TE TABLE t2(c, d
5800: 2c 20 46 4f 52 45 49 47 4e 20 4b 45 59 28 63 29  , FOREIGN KEY(c)
5810: 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 28 72   REFERENCES t1(r
5820: 6f 77 69 64 29 29 3b 0a 20 20 20 20 49 4e 53 45  owid));.    INSE
5830: 52 54 20 49 4e 54 4f 20 74 31 28 72 6f 77 69 64  RT INTO t1(rowid
5840: 2c 20 62 29 20 56 41 4c 55 45 53 28 31 2c 20 31  , b) VALUES(1, 1
5850: 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  );.    INSERT IN
5860: 54 4f 20 74 32 20 56 41 4c 55 45 53 28 31 2c 20  TO t2 VALUES(1, 
5870: 31 29 3b 0a 20 20 7d 0a 7d 20 7b 30 20 7b 7d 7d  1);.  }.} {0 {}}
5880: 0a 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ...#------------
5890: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
58a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
58b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
58c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20  -------------.# 
58d0: 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 74 65  The following te
58e0: 73 74 73 2c 20 66 6b 65 79 32 2d 31 31 2e 2a 2c  sts, fkey2-11.*,
58f0: 20 74 65 73 74 20 43 41 53 43 41 44 45 20 61 63   test CASCADE ac
5900: 74 69 6f 6e 73 2e 0a 23 0a 64 72 6f 70 5f 61 6c  tions..#.drop_al
5910: 6c 5f 74 61 62 6c 65 73 0a 64 6f 5f 74 65 73 74  l_tables.do_test
5920: 20 66 6b 65 79 32 2d 31 31 2e 31 2e 31 20 7b 0a   fkey2-11.1.1 {.
5930: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
5940: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28  CREATE TABLE t1(
5950: 61 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52  a INTEGER PRIMAR
5960: 59 20 4b 45 59 2c 20 62 29 3b 0a 20 20 20 20 43  Y KEY, b);.    C
5970: 52 45 41 54 45 20 54 41 42 4c 45 20 74 32 28 63  REATE TABLE t2(c
5980: 2c 20 64 2c 20 46 4f 52 45 49 47 4e 20 4b 45 59  , d, FOREIGN KEY
5990: 28 63 29 20 52 45 46 45 52 45 4e 43 45 53 20 74  (c) REFERENCES t
59a0: 31 28 61 29 20 4f 4e 20 55 50 44 41 54 45 20 43  1(a) ON UPDATE C
59b0: 41 53 43 41 44 45 29 3b 0a 0a 20 20 20 20 49 4e  ASCADE);..    IN
59c0: 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c  SERT INTO t1 VAL
59d0: 55 45 53 28 31 30 2c 20 31 30 30 29 3b 0a 20 20  UES(10, 100);.  
59e0: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32    INSERT INTO t2
59f0: 20 56 41 4c 55 45 53 28 31 30 2c 20 31 30 30 29   VALUES(10, 100)
5a00: 3b 0a 20 20 20 20 55 50 44 41 54 45 20 74 31 20  ;.    UPDATE t1 
5a10: 53 45 54 20 61 20 3d 20 31 35 3b 0a 20 20 20 20  SET a = 15;.    
5a20: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 32  SELECT * FROM t2
5a30: 3b 0a 20 20 7d 0a 7d 20 7b 31 35 20 31 30 30 7d  ;.  }.} {15 100}
5a40: 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ..#-------------
5a50: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5a60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5a70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
5a80: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 54  ------------.# T
5a90: 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 74 65 73  he following tes
5aa0: 74 73 2c 20 66 6b 65 79 32 2d 31 32 2e 2a 2c 20  ts, fkey2-12.*, 
5ab0: 74 65 73 74 20 52 45 53 54 52 49 43 54 20 61 63  test RESTRICT ac
5ac0: 74 69 6f 6e 73 2e 0a 23 0a 64 72 6f 70 5f 61 6c  tions..#.drop_al
5ad0: 6c 5f 74 61 62 6c 65 73 0a 64 6f 5f 74 65 73 74  l_tables.do_test
5ae0: 20 66 6b 65 79 32 2d 31 32 2e 31 2e 31 20 7b 0a   fkey2-12.1.1 {.
5af0: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
5b00: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28  CREATE TABLE t1(
5b10: 61 2c 20 62 20 50 52 49 4d 41 52 59 20 4b 45 59  a, b PRIMARY KEY
5b20: 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41  );.    CREATE TA
5b30: 42 4c 45 20 74 32 28 0a 20 20 20 20 20 20 78 20  BLE t2(.      x 
5b40: 52 45 46 45 52 45 4e 43 45 53 20 74 31 20 4f 4e  REFERENCES t1 ON
5b50: 20 55 50 44 41 54 45 20 52 45 53 54 52 49 43 54   UPDATE RESTRICT
5b60: 20 44 45 46 45 52 52 41 42 4c 45 20 49 4e 49 54   DEFERRABLE INIT
5b70: 49 41 4c 4c 59 20 44 45 46 45 52 52 45 44 20 0a  IALLY DEFERRED .
5b80: 20 20 20 20 29 3b 0a 20 20 20 20 49 4e 53 45 52      );.    INSER
5b90: 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53  T INTO t1 VALUES
5ba0: 28 31 2c 20 27 6f 6e 65 27 29 3b 0a 20 20 20 20  (1, 'one');.    
5bb0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56  INSERT INTO t1 V
5bc0: 41 4c 55 45 53 28 32 2c 20 27 74 77 6f 27 29 3b  ALUES(2, 'two');
5bd0: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
5be0: 20 74 31 20 56 41 4c 55 45 53 28 33 2c 20 27 74   t1 VALUES(3, 't
5bf0: 68 72 65 65 27 29 3b 0a 20 20 7d 0a 7d 20 7b 7d  hree');.  }.} {}
5c00: 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31  .do_test fkey2-1
5c10: 32 2e 31 2e 32 20 7b 20 0a 20 20 65 78 65 63 73  2.1.2 { .  execs
5c20: 71 6c 20 22 42 45 47 49 4e 22 0a 20 20 65 78 65  ql "BEGIN".  exe
5c30: 63 73 71 6c 20 22 49 4e 53 45 52 54 20 49 4e 54  csql "INSERT INT
5c40: 4f 20 74 32 20 56 41 4c 55 45 53 28 27 74 77 6f  O t2 VALUES('two
5c50: 27 29 22 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74  ')".} {}.do_test
5c60: 20 66 6b 65 79 32 2d 31 32 2e 31 2e 33 20 7b 20   fkey2-12.1.3 { 
5c70: 0a 20 20 65 78 65 63 73 71 6c 20 22 55 50 44 41  .  execsql "UPDA
5c80: 54 45 20 74 31 20 53 45 54 20 62 20 3d 20 27 66  TE t1 SET b = 'f
5c90: 6f 75 72 27 20 57 48 45 52 45 20 62 20 3d 20 27  our' WHERE b = '
5ca0: 6f 6e 65 27 22 0a 7d 20 7b 7d 0a 64 6f 5f 74 65  one'".} {}.do_te
5cb0: 73 74 20 66 6b 65 79 32 2d 31 32 2e 31 2e 34 20  st fkey2-12.1.4 
5cc0: 7b 20 0a 20 20 63 61 74 63 68 73 71 6c 20 22 55  { .  catchsql "U
5cd0: 50 44 41 54 45 20 74 31 20 53 45 54 20 62 20 3d  PDATE t1 SET b =
5ce0: 20 27 66 69 76 65 27 20 57 48 45 52 45 20 62 20   'five' WHERE b 
5cf0: 3d 20 27 74 77 6f 27 22 0a 7d 20 7b 31 20 7b 66  = 'two'".} {1 {f
5d00: 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73 74  oreign key const
5d10: 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 64  raint failed}}.d
5d20: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 32 2e  o_test fkey2-12.
5d30: 31 2e 35 20 7b 20 0a 20 20 65 78 65 63 73 71 6c  1.5 { .  execsql
5d40: 20 22 44 45 4c 45 54 45 20 46 52 4f 4d 20 74 31   "DELETE FROM t1
5d50: 20 57 48 45 52 45 20 62 20 3d 20 27 74 77 6f 27   WHERE b = 'two'
5d60: 22 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66  ".} {}.do_test f
5d70: 6b 65 79 32 2d 31 32 2e 31 2e 36 20 7b 20 0a 20  key2-12.1.6 { . 
5d80: 20 63 61 74 63 68 73 71 6c 20 22 43 4f 4d 4d 49   catchsql "COMMI
5d90: 54 22 0a 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e  T".} {1 {foreign
5da0: 20 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e 74 20   key constraint 
5db0: 66 61 69 6c 65 64 7d 7d 0a 64 6f 5f 74 65 73 74  failed}}.do_test
5dc0: 20 66 6b 65 79 32 2d 31 32 2e 31 2e 37 20 7b 20   fkey2-12.1.7 { 
5dd0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
5de0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
5df0: 56 41 4c 55 45 53 28 32 2c 20 27 74 77 6f 27 29  VALUES(2, 'two')
5e00: 3b 0a 20 20 20 20 43 4f 4d 4d 49 54 3b 0a 20 20  ;.    COMMIT;.  
5e10: 7d 0a 7d 20 7b 7d 0a 0a 64 72 6f 70 5f 61 6c 6c  }.} {}..drop_all
5e20: 5f 74 61 62 6c 65 73 0a 64 6f 5f 74 65 73 74 20  _tables.do_test 
5e30: 66 6b 65 79 32 2d 31 32 2e 32 2e 31 20 7b 0a 20  fkey2-12.2.1 {. 
5e40: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43   execsql {.    C
5e50: 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 78  REATE TABLE t1(x
5e60: 20 43 4f 4c 4c 41 54 45 20 4e 4f 43 41 53 45 20   COLLATE NOCASE 
5e70: 50 52 49 4d 41 52 59 20 4b 45 59 29 3b 0a 20 20  PRIMARY KEY);.  
5e80: 20 20 43 52 45 41 54 45 20 54 52 49 47 47 45 52    CREATE TRIGGER
5e90: 20 74 74 31 20 41 46 54 45 52 20 44 45 4c 45 54   tt1 AFTER DELET
5ea0: 45 20 4f 4e 20 74 31 20 0a 20 20 20 20 20 20 57  E ON t1 .      W
5eb0: 48 45 4e 20 45 58 49 53 54 53 20 28 20 53 45 4c  HEN EXISTS ( SEL
5ec0: 45 43 54 20 31 20 46 52 4f 4d 20 74 32 20 57 48  ECT 1 FROM t2 WH
5ed0: 45 52 45 20 6f 6c 64 2e 78 20 3d 20 79 20 29 0a  ERE old.x = y ).
5ee0: 20 20 20 20 42 45 47 49 4e 0a 20 20 20 20 20 20      BEGIN.      
5ef0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56  INSERT INTO t1 V
5f00: 41 4c 55 45 53 28 6f 6c 64 2e 78 29 3b 0a 20 20  ALUES(old.x);.  
5f10: 20 20 45 4e 44 3b 0a 20 20 20 20 43 52 45 41 54    END;.    CREAT
5f20: 45 20 54 41 42 4c 45 20 74 32 28 79 20 52 45 46  E TABLE t2(y REF
5f30: 45 52 45 4e 43 45 53 20 74 31 29 3b 0a 20 20 20  ERENCES t1);.   
5f40: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
5f50: 56 41 4c 55 45 53 28 27 41 27 29 3b 0a 20 20 20  VALUES('A');.   
5f60: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
5f70: 56 41 4c 55 45 53 28 27 42 27 29 3b 0a 20 20 20  VALUES('B');.   
5f80: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 20   INSERT INTO t2 
5f90: 56 41 4c 55 45 53 28 27 61 27 29 3b 0a 20 20 20  VALUES('a');.   
5fa0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 20   INSERT INTO t2 
5fb0: 56 41 4c 55 45 53 28 27 62 27 29 3b 0a 0a 20 20  VALUES('b');..  
5fc0: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
5fd0: 74 31 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a  t1;.    SELECT *
5fe0: 20 46 52 4f 4d 20 74 32 3b 0a 20 20 7d 0a 7d 20   FROM t2;.  }.} 
5ff0: 7b 41 20 42 20 61 20 62 7d 0a 64 6f 5f 74 65 73  {A B a b}.do_tes
6000: 74 20 66 6b 65 79 32 2d 31 32 2e 32 2e 32 20 7b  t fkey2-12.2.2 {
6010: 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 44 45 4c  .  execsql { DEL
6020: 45 54 45 20 46 52 4f 4d 20 74 31 20 7d 0a 20 20  ETE FROM t1 }.  
6030: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45  execsql {.    SE
6040: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 31 3b 0a  LECT * FROM t1;.
6050: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
6060: 4d 20 74 32 3b 0a 20 20 7d 0a 7d 20 7b 41 20 42  M t2;.  }.} {A B
6070: 20 61 20 62 7d 0a 64 6f 5f 74 65 73 74 20 66 6b   a b}.do_test fk
6080: 65 79 32 2d 31 32 2e 32 2e 33 20 7b 0a 20 20 65  ey2-12.2.3 {.  e
6090: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f  xecsql {.    DRO
60a0: 50 20 54 41 42 4c 45 20 74 32 3b 0a 20 20 20 20  P TABLE t2;.    
60b0: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 32 28  CREATE TABLE t2(
60c0: 79 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 20  y REFERENCES t1 
60d0: 4f 4e 20 44 45 4c 45 54 45 20 52 45 53 54 52 49  ON DELETE RESTRI
60e0: 43 54 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  CT);.    INSERT 
60f0: 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28 27  INTO t2 VALUES('
6100: 61 27 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  a');.    INSERT 
6110: 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28 27  INTO t2 VALUES('
6120: 62 27 29 3b 0a 20 20 7d 0a 20 20 63 61 74 63 68  b');.  }.  catch
6130: 73 71 6c 20 7b 20 44 45 4c 45 54 45 20 46 52 4f  sql { DELETE FRO
6140: 4d 20 74 31 20 7d 0a 7d 20 7b 31 20 7b 66 6f 72  M t1 }.} {1 {for
6150: 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61  eign key constra
6160: 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 64 6f 5f  int failed}}.do_
6170: 74 65 73 74 20 66 6b 65 79 32 2d 31 32 2e 32 2e  test fkey2-12.2.
6180: 34 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  4 {.  execsql {.
6190: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
61a0: 4d 20 74 31 3b 0a 20 20 20 20 53 45 4c 45 43 54  M t1;.    SELECT
61b0: 20 2a 20 46 52 4f 4d 20 74 32 3b 0a 20 20 7d 0a   * FROM t2;.  }.
61c0: 7d 20 7b 41 20 42 20 61 20 62 7d 0a 0a 64 72 6f  } {A B a b}..dro
61d0: 70 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a 64 6f 5f  p_all_tables.do_
61e0: 74 65 73 74 20 66 6b 65 79 32 2d 31 32 2e 33 2e  test fkey2-12.3.
61f0: 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  1 {.  execsql {.
6200: 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45      CREATE TABLE
6210: 20 75 70 28 0a 20 20 20 20 20 20 63 30 30 2c 20   up(.      c00, 
6220: 63 30 31 2c 20 63 30 32 2c 20 63 30 33 2c 20 63  c01, c02, c03, c
6230: 30 34 2c 20 63 30 35 2c 20 63 30 36 2c 20 63 30  04, c05, c06, c0
6240: 37 2c 20 63 30 38 2c 20 63 30 39 2c 0a 20 20 20  7, c08, c09,.   
6250: 20 20 20 63 31 30 2c 20 63 31 31 2c 20 63 31 32     c10, c11, c12
6260: 2c 20 63 31 33 2c 20 63 31 34 2c 20 63 31 35 2c  , c13, c14, c15,
6270: 20 63 31 36 2c 20 63 31 37 2c 20 63 31 38 2c 20   c16, c17, c18, 
6280: 63 31 39 2c 0a 20 20 20 20 20 20 63 32 30 2c 20  c19,.      c20, 
6290: 63 32 31 2c 20 63 32 32 2c 20 63 32 33 2c 20 63  c21, c22, c23, c
62a0: 32 34 2c 20 63 32 35 2c 20 63 32 36 2c 20 63 32  24, c25, c26, c2
62b0: 37 2c 20 63 32 38 2c 20 63 32 39 2c 0a 20 20 20  7, c28, c29,.   
62c0: 20 20 20 63 33 30 2c 20 63 33 31 2c 20 63 33 32     c30, c31, c32
62d0: 2c 20 63 33 33 2c 20 63 33 34 2c 20 63 33 35 2c  , c33, c34, c35,
62e0: 20 63 33 36 2c 20 63 33 37 2c 20 63 33 38 2c 20   c36, c37, c38, 
62f0: 63 33 39 2c 0a 20 20 20 20 20 20 50 52 49 4d 41  c39,.      PRIMA
6300: 52 59 20 4b 45 59 28 63 33 34 2c 20 63 33 35 29  RY KEY(c34, c35)
6310: 0a 20 20 20 20 29 3b 0a 20 20 20 20 43 52 45 41  .    );.    CREA
6320: 54 45 20 54 41 42 4c 45 20 64 6f 77 6e 28 0a 20  TE TABLE down(. 
6330: 20 20 20 20 20 63 30 30 2c 20 63 30 31 2c 20 63       c00, c01, c
6340: 30 32 2c 20 63 30 33 2c 20 63 30 34 2c 20 63 30  02, c03, c04, c0
6350: 35 2c 20 63 30 36 2c 20 63 30 37 2c 20 63 30 38  5, c06, c07, c08
6360: 2c 20 63 30 39 2c 0a 20 20 20 20 20 20 63 31 30  , c09,.      c10
6370: 2c 20 63 31 31 2c 20 63 31 32 2c 20 63 31 33 2c  , c11, c12, c13,
6380: 20 63 31 34 2c 20 63 31 35 2c 20 63 31 36 2c 20   c14, c15, c16, 
6390: 63 31 37 2c 20 63 31 38 2c 20 63 31 39 2c 0a 20  c17, c18, c19,. 
63a0: 20 20 20 20 20 63 32 30 2c 20 63 32 31 2c 20 63       c20, c21, c
63b0: 32 32 2c 20 63 32 33 2c 20 63 32 34 2c 20 63 32  22, c23, c24, c2
63c0: 35 2c 20 63 32 36 2c 20 63 32 37 2c 20 63 32 38  5, c26, c27, c28
63d0: 2c 20 63 32 39 2c 0a 20 20 20 20 20 20 63 33 30  , c29,.      c30
63e0: 2c 20 63 33 31 2c 20 63 33 32 2c 20 63 33 33 2c  , c31, c32, c33,
63f0: 20 63 33 34 2c 20 63 33 35 2c 20 63 33 36 2c 20   c34, c35, c36, 
6400: 63 33 37 2c 20 63 33 38 2c 20 63 33 39 2c 0a 20  c37, c38, c39,. 
6410: 20 20 20 20 20 46 4f 52 45 49 47 4e 20 4b 45 59       FOREIGN KEY
6420: 28 63 33 39 2c 20 63 33 38 29 20 52 45 46 45 52  (c39, c38) REFER
6430: 45 4e 43 45 53 20 75 70 20 4f 4e 20 55 50 44 41  ENCES up ON UPDA
6440: 54 45 20 43 41 53 43 41 44 45 0a 20 20 20 20 29  TE CASCADE.    )
6450: 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65  ;.  }.} {}.do_te
6460: 73 74 20 66 6b 65 79 32 2d 31 32 2e 33 2e 32 20  st fkey2-12.3.2 
6470: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
6480: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 75 70    INSERT INTO up
6490: 28 63 33 34 2c 20 63 33 35 29 20 56 41 4c 55 45  (c34, c35) VALUE
64a0: 53 28 27 79 65 73 27 2c 20 27 6e 6f 27 29 3b 0a  S('yes', 'no');.
64b0: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
64c0: 64 6f 77 6e 28 63 33 39 2c 20 63 33 38 29 20 56  down(c39, c38) V
64d0: 41 4c 55 45 53 28 27 79 65 73 27 2c 20 27 6e 6f  ALUES('yes', 'no
64e0: 27 29 3b 0a 20 20 20 20 55 50 44 41 54 45 20 75  ');.    UPDATE u
64f0: 70 20 53 45 54 20 63 33 34 20 3d 20 27 70 6f 73  p SET c34 = 'pos
6500: 73 69 62 6c 79 27 3b 0a 20 20 20 20 53 45 4c 45  sibly';.    SELE
6510: 43 54 20 63 33 38 2c 20 63 33 39 20 46 52 4f 4d  CT c38, c39 FROM
6520: 20 64 6f 77 6e 3b 0a 20 20 20 20 44 45 4c 45 54   down;.    DELET
6530: 45 20 46 52 4f 4d 20 64 6f 77 6e 3b 0a 20 20 7d  E FROM down;.  }
6540: 0a 7d 20 7b 6e 6f 20 70 6f 73 73 69 62 6c 79 7d  .} {no possibly}
6550: 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31  .do_test fkey2-1
6560: 32 2e 33 2e 33 20 7b 0a 20 20 63 61 74 63 68 73  2.3.3 {.  catchs
6570: 71 6c 20 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f  ql { INSERT INTO
6580: 20 64 6f 77 6e 28 63 33 39 2c 20 63 33 38 29 20   down(c39, c38) 
6590: 56 41 4c 55 45 53 28 27 79 65 73 27 2c 20 27 6e  VALUES('yes', 'n
65a0: 6f 27 29 20 7d 0a 7d 20 7b 31 20 7b 66 6f 72 65  o') }.} {1 {fore
65b0: 69 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61 69  ign key constrai
65c0: 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 64 6f 5f 74  nt failed}}.do_t
65d0: 65 73 74 20 66 6b 65 79 32 2d 31 32 2e 33 2e 34  est fkey2-12.3.4
65e0: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 0a   {.  execsql { .
65f0: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
6600: 75 70 28 63 33 34 2c 20 63 33 35 29 20 56 41 4c  up(c34, c35) VAL
6610: 55 45 53 28 27 79 65 73 27 2c 20 27 6e 6f 27 29  UES('yes', 'no')
6620: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
6630: 4f 20 64 6f 77 6e 28 63 33 39 2c 20 63 33 38 29  O down(c39, c38)
6640: 20 56 41 4c 55 45 53 28 27 79 65 73 27 2c 20 27   VALUES('yes', '
6650: 6e 6f 27 29 3b 0a 20 20 7d 0a 20 20 63 61 74 63  no');.  }.  catc
6660: 68 73 71 6c 20 7b 20 44 45 4c 45 54 45 20 46 52  hsql { DELETE FR
6670: 4f 4d 20 75 70 20 57 48 45 52 45 20 63 33 34 20  OM up WHERE c34 
6680: 3d 20 27 79 65 73 27 20 7d 0a 7d 20 7b 31 20 7b  = 'yes' }.} {1 {
6690: 66 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73  foreign key cons
66a0: 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a  traint failed}}.
66b0: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 32  do_test fkey2-12
66c0: 2e 33 2e 35 20 7b 0a 20 20 65 78 65 63 73 71 6c  .3.5 {.  execsql
66d0: 20 7b 20 0a 20 20 20 20 44 45 4c 45 54 45 20 46   { .    DELETE F
66e0: 52 4f 4d 20 75 70 20 57 48 45 52 45 20 63 33 34  ROM up WHERE c34
66f0: 20 3d 20 27 70 6f 73 73 69 62 6c 79 27 3b 0a 20   = 'possibly';. 
6700: 20 20 20 53 45 4c 45 43 54 20 63 33 34 2c 20 63     SELECT c34, c
6710: 33 35 20 46 52 4f 4d 20 75 70 3b 0a 20 20 20 20  35 FROM up;.    
6720: 53 45 4c 45 43 54 20 63 33 39 2c 20 63 33 38 20  SELECT c39, c38 
6730: 46 52 4f 4d 20 64 6f 77 6e 3b 0a 20 20 7d 0a 7d  FROM down;.  }.}
6740: 20 7b 79 65 73 20 6e 6f 20 79 65 73 20 6e 6f 7d   {yes no yes no}
6750: 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ..#-------------
6760: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6770: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6780: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6790: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 54  ------------.# T
67a0: 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 74 65 73  he following tes
67b0: 74 73 2c 20 66 6b 65 79 32 2d 31 33 2e 2a 2c 20  ts, fkey2-13.*, 
67c0: 74 65 73 74 20 74 68 61 74 20 46 4b 20 70 72 6f  test that FK pro
67d0: 63 65 73 73 69 6e 67 20 69 73 20 70 65 72 66 6f  cessing is perfo
67e0: 72 6d 65 64 0a 23 20 77 68 65 6e 20 72 6f 77 73  rmed.# when rows
67f0: 20 61 72 65 20 52 45 50 4c 41 43 45 64 2e 0a 23   are REPLACEd..#
6800: 0a 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73  .drop_all_tables
6810: 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31  .do_test fkey2-1
6820: 33 2e 31 2e 31 20 7b 0a 20 20 65 78 65 63 73 71  3.1.1 {.  execsq
6830: 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54  l {.    CREATE T
6840: 41 42 4c 45 20 70 70 28 61 20 55 4e 49 51 55 45  ABLE pp(a UNIQUE
6850: 2c 20 62 2c 20 63 2c 20 50 52 49 4d 41 52 59 20  , b, c, PRIMARY 
6860: 4b 45 59 28 62 2c 20 63 29 29 3b 0a 20 20 20 20  KEY(b, c));.    
6870: 43 52 45 41 54 45 20 54 41 42 4c 45 20 63 63 28  CREATE TABLE cc(
6880: 64 2c 20 65 2c 20 66 20 55 4e 49 51 55 45 2c 20  d, e, f UNIQUE, 
6890: 46 4f 52 45 49 47 4e 20 4b 45 59 28 64 2c 20 65  FOREIGN KEY(d, e
68a0: 29 20 52 45 46 45 52 45 4e 43 45 53 20 70 70 29  ) REFERENCES pp)
68b0: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
68c0: 4f 20 70 70 20 56 41 4c 55 45 53 28 31 2c 20 32  O pp VALUES(1, 2
68d0: 2c 20 33 29 3b 0a 20 20 20 20 49 4e 53 45 52 54  , 3);.    INSERT
68e0: 20 49 4e 54 4f 20 63 63 20 56 41 4c 55 45 53 28   INTO cc VALUES(
68f0: 32 2c 20 33 2c 20 31 29 3b 0a 20 20 7d 0a 7d 20  2, 3, 1);.  }.} 
6900: 7b 7d 0a 66 6f 72 65 61 63 68 20 7b 74 6e 20 73  {}.foreach {tn s
6910: 74 6d 74 7d 20 7b 0a 20 20 31 20 20 20 22 52 45  tmt} {.  1   "RE
6920: 50 4c 41 43 45 20 49 4e 54 4f 20 70 70 20 56 41  PLACE INTO pp VA
6930: 4c 55 45 53 28 31 2c 20 34 2c 20 35 29 22 0a 20  LUES(1, 4, 5)". 
6940: 20 32 20 20 20 22 52 45 50 4c 41 43 45 20 49 4e   2   "REPLACE IN
6950: 54 4f 20 70 70 28 72 6f 77 69 64 2c 20 61 2c 20  TO pp(rowid, a, 
6960: 62 2c 20 63 29 20 56 41 4c 55 45 53 28 31 2c 20  b, c) VALUES(1, 
6970: 32 2c 20 33 2c 20 34 29 22 0a 7d 20 7b 0a 20 20  2, 3, 4)".} {.  
6980: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 33  do_test fkey2-13
6990: 2e 31 2e 24 74 6e 2e 31 20 7b 0a 20 20 20 20 63  .1.$tn.1 {.    c
69a0: 61 74 63 68 73 71 6c 20 24 73 74 6d 74 0a 20 20  atchsql $stmt.  
69b0: 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65  } {1 {foreign ke
69c0: 79 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69  y constraint fai
69d0: 6c 65 64 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20  led}}.  do_test 
69e0: 66 6b 65 79 32 2d 31 33 2e 31 2e 24 74 6e 2e 32  fkey2-13.1.$tn.2
69f0: 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b   {.    execsql {
6a00: 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 2a 20  .      SELECT * 
6a10: 46 52 4f 4d 20 70 70 3b 0a 20 20 20 20 20 20 53  FROM pp;.      S
6a20: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 63 63 3b  ELECT * FROM cc;
6a30: 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 31 20 32 20  .    }.  } {1 2 
6a40: 33 20 32 20 33 20 31 7d 0a 20 20 64 6f 5f 74 65  3 2 3 1}.  do_te
6a50: 73 74 20 66 6b 65 79 32 2d 31 33 2e 31 2e 24 74  st fkey2-13.1.$t
6a60: 6e 2e 33 20 7b 0a 20 20 20 20 65 78 65 63 73 71  n.3 {.    execsq
6a70: 6c 20 42 45 47 49 4e 3b 0a 20 20 20 20 63 61 74  l BEGIN;.    cat
6a80: 63 68 73 71 6c 20 24 73 74 6d 74 0a 20 20 7d 20  chsql $stmt.  } 
6a90: 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65 79 20  {1 {foreign key 
6aa0: 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65  constraint faile
6ab0: 64 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b  d}}.  do_test fk
6ac0: 65 79 32 2d 31 33 2e 31 2e 24 74 6e 2e 34 20 7b  ey2-13.1.$tn.4 {
6ad0: 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20  .    execsql {. 
6ae0: 20 20 20 20 20 43 4f 4d 4d 49 54 3b 0a 20 20 20       COMMIT;.   
6af0: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
6b00: 20 70 70 3b 0a 20 20 20 20 20 20 53 45 4c 45 43   pp;.      SELEC
6b10: 54 20 2a 20 46 52 4f 4d 20 63 63 3b 0a 20 20 20  T * FROM cc;.   
6b20: 20 7d 0a 20 20 7d 20 7b 31 20 32 20 33 20 32 20   }.  } {1 2 3 2 
6b30: 33 20 31 7d 0a 7d 0a 64 6f 5f 74 65 73 74 20 66  3 1}.}.do_test f
6b40: 6b 65 79 32 2d 31 33 2e 31 2e 33 20 7b 0a 20 20  key2-13.1.3 {.  
6b50: 65 78 65 63 73 71 6c 20 7b 20 0a 20 20 20 20 52  execsql { .    R
6b60: 45 50 4c 41 43 45 20 49 4e 54 4f 20 70 70 28 72  EPLACE INTO pp(r
6b70: 6f 77 69 64 2c 20 61 2c 20 62 2c 20 63 29 20 56  owid, a, b, c) V
6b80: 41 4c 55 45 53 28 31 2c 20 32 2c 20 32 2c 20 33  ALUES(1, 2, 2, 3
6b90: 29 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 72 6f  );.    SELECT ro
6ba0: 77 69 64 2c 20 2a 20 46 52 4f 4d 20 70 70 3b 0a  wid, * FROM pp;.
6bb0: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
6bc0: 4d 20 63 63 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32  M cc;.  }.} {1 2
6bd0: 20 32 20 33 20 32 20 33 20 31 7d 0a 64 6f 5f 74   2 3 2 3 1}.do_t
6be0: 65 73 74 20 66 6b 65 79 32 2d 31 33 2e 31 2e 34  est fkey2-13.1.4
6bf0: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 0a   {.  execsql { .
6c00: 20 20 20 20 52 45 50 4c 41 43 45 20 49 4e 54 4f      REPLACE INTO
6c10: 20 70 70 28 72 6f 77 69 64 2c 20 61 2c 20 62 2c   pp(rowid, a, b,
6c20: 20 63 29 20 56 41 4c 55 45 53 28 32 2c 20 32 2c   c) VALUES(2, 2,
6c30: 20 32 2c 20 33 29 3b 0a 20 20 20 20 53 45 4c 45   2, 3);.    SELE
6c40: 43 54 20 72 6f 77 69 64 2c 20 2a 20 46 52 4f 4d  CT rowid, * FROM
6c50: 20 70 70 3b 0a 20 20 20 20 53 45 4c 45 43 54 20   pp;.    SELECT 
6c60: 2a 20 46 52 4f 4d 20 63 63 3b 0a 20 20 7d 0a 7d  * FROM cc;.  }.}
6c70: 20 7b 32 20 32 20 32 20 33 20 32 20 33 20 31 7d   {2 2 2 3 2 3 1}
6c80: 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ..#-------------
6c90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6ca0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6cb0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
6cc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 54  ------------.# T
6cd0: 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 74 65 73  he following tes
6ce0: 74 73 2c 20 66 6b 65 79 32 2d 31 34 2e 2a 2c 20  ts, fkey2-14.*, 
6cf0: 74 65 73 74 20 74 68 61 74 20 74 68 65 20 22 44  test that the "D
6d00: 52 4f 50 20 54 41 42 4c 45 22 20 61 6e 64 20 22  ROP TABLE" and "
6d10: 41 4c 54 45 52 0a 23 20 54 41 42 4c 45 22 20 63  ALTER.# TABLE" c
6d20: 6f 6d 6d 61 6e 64 73 20 77 6f 72 6b 20 61 73 20  ommands work as 
6d30: 65 78 70 65 63 74 65 64 20 77 72 74 20 66 6f 72  expected wrt for
6d40: 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61  eign key constra
6d50: 69 6e 74 73 2e 0a 23 0a 23 20 66 6b 65 79 32 2d  ints..#.# fkey2-
6d60: 31 34 2e 31 2a 3a 20 41 4c 54 45 52 20 54 41 42  14.1*: ALTER TAB
6d70: 4c 45 20 41 44 44 20 43 4f 4c 55 4d 4e 0a 23 20  LE ADD COLUMN.# 
6d80: 66 6b 65 79 32 2d 31 34 2e 32 2a 3a 20 41 4c 54  fkey2-14.2*: ALT
6d90: 45 52 20 54 41 42 4c 45 20 52 45 4e 41 4d 45 20  ER TABLE RENAME 
6da0: 54 41 42 4c 45 0a 23 20 66 6b 65 79 32 2d 31 34  TABLE.# fkey2-14
6db0: 2e 33 2a 3a 20 44 52 4f 50 20 54 41 42 4c 45 0a  .3*: DROP TABLE.
6dc0: 23 0a 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65  #.drop_all_table
6dd0: 73 0a 69 66 63 61 70 61 62 6c 65 20 61 6c 74 65  s.ifcapable alte
6de0: 72 74 61 62 6c 65 20 7b 0a 20 20 64 6f 5f 74 65  rtable {.  do_te
6df0: 73 74 20 66 6b 65 79 32 2d 31 34 2e 31 2e 31 20  st fkey2-14.1.1 
6e00: 7b 0a 20 20 20 20 23 20 41 64 64 69 6e 67 20 61  {.    # Adding a
6e10: 20 63 6f 6c 75 6d 6e 20 77 69 74 68 20 61 20 52   column with a R
6e20: 45 46 45 52 45 4e 43 45 53 20 63 6c 61 75 73 65  EFERENCES clause
6e30: 20 69 73 20 6e 6f 74 20 73 75 70 70 6f 72 74 65   is not supporte
6e40: 64 2e 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b  d..    execsql {
6e50: 20 0a 20 20 20 20 20 20 43 52 45 41 54 45 20 54   .      CREATE T
6e60: 41 42 4c 45 20 74 31 28 61 20 50 52 49 4d 41 52  ABLE t1(a PRIMAR
6e70: 59 20 4b 45 59 29 3b 0a 20 20 20 20 20 20 43 52  Y KEY);.      CR
6e80: 45 41 54 45 20 54 41 42 4c 45 20 74 32 28 61 2c  EATE TABLE t2(a,
6e90: 20 62 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63   b);.    }.    c
6ea0: 61 74 63 68 73 71 6c 20 7b 20 41 4c 54 45 52 20  atchsql { ALTER 
6eb0: 54 41 42 4c 45 20 74 32 20 41 44 44 20 43 4f 4c  TABLE t2 ADD COL
6ec0: 55 4d 4e 20 63 20 52 45 46 45 52 45 4e 43 45 53  UMN c REFERENCES
6ed0: 20 74 31 20 7d 0a 20 20 7d 20 7b 30 20 7b 7d 7d   t1 }.  } {0 {}}
6ee0: 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  .  do_test fkey2
6ef0: 2d 31 34 2e 31 2e 32 20 7b 0a 20 20 20 20 63 61  -14.1.2 {.    ca
6f00: 74 63 68 73 71 6c 20 7b 20 41 4c 54 45 52 20 54  tchsql { ALTER T
6f10: 41 42 4c 45 20 74 32 20 41 44 44 20 43 4f 4c 55  ABLE t2 ADD COLU
6f20: 4d 4e 20 64 20 44 45 46 41 55 4c 54 20 4e 55 4c  MN d DEFAULT NUL
6f30: 4c 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 20  L REFERENCES t1 
6f40: 7d 0a 20 20 7d 20 7b 30 20 7b 7d 7d 0a 20 20 64  }.  } {0 {}}.  d
6f50: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 34 2e  o_test fkey2-14.
6f60: 31 2e 33 20 7b 0a 20 20 20 20 63 61 74 63 68 73  1.3 {.    catchs
6f70: 71 6c 20 7b 20 41 4c 54 45 52 20 54 41 42 4c 45  ql { ALTER TABLE
6f80: 20 74 32 20 41 44 44 20 43 4f 4c 55 4d 4e 20 65   t2 ADD COLUMN e
6f90: 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 20 44   REFERENCES t1 D
6fa0: 45 46 41 55 4c 54 20 4e 55 4c 4c 7d 0a 20 20 7d  EFAULT NULL}.  }
6fb0: 20 7b 30 20 7b 7d 7d 0a 20 20 64 6f 5f 74 65 73   {0 {}}.  do_tes
6fc0: 74 20 66 6b 65 79 32 2d 31 34 2e 31 2e 34 20 7b  t fkey2-14.1.4 {
6fd0: 0a 20 20 20 20 63 61 74 63 68 73 71 6c 20 7b 20  .    catchsql { 
6fe0: 41 4c 54 45 52 20 54 41 42 4c 45 20 74 32 20 41  ALTER TABLE t2 A
6ff0: 44 44 20 43 4f 4c 55 4d 4e 20 66 20 52 45 46 45  DD COLUMN f REFE
7000: 52 45 4e 43 45 53 20 74 31 20 44 45 46 41 55 4c  RENCES t1 DEFAUL
7010: 54 20 27 74 65 78 74 27 7d 0a 20 20 7d 20 7b 31  T 'text'}.  } {1
7020: 20 7b 43 61 6e 6e 6f 74 20 61 64 64 20 61 20 52   {Cannot add a R
7030: 45 46 45 52 45 4e 43 45 53 20 63 6f 6c 75 6d 6e  EFERENCES column
7040: 20 77 69 74 68 20 6e 6f 6e 2d 4e 55 4c 4c 20 64   with non-NULL d
7050: 65 66 61 75 6c 74 20 76 61 6c 75 65 7d 7d 0a 20  efault value}}. 
7060: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31   do_test fkey2-1
7070: 34 2e 31 2e 35 20 7b 0a 20 20 20 20 63 61 74 63  4.1.5 {.    catc
7080: 68 73 71 6c 20 7b 20 41 4c 54 45 52 20 54 41 42  hsql { ALTER TAB
7090: 4c 45 20 74 32 20 41 44 44 20 43 4f 4c 55 4d 4e  LE t2 ADD COLUMN
70a0: 20 67 20 44 45 46 41 55 4c 54 20 43 55 52 52 45   g DEFAULT CURRE
70b0: 4e 54 5f 54 49 4d 45 20 52 45 46 45 52 45 4e 43  NT_TIME REFERENC
70c0: 45 53 20 74 31 20 7d 0a 20 20 7d 20 7b 31 20 7b  ES t1 }.  } {1 {
70d0: 43 61 6e 6e 6f 74 20 61 64 64 20 61 20 52 45 46  Cannot add a REF
70e0: 45 52 45 4e 43 45 53 20 63 6f 6c 75 6d 6e 20 77  ERENCES column w
70f0: 69 74 68 20 6e 6f 6e 2d 4e 55 4c 4c 20 64 65 66  ith non-NULL def
7100: 61 75 6c 74 20 76 61 6c 75 65 7d 7d 0a 20 20 64  ault value}}.  d
7110: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 34 2e  o_test fkey2-14.
7120: 31 2e 36 20 7b 0a 20 20 20 20 65 78 65 63 73 71  1.6 {.    execsq
7130: 6c 20 7b 20 0a 20 20 20 20 20 20 50 52 41 47 4d  l { .      PRAGM
7140: 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79 73 20 3d  A foreign_keys =
7150: 20 6f 66 66 3b 0a 20 20 20 20 20 20 41 4c 54 45   off;.      ALTE
7160: 52 20 54 41 42 4c 45 20 74 32 20 41 44 44 20 43  R TABLE t2 ADD C
7170: 4f 4c 55 4d 4e 20 68 20 44 45 46 41 55 4c 54 20  OLUMN h DEFAULT 
7180: 27 74 65 78 74 27 20 52 45 46 45 52 45 4e 43 45  'text' REFERENCE
7190: 53 20 74 31 3b 0a 20 20 20 20 20 20 50 52 41 47  S t1;.      PRAG
71a0: 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79 73 20  MA foreign_keys 
71b0: 3d 20 6f 6e 3b 0a 20 20 20 20 20 20 53 45 4c 45  = on;.      SELE
71c0: 43 54 20 73 71 6c 20 46 52 4f 4d 20 73 71 6c 69  CT sql FROM sqli
71d0: 74 65 5f 6d 61 73 74 65 72 20 57 48 45 52 45 20  te_master WHERE 
71e0: 6e 61 6d 65 3d 27 74 32 27 3b 0a 20 20 20 20 7d  name='t2';.    }
71f0: 0a 20 20 7d 20 7b 7b 43 52 45 41 54 45 20 54 41  .  } {{CREATE TA
7200: 42 4c 45 20 74 32 28 61 2c 20 62 2c 20 63 20 52  BLE t2(a, b, c R
7210: 45 46 45 52 45 4e 43 45 53 20 74 31 2c 20 64 20  EFERENCES t1, d 
7220: 44 45 46 41 55 4c 54 20 4e 55 4c 4c 20 52 45 46  DEFAULT NULL REF
7230: 45 52 45 4e 43 45 53 20 74 31 2c 20 65 20 52 45  ERENCES t1, e RE
7240: 46 45 52 45 4e 43 45 53 20 74 31 20 44 45 46 41  FERENCES t1 DEFA
7250: 55 4c 54 20 4e 55 4c 4c 2c 20 68 20 44 45 46 41  ULT NULL, h DEFA
7260: 55 4c 54 20 27 74 65 78 74 27 20 52 45 46 45 52  ULT 'text' REFER
7270: 45 4e 43 45 53 20 74 31 29 7d 7d 0a 20 20 0a 20  ENCES t1)}}.  . 
7280: 20 0a 20 20 23 20 54 65 73 74 20 74 68 65 20 73   .  # Test the s
7290: 71 6c 69 74 65 5f 72 65 6e 61 6d 65 5f 70 61 72  qlite_rename_par
72a0: 65 6e 74 28 29 20 66 75 6e 63 74 69 6f 6e 20 64  ent() function d
72b0: 69 72 65 63 74 6c 79 2e 0a 20 20 23 0a 20 20 70  irectly..  #.  p
72c0: 72 6f 63 20 74 65 73 74 5f 72 65 6e 61 6d 65 5f  roc test_rename_
72d0: 70 61 72 65 6e 74 20 7b 7a 43 72 65 61 74 65 20  parent {zCreate 
72e0: 7a 4f 6c 64 20 7a 4e 65 77 7d 20 7b 0a 20 20 20  zOld zNew} {.   
72f0: 20 64 62 20 65 76 61 6c 20 7b 53 45 4c 45 43 54   db eval {SELECT
7300: 20 73 71 6c 69 74 65 5f 72 65 6e 61 6d 65 5f 70   sqlite_rename_p
7310: 61 72 65 6e 74 28 24 7a 43 72 65 61 74 65 2c 20  arent($zCreate, 
7320: 24 7a 4f 6c 64 2c 20 24 7a 4e 65 77 29 7d 0a 20  $zOld, $zNew)}. 
7330: 20 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65   }.  do_test fke
7340: 79 32 2d 31 34 2e 32 2e 31 2e 31 20 7b 0a 20 20  y2-14.2.1.1 {.  
7350: 20 20 74 65 73 74 5f 72 65 6e 61 6d 65 5f 70 61    test_rename_pa
7360: 72 65 6e 74 20 7b 43 52 45 41 54 45 20 54 41 42  rent {CREATE TAB
7370: 4c 45 20 74 31 28 61 20 52 45 46 45 52 45 4e 43  LE t1(a REFERENC
7380: 45 53 20 74 32 29 7d 20 74 32 20 74 33 0a 20 20  ES t2)} t2 t3.  
7390: 7d 20 7b 7b 43 52 45 41 54 45 20 54 41 42 4c 45  } {{CREATE TABLE
73a0: 20 74 31 28 61 20 52 45 46 45 52 45 4e 43 45 53   t1(a REFERENCES
73b0: 20 22 74 33 22 29 7d 7d 0a 20 20 64 6f 5f 74 65   "t3")}}.  do_te
73c0: 73 74 20 66 6b 65 79 32 2d 31 34 2e 32 2e 31 2e  st fkey2-14.2.1.
73d0: 32 20 7b 0a 20 20 20 20 74 65 73 74 5f 72 65 6e  2 {.    test_ren
73e0: 61 6d 65 5f 70 61 72 65 6e 74 20 7b 43 52 45 41  ame_parent {CREA
73f0: 54 45 20 54 41 42 4c 45 20 74 31 28 61 20 52 45  TE TABLE t1(a RE
7400: 46 45 52 45 4e 43 45 53 20 74 32 29 7d 20 74 34  FERENCES t2)} t4
7410: 20 74 33 0a 20 20 7d 20 7b 7b 43 52 45 41 54 45   t3.  } {{CREATE
7420: 20 54 41 42 4c 45 20 74 31 28 61 20 52 45 46 45   TABLE t1(a REFE
7430: 52 45 4e 43 45 53 20 74 32 29 7d 7d 0a 20 20 64  RENCES t2)}}.  d
7440: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 34 2e  o_test fkey2-14.
7450: 32 2e 31 2e 33 20 7b 0a 20 20 20 20 74 65 73 74  2.1.3 {.    test
7460: 5f 72 65 6e 61 6d 65 5f 70 61 72 65 6e 74 20 7b  _rename_parent {
7470: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28  CREATE TABLE t1(
7480: 61 20 52 45 46 45 52 45 4e 43 45 53 20 22 74 32  a REFERENCES "t2
7490: 22 29 7d 20 74 32 20 74 33 0a 20 20 7d 20 7b 7b  ")} t2 t3.  } {{
74a0: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28  CREATE TABLE t1(
74b0: 61 20 52 45 46 45 52 45 4e 43 45 53 20 22 74 33  a REFERENCES "t3
74c0: 22 29 7d 7d 0a 20 20 0a 20 20 23 20 54 65 73 74  ")}}.  .  # Test
74d0: 20 41 4c 54 45 52 20 54 41 42 4c 45 20 52 45 4e   ALTER TABLE REN
74e0: 41 4d 45 20 54 41 42 4c 45 20 61 20 62 69 74 2e  AME TABLE a bit.
74f0: 0a 20 20 23 0a 20 20 64 6f 5f 74 65 73 74 20 66  .  #.  do_test f
7500: 6b 65 79 32 2d 31 34 2e 32 2e 32 2e 31 20 7b 0a  key2-14.2.2.1 {.
7510: 20 20 20 20 64 72 6f 70 5f 61 6c 6c 5f 74 61 62      drop_all_tab
7520: 6c 65 73 0a 20 20 20 20 65 78 65 63 73 71 6c 20  les.    execsql 
7530: 7b 0a 20 20 20 20 20 20 43 52 45 41 54 45 20 54  {.      CREATE T
7540: 41 42 4c 45 20 74 31 28 61 20 50 52 49 4d 41 52  ABLE t1(a PRIMAR
7550: 59 20 4b 45 59 2c 20 62 20 52 45 46 45 52 45 4e  Y KEY, b REFEREN
7560: 43 45 53 20 74 31 29 3b 0a 20 20 20 20 20 20 43  CES t1);.      C
7570: 52 45 41 54 45 20 54 41 42 4c 45 20 74 32 28 61  REATE TABLE t2(a
7580: 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62 20   PRIMARY KEY, b 
7590: 52 45 46 45 52 45 4e 43 45 53 20 74 31 2c 20 63  REFERENCES t1, c
75a0: 20 52 45 46 45 52 45 4e 43 45 53 20 74 32 29 3b   REFERENCES t2);
75b0: 0a 20 20 20 20 20 20 43 52 45 41 54 45 20 54 41  .      CREATE TA
75c0: 42 4c 45 20 74 33 28 61 20 52 45 46 45 52 45 4e  BLE t3(a REFEREN
75d0: 43 45 53 20 74 31 2c 20 62 20 52 45 46 45 52 45  CES t1, b REFERE
75e0: 4e 43 45 53 20 74 32 2c 20 63 20 52 45 46 45 52  NCES t2, c REFER
75f0: 45 4e 43 45 53 20 74 31 29 3b 0a 20 20 20 20 7d  ENCES t1);.    }
7600: 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20 53  .    execsql { S
7610: 45 4c 45 43 54 20 73 71 6c 20 46 52 4f 4d 20 73  ELECT sql FROM s
7620: 71 6c 69 74 65 5f 6d 61 73 74 65 72 20 57 48 45  qlite_master WHE
7630: 52 45 20 74 79 70 65 20 3d 20 27 74 61 62 6c 65  RE type = 'table
7640: 27 7d 0a 20 20 7d 20 5b 6c 69 73 74 20 5c 0a 20  '}.  } [list \. 
7650: 20 20 20 7b 43 52 45 41 54 45 20 54 41 42 4c 45     {CREATE TABLE
7660: 20 74 31 28 61 20 50 52 49 4d 41 52 59 20 4b 45   t1(a PRIMARY KE
7670: 59 2c 20 62 20 52 45 46 45 52 45 4e 43 45 53 20  Y, b REFERENCES 
7680: 74 31 29 7d 20 20 20 20 20 20 20 20 20 20 20 20  t1)}            
7690: 20 20 20 20 20 20 20 20 20 5c 0a 20 20 20 20 7b           \.    {
76a0: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 32 28  CREATE TABLE t2(
76b0: 61 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62  a PRIMARY KEY, b
76c0: 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 2c 20   REFERENCES t1, 
76d0: 63 20 52 45 46 45 52 45 4e 43 45 53 20 74 32 29  c REFERENCES t2)
76e0: 7d 20 20 20 20 5c 0a 20 20 20 20 7b 43 52 45 41  }    \.    {CREA
76f0: 54 45 20 54 41 42 4c 45 20 74 33 28 61 20 52 45  TE TABLE t3(a RE
7700: 46 45 52 45 4e 43 45 53 20 74 31 2c 20 62 20 52  FERENCES t1, b R
7710: 45 46 45 52 45 4e 43 45 53 20 74 32 2c 20 63 20  EFERENCES t2, c 
7720: 52 45 46 45 52 45 4e 43 45 53 20 74 31 29 7d 20  REFERENCES t1)} 
7730: 20 5c 0a 20 20 5d 0a 20 20 64 6f 5f 74 65 73 74   \.  ].  do_test
7740: 20 66 6b 65 79 32 2d 31 34 2e 32 2e 32 2e 32 20   fkey2-14.2.2.2 
7750: 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20  {.    execsql { 
7760: 41 4c 54 45 52 20 54 41 42 4c 45 20 74 31 20 52  ALTER TABLE t1 R
7770: 45 4e 41 4d 45 20 54 4f 20 74 34 20 7d 0a 20 20  ENAME TO t4 }.  
7780: 20 20 65 78 65 63 73 71 6c 20 7b 20 53 45 4c 45    execsql { SELE
7790: 43 54 20 73 71 6c 20 46 52 4f 4d 20 73 71 6c 69  CT sql FROM sqli
77a0: 74 65 5f 6d 61 73 74 65 72 20 57 48 45 52 45 20  te_master WHERE 
77b0: 74 79 70 65 20 3d 20 27 74 61 62 6c 65 27 7d 0a  type = 'table'}.
77c0: 20 20 7d 20 5b 6c 69 73 74 20 5c 0a 20 20 20 20    } [list \.    
77d0: 7b 43 52 45 41 54 45 20 54 41 42 4c 45 20 22 74  {CREATE TABLE "t
77e0: 34 22 28 61 20 50 52 49 4d 41 52 59 20 4b 45 59  4"(a PRIMARY KEY
77f0: 2c 20 62 20 52 45 46 45 52 45 4e 43 45 53 20 22  , b REFERENCES "
7800: 74 34 22 29 7d 20 20 20 20 20 20 20 20 20 20 20  t4")}           
7810: 20 20 20 20 20 20 20 20 20 5c 0a 20 20 20 20 7b           \.    {
7820: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 32 28  CREATE TABLE t2(
7830: 61 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62  a PRIMARY KEY, b
7840: 20 52 45 46 45 52 45 4e 43 45 53 20 22 74 34 22   REFERENCES "t4"
7850: 2c 20 63 20 52 45 46 45 52 45 4e 43 45 53 20 74  , c REFERENCES t
7860: 32 29 7d 20 20 20 20 20 5c 0a 20 20 20 20 7b 43  2)}     \.    {C
7870: 52 45 41 54 45 20 54 41 42 4c 45 20 74 33 28 61  REATE TABLE t3(a
7880: 20 52 45 46 45 52 45 4e 43 45 53 20 22 74 34 22   REFERENCES "t4"
7890: 2c 20 62 20 52 45 46 45 52 45 4e 43 45 53 20 74  , b REFERENCES t
78a0: 32 2c 20 63 20 52 45 46 45 52 45 4e 43 45 53 20  2, c REFERENCES 
78b0: 22 74 34 22 29 7d 20 5c 0a 20 20 5d 0a 20 20 64  "t4")} \.  ].  d
78c0: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 34 2e  o_test fkey2-14.
78d0: 32 2e 32 2e 33 20 7b 0a 20 20 20 20 63 61 74 63  2.2.3 {.    catc
78e0: 68 73 71 6c 20 7b 20 49 4e 53 45 52 54 20 49 4e  hsql { INSERT IN
78f0: 54 4f 20 74 33 20 56 41 4c 55 45 53 28 31 2c 20  TO t3 VALUES(1, 
7900: 32 2c 20 33 29 20 7d 0a 20 20 7d 20 7b 31 20 7b  2, 3) }.  } {1 {
7910: 66 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73  foreign key cons
7920: 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a  traint failed}}.
7930: 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d    do_test fkey2-
7940: 31 34 2e 32 2e 32 2e 34 20 7b 0a 20 20 20 20 65  14.2.2.4 {.    e
7950: 78 65 63 73 71 6c 20 7b 20 49 4e 53 45 52 54 20  xecsql { INSERT 
7960: 49 4e 54 4f 20 74 34 20 56 41 4c 55 45 53 28 31  INTO t4 VALUES(1
7970: 2c 20 4e 55 4c 4c 29 20 7d 0a 20 20 7d 20 7b 7d  , NULL) }.  } {}
7980: 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  .  do_test fkey2
7990: 2d 31 34 2e 32 2e 32 2e 35 20 7b 0a 20 20 20 20  -14.2.2.5 {.    
79a0: 63 61 74 63 68 73 71 6c 20 7b 20 55 50 44 41 54  catchsql { UPDAT
79b0: 45 20 74 34 20 53 45 54 20 62 20 3d 20 35 20 7d  E t4 SET b = 5 }
79c0: 0a 20 20 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e  .  } {1 {foreign
79d0: 20 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e 74 20   key constraint 
79e0: 66 61 69 6c 65 64 7d 7d 0a 20 20 64 6f 5f 74 65  failed}}.  do_te
79f0: 73 74 20 66 6b 65 79 32 2d 31 34 2e 32 2e 32 2e  st fkey2-14.2.2.
7a00: 36 20 7b 0a 20 20 20 20 63 61 74 63 68 73 71 6c  6 {.    catchsql
7a10: 20 7b 20 55 50 44 41 54 45 20 74 34 20 53 45 54   { UPDATE t4 SET
7a20: 20 62 20 3d 20 31 20 7d 0a 20 20 7d 20 7b 30 20   b = 1 }.  } {0 
7a30: 7b 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b  {}}.  do_test fk
7a40: 65 79 32 2d 31 34 2e 32 2e 32 2e 37 20 7b 0a 20  ey2-14.2.2.7 {. 
7a50: 20 20 20 65 78 65 63 73 71 6c 20 7b 20 49 4e 53     execsql { INS
7a60: 45 52 54 20 49 4e 54 4f 20 74 33 20 56 41 4c 55  ERT INTO t3 VALU
7a70: 45 53 28 31 2c 20 4e 55 4c 4c 2c 20 31 29 20 7d  ES(1, NULL, 1) }
7a80: 0a 20 20 7d 20 7b 7d 0a 0a 20 20 23 20 52 65 70  .  } {}..  # Rep
7a90: 65 61 74 20 66 6f 72 20 54 45 4d 50 20 74 61 62  eat for TEMP tab
7aa0: 6c 65 73 0a 20 20 23 0a 20 20 64 72 6f 70 5f 61  les.  #.  drop_a
7ab0: 6c 6c 5f 74 61 62 6c 65 73 0a 20 20 64 6f 5f 74  ll_tables.  do_t
7ac0: 65 73 74 20 66 6b 65 79 32 2d 31 34 2e 31 74 6d  est fkey2-14.1tm
7ad0: 70 2e 31 20 7b 0a 20 20 20 20 23 20 41 64 64 69  p.1 {.    # Addi
7ae0: 6e 67 20 61 20 63 6f 6c 75 6d 6e 20 77 69 74 68  ng a column with
7af0: 20 61 20 52 45 46 45 52 45 4e 43 45 53 20 63 6c   a REFERENCES cl
7b00: 61 75 73 65 20 69 73 20 6e 6f 74 20 73 75 70 70  ause is not supp
7b10: 6f 72 74 65 64 2e 0a 20 20 20 20 65 78 65 63 73  orted..    execs
7b20: 71 6c 20 7b 20 0a 20 20 20 20 20 20 43 52 45 41  ql { .      CREA
7b30: 54 45 20 54 45 4d 50 20 54 41 42 4c 45 20 74 31  TE TEMP TABLE t1
7b40: 28 61 20 50 52 49 4d 41 52 59 20 4b 45 59 29 3b  (a PRIMARY KEY);
7b50: 0a 20 20 20 20 20 20 43 52 45 41 54 45 20 54 45  .      CREATE TE
7b60: 4d 50 20 54 41 42 4c 45 20 74 32 28 61 2c 20 62  MP TABLE t2(a, b
7b70: 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 74  );.    }.    cat
7b80: 63 68 73 71 6c 20 7b 20 41 4c 54 45 52 20 54 41  chsql { ALTER TA
7b90: 42 4c 45 20 74 32 20 41 44 44 20 43 4f 4c 55 4d  BLE t2 ADD COLUM
7ba0: 4e 20 63 20 52 45 46 45 52 45 4e 43 45 53 20 74  N c REFERENCES t
7bb0: 31 20 7d 0a 20 20 7d 20 7b 30 20 7b 7d 7d 0a 20  1 }.  } {0 {}}. 
7bc0: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31   do_test fkey2-1
7bd0: 34 2e 31 74 6d 70 2e 32 20 7b 0a 20 20 20 20 63  4.1tmp.2 {.    c
7be0: 61 74 63 68 73 71 6c 20 7b 20 41 4c 54 45 52 20  atchsql { ALTER 
7bf0: 54 41 42 4c 45 20 74 32 20 41 44 44 20 43 4f 4c  TABLE t2 ADD COL
7c00: 55 4d 4e 20 64 20 44 45 46 41 55 4c 54 20 4e 55  UMN d DEFAULT NU
7c10: 4c 4c 20 52 45 46 45 52 45 4e 43 45 53 20 74 31  LL REFERENCES t1
7c20: 20 7d 0a 20 20 7d 20 7b 30 20 7b 7d 7d 0a 20 20   }.  } {0 {}}.  
7c30: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 34  do_test fkey2-14
7c40: 2e 31 74 6d 70 2e 33 20 7b 0a 20 20 20 20 63 61  .1tmp.3 {.    ca
7c50: 74 63 68 73 71 6c 20 7b 20 41 4c 54 45 52 20 54  tchsql { ALTER T
7c60: 41 42 4c 45 20 74 32 20 41 44 44 20 43 4f 4c 55  ABLE t2 ADD COLU
7c70: 4d 4e 20 65 20 52 45 46 45 52 45 4e 43 45 53 20  MN e REFERENCES 
7c80: 74 31 20 44 45 46 41 55 4c 54 20 4e 55 4c 4c 7d  t1 DEFAULT NULL}
7c90: 0a 20 20 7d 20 7b 30 20 7b 7d 7d 0a 20 20 64 6f  .  } {0 {}}.  do
7ca0: 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 34 2e 31  _test fkey2-14.1
7cb0: 74 6d 70 2e 34 20 7b 0a 20 20 20 20 63 61 74 63  tmp.4 {.    catc
7cc0: 68 73 71 6c 20 7b 20 41 4c 54 45 52 20 54 41 42  hsql { ALTER TAB
7cd0: 4c 45 20 74 32 20 41 44 44 20 43 4f 4c 55 4d 4e  LE t2 ADD COLUMN
7ce0: 20 66 20 52 45 46 45 52 45 4e 43 45 53 20 74 31   f REFERENCES t1
7cf0: 20 44 45 46 41 55 4c 54 20 27 74 65 78 74 27 7d   DEFAULT 'text'}
7d00: 0a 20 20 7d 20 7b 31 20 7b 43 61 6e 6e 6f 74 20  .  } {1 {Cannot 
7d10: 61 64 64 20 61 20 52 45 46 45 52 45 4e 43 45 53  add a REFERENCES
7d20: 20 63 6f 6c 75 6d 6e 20 77 69 74 68 20 6e 6f 6e   column with non
7d30: 2d 4e 55 4c 4c 20 64 65 66 61 75 6c 74 20 76 61  -NULL default va
7d40: 6c 75 65 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20  lue}}.  do_test 
7d50: 66 6b 65 79 32 2d 31 34 2e 31 74 6d 70 2e 35 20  fkey2-14.1tmp.5 
7d60: 7b 0a 20 20 20 20 63 61 74 63 68 73 71 6c 20 7b  {.    catchsql {
7d70: 20 41 4c 54 45 52 20 54 41 42 4c 45 20 74 32 20   ALTER TABLE t2 
7d80: 41 44 44 20 43 4f 4c 55 4d 4e 20 67 20 44 45 46  ADD COLUMN g DEF
7d90: 41 55 4c 54 20 43 55 52 52 45 4e 54 5f 54 49 4d  AULT CURRENT_TIM
7da0: 45 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 20  E REFERENCES t1 
7db0: 7d 0a 20 20 7d 20 7b 31 20 7b 43 61 6e 6e 6f 74  }.  } {1 {Cannot
7dc0: 20 61 64 64 20 61 20 52 45 46 45 52 45 4e 43 45   add a REFERENCE
7dd0: 53 20 63 6f 6c 75 6d 6e 20 77 69 74 68 20 6e 6f  S column with no
7de0: 6e 2d 4e 55 4c 4c 20 64 65 66 61 75 6c 74 20 76  n-NULL default v
7df0: 61 6c 75 65 7d 7d 0a 20 20 64 6f 5f 74 65 73 74  alue}}.  do_test
7e00: 20 66 6b 65 79 32 2d 31 34 2e 31 74 6d 70 2e 36   fkey2-14.1tmp.6
7e10: 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b   {.    execsql {
7e20: 20 0a 20 20 20 20 20 20 50 52 41 47 4d 41 20 66   .      PRAGMA f
7e30: 6f 72 65 69 67 6e 5f 6b 65 79 73 20 3d 20 6f 66  oreign_keys = of
7e40: 66 3b 0a 20 20 20 20 20 20 41 4c 54 45 52 20 54  f;.      ALTER T
7e50: 41 42 4c 45 20 74 32 20 41 44 44 20 43 4f 4c 55  ABLE t2 ADD COLU
7e60: 4d 4e 20 68 20 44 45 46 41 55 4c 54 20 27 74 65  MN h DEFAULT 'te
7e70: 78 74 27 20 52 45 46 45 52 45 4e 43 45 53 20 74  xt' REFERENCES t
7e80: 31 3b 0a 20 20 20 20 20 20 50 52 41 47 4d 41 20  1;.      PRAGMA 
7e90: 66 6f 72 65 69 67 6e 5f 6b 65 79 73 20 3d 20 6f  foreign_keys = o
7ea0: 6e 3b 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20  n;.      SELECT 
7eb0: 73 71 6c 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f  sql FROM sqlite_
7ec0: 74 65 6d 70 5f 6d 61 73 74 65 72 20 57 48 45 52  temp_master WHER
7ed0: 45 20 6e 61 6d 65 3d 27 74 32 27 3b 0a 20 20 20  E name='t2';.   
7ee0: 20 7d 0a 20 20 7d 20 7b 7b 43 52 45 41 54 45 20   }.  } {{CREATE 
7ef0: 54 41 42 4c 45 20 74 32 28 61 2c 20 62 2c 20 63  TABLE t2(a, b, c
7f00: 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 2c 20   REFERENCES t1, 
7f10: 64 20 44 45 46 41 55 4c 54 20 4e 55 4c 4c 20 52  d DEFAULT NULL R
7f20: 45 46 45 52 45 4e 43 45 53 20 74 31 2c 20 65 20  EFERENCES t1, e 
7f30: 52 45 46 45 52 45 4e 43 45 53 20 74 31 20 44 45  REFERENCES t1 DE
7f40: 46 41 55 4c 54 20 4e 55 4c 4c 2c 20 68 20 44 45  FAULT NULL, h DE
7f50: 46 41 55 4c 54 20 27 74 65 78 74 27 20 52 45 46  FAULT 'text' REF
7f60: 45 52 45 4e 43 45 53 20 74 31 29 7d 7d 0a 0a 20  ERENCES t1)}}.. 
7f70: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31   do_test fkey2-1
7f80: 34 2e 32 74 6d 70 2e 31 2e 31 20 7b 0a 20 20 20  4.2tmp.1.1 {.   
7f90: 20 74 65 73 74 5f 72 65 6e 61 6d 65 5f 70 61 72   test_rename_par
7fa0: 65 6e 74 20 7b 43 52 45 41 54 45 20 54 41 42 4c  ent {CREATE TABL
7fb0: 45 20 74 31 28 61 20 52 45 46 45 52 45 4e 43 45  E t1(a REFERENCE
7fc0: 53 20 74 32 29 7d 20 74 32 20 74 33 0a 20 20 7d  S t2)} t2 t3.  }
7fd0: 20 7b 7b 43 52 45 41 54 45 20 54 41 42 4c 45 20   {{CREATE TABLE 
7fe0: 74 31 28 61 20 52 45 46 45 52 45 4e 43 45 53 20  t1(a REFERENCES 
7ff0: 22 74 33 22 29 7d 7d 0a 20 20 64 6f 5f 74 65 73  "t3")}}.  do_tes
8000: 74 20 66 6b 65 79 32 2d 31 34 2e 32 74 6d 70 2e  t fkey2-14.2tmp.
8010: 31 2e 32 20 7b 0a 20 20 20 20 74 65 73 74 5f 72  1.2 {.    test_r
8020: 65 6e 61 6d 65 5f 70 61 72 65 6e 74 20 7b 43 52  ename_parent {CR
8030: 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 61 20  EATE TABLE t1(a 
8040: 52 45 46 45 52 45 4e 43 45 53 20 74 32 29 7d 20  REFERENCES t2)} 
8050: 74 34 20 74 33 0a 20 20 7d 20 7b 7b 43 52 45 41  t4 t3.  } {{CREA
8060: 54 45 20 54 41 42 4c 45 20 74 31 28 61 20 52 45  TE TABLE t1(a RE
8070: 46 45 52 45 4e 43 45 53 20 74 32 29 7d 7d 0a 20  FERENCES t2)}}. 
8080: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31   do_test fkey2-1
8090: 34 2e 32 74 6d 70 2e 31 2e 33 20 7b 0a 20 20 20  4.2tmp.1.3 {.   
80a0: 20 74 65 73 74 5f 72 65 6e 61 6d 65 5f 70 61 72   test_rename_par
80b0: 65 6e 74 20 7b 43 52 45 41 54 45 20 54 41 42 4c  ent {CREATE TABL
80c0: 45 20 74 31 28 61 20 52 45 46 45 52 45 4e 43 45  E t1(a REFERENCE
80d0: 53 20 22 74 32 22 29 7d 20 74 32 20 74 33 0a 20  S "t2")} t2 t3. 
80e0: 20 7d 20 7b 7b 43 52 45 41 54 45 20 54 41 42 4c   } {{CREATE TABL
80f0: 45 20 74 31 28 61 20 52 45 46 45 52 45 4e 43 45  E t1(a REFERENCE
8100: 53 20 22 74 33 22 29 7d 7d 0a 20 20 0a 20 20 23  S "t3")}}.  .  #
8110: 20 54 65 73 74 20 41 4c 54 45 52 20 54 41 42 4c   Test ALTER TABL
8120: 45 20 52 45 4e 41 4d 45 20 54 41 42 4c 45 20 61  E RENAME TABLE a
8130: 20 62 69 74 2e 0a 20 20 23 0a 20 20 64 6f 5f 74   bit..  #.  do_t
8140: 65 73 74 20 66 6b 65 79 32 2d 31 34 2e 32 74 6d  est fkey2-14.2tm
8150: 70 2e 32 2e 31 20 7b 0a 20 20 20 20 64 72 6f 70  p.2.1 {.    drop
8160: 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a 20 20 20 20  _all_tables.    
8170: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 20 20  execsql {.      
8180: 43 52 45 41 54 45 20 54 45 4d 50 20 54 41 42 4c  CREATE TEMP TABL
8190: 45 20 74 31 28 61 20 50 52 49 4d 41 52 59 20 4b  E t1(a PRIMARY K
81a0: 45 59 2c 20 62 20 52 45 46 45 52 45 4e 43 45 53  EY, b REFERENCES
81b0: 20 74 31 29 3b 0a 20 20 20 20 20 20 43 52 45 41   t1);.      CREA
81c0: 54 45 20 54 45 4d 50 20 54 41 42 4c 45 20 74 32  TE TEMP TABLE t2
81d0: 28 61 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20  (a PRIMARY KEY, 
81e0: 62 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 2c  b REFERENCES t1,
81f0: 20 63 20 52 45 46 45 52 45 4e 43 45 53 20 74 32   c REFERENCES t2
8200: 29 3b 0a 20 20 20 20 20 20 43 52 45 41 54 45 20  );.      CREATE 
8210: 54 45 4d 50 20 54 41 42 4c 45 20 74 33 28 61 20  TEMP TABLE t3(a 
8220: 52 45 46 45 52 45 4e 43 45 53 20 74 31 2c 20 62  REFERENCES t1, b
8230: 20 52 45 46 45 52 45 4e 43 45 53 20 74 32 2c 20   REFERENCES t2, 
8240: 63 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 29  c REFERENCES t1)
8250: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 65 78 65 63  ;.    }.    exec
8260: 73 71 6c 20 7b 20 53 45 4c 45 43 54 20 73 71 6c  sql { SELECT sql
8270: 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f 74 65 6d   FROM sqlite_tem
8280: 70 5f 6d 61 73 74 65 72 20 57 48 45 52 45 20 74  p_master WHERE t
8290: 79 70 65 20 3d 20 27 74 61 62 6c 65 27 7d 0a 20  ype = 'table'}. 
82a0: 20 7d 20 5b 6c 69 73 74 20 5c 0a 20 20 20 20 7b   } [list \.    {
82b0: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28  CREATE TABLE t1(
82c0: 61 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62  a PRIMARY KEY, b
82d0: 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 29 7d   REFERENCES t1)}
82e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
82f0: 20 20 20 20 20 5c 0a 20 20 20 20 7b 43 52 45 41       \.    {CREA
8300: 54 45 20 54 41 42 4c 45 20 74 32 28 61 20 50 52  TE TABLE t2(a PR
8310: 49 4d 41 52 59 20 4b 45 59 2c 20 62 20 52 45 46  IMARY KEY, b REF
8320: 45 52 45 4e 43 45 53 20 74 31 2c 20 63 20 52 45  ERENCES t1, c RE
8330: 46 45 52 45 4e 43 45 53 20 74 32 29 7d 20 20 20  FERENCES t2)}   
8340: 20 5c 0a 20 20 20 20 7b 43 52 45 41 54 45 20 54   \.    {CREATE T
8350: 41 42 4c 45 20 74 33 28 61 20 52 45 46 45 52 45  ABLE t3(a REFERE
8360: 4e 43 45 53 20 74 31 2c 20 62 20 52 45 46 45 52  NCES t1, b REFER
8370: 45 4e 43 45 53 20 74 32 2c 20 63 20 52 45 46 45  ENCES t2, c REFE
8380: 52 45 4e 43 45 53 20 74 31 29 7d 20 20 5c 0a 20  RENCES t1)}  \. 
8390: 20 5d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65   ].  do_test fke
83a0: 79 32 2d 31 34 2e 32 74 6d 70 2e 32 2e 32 20 7b  y2-14.2tmp.2.2 {
83b0: 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20 41  .    execsql { A
83c0: 4c 54 45 52 20 54 41 42 4c 45 20 74 31 20 52 45  LTER TABLE t1 RE
83d0: 4e 41 4d 45 20 54 4f 20 74 34 20 7d 0a 20 20 20  NAME TO t4 }.   
83e0: 20 65 78 65 63 73 71 6c 20 7b 20 53 45 4c 45 43   execsql { SELEC
83f0: 54 20 73 71 6c 20 46 52 4f 4d 20 73 71 6c 69 74  T sql FROM sqlit
8400: 65 5f 74 65 6d 70 5f 6d 61 73 74 65 72 20 57 48  e_temp_master WH
8410: 45 52 45 20 74 79 70 65 20 3d 20 27 74 61 62 6c  ERE type = 'tabl
8420: 65 27 7d 0a 20 20 7d 20 5b 6c 69 73 74 20 5c 0a  e'}.  } [list \.
8430: 20 20 20 20 7b 43 52 45 41 54 45 20 54 41 42 4c      {CREATE TABL
8440: 45 20 22 74 34 22 28 61 20 50 52 49 4d 41 52 59  E "t4"(a PRIMARY
8450: 20 4b 45 59 2c 20 62 20 52 45 46 45 52 45 4e 43   KEY, b REFERENC
8460: 45 53 20 22 74 34 22 29 7d 20 20 20 20 20 20 20  ES "t4")}       
8470: 20 20 20 20 20 20 20 20 20 20 20 20 20 5c 0a 20               \. 
8480: 20 20 20 7b 43 52 45 41 54 45 20 54 41 42 4c 45     {CREATE TABLE
8490: 20 74 32 28 61 20 50 52 49 4d 41 52 59 20 4b 45   t2(a PRIMARY KE
84a0: 59 2c 20 62 20 52 45 46 45 52 45 4e 43 45 53 20  Y, b REFERENCES 
84b0: 22 74 34 22 2c 20 63 20 52 45 46 45 52 45 4e 43  "t4", c REFERENC
84c0: 45 53 20 74 32 29 7d 20 20 20 20 20 5c 0a 20 20  ES t2)}     \.  
84d0: 20 20 7b 43 52 45 41 54 45 20 54 41 42 4c 45 20    {CREATE TABLE 
84e0: 74 33 28 61 20 52 45 46 45 52 45 4e 43 45 53 20  t3(a REFERENCES 
84f0: 22 74 34 22 2c 20 62 20 52 45 46 45 52 45 4e 43  "t4", b REFERENC
8500: 45 53 20 74 32 2c 20 63 20 52 45 46 45 52 45 4e  ES t2, c REFEREN
8510: 43 45 53 20 22 74 34 22 29 7d 20 5c 0a 20 20 5d  CES "t4")} \.  ]
8520: 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  .  do_test fkey2
8530: 2d 31 34 2e 32 74 6d 70 2e 32 2e 33 20 7b 0a 20  -14.2tmp.2.3 {. 
8540: 20 20 20 63 61 74 63 68 73 71 6c 20 7b 20 49 4e     catchsql { IN
8550: 53 45 52 54 20 49 4e 54 4f 20 74 33 20 56 41 4c  SERT INTO t3 VAL
8560: 55 45 53 28 31 2c 20 32 2c 20 33 29 20 7d 0a 20  UES(1, 2, 3) }. 
8570: 20 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b   } {1 {foreign k
8580: 65 79 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61  ey constraint fa
8590: 69 6c 65 64 7d 7d 0a 20 20 64 6f 5f 74 65 73 74  iled}}.  do_test
85a0: 20 66 6b 65 79 32 2d 31 34 2e 32 74 6d 70 2e 32   fkey2-14.2tmp.2
85b0: 2e 34 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c  .4 {.    execsql
85c0: 20 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74   { INSERT INTO t
85d0: 34 20 56 41 4c 55 45 53 28 31 2c 20 4e 55 4c 4c  4 VALUES(1, NULL
85e0: 29 20 7d 0a 20 20 7d 20 7b 7d 0a 20 20 64 6f 5f  ) }.  } {}.  do_
85f0: 74 65 73 74 20 66 6b 65 79 32 2d 31 34 2e 32 74  test fkey2-14.2t
8600: 6d 70 2e 32 2e 35 20 7b 0a 20 20 20 20 63 61 74  mp.2.5 {.    cat
8610: 63 68 73 71 6c 20 7b 20 55 50 44 41 54 45 20 74  chsql { UPDATE t
8620: 34 20 53 45 54 20 62 20 3d 20 35 20 7d 0a 20 20  4 SET b = 5 }.  
8630: 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65  } {1 {foreign ke
8640: 79 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69  y constraint fai
8650: 6c 65 64 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20  led}}.  do_test 
8660: 66 6b 65 79 32 2d 31 34 2e 32 74 6d 70 2e 32 2e  fkey2-14.2tmp.2.
8670: 36 20 7b 0a 20 20 20 20 63 61 74 63 68 73 71 6c  6 {.    catchsql
8680: 20 7b 20 55 50 44 41 54 45 20 74 34 20 53 45 54   { UPDATE t4 SET
8690: 20 62 20 3d 20 31 20 7d 0a 20 20 7d 20 7b 30 20   b = 1 }.  } {0 
86a0: 7b 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b  {}}.  do_test fk
86b0: 65 79 32 2d 31 34 2e 32 74 6d 70 2e 32 2e 37 20  ey2-14.2tmp.2.7 
86c0: 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20  {.    execsql { 
86d0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 33 20 56  INSERT INTO t3 V
86e0: 41 4c 55 45 53 28 31 2c 20 4e 55 4c 4c 2c 20 31  ALUES(1, NULL, 1
86f0: 29 20 7d 0a 20 20 7d 20 7b 7d 0a 0a 20 20 23 20  ) }.  } {}..  # 
8700: 52 65 70 65 61 74 20 66 6f 72 20 41 54 54 41 43  Repeat for ATTAC
8710: 48 2d 65 64 20 74 61 62 6c 65 73 0a 20 20 23 0a  H-ed tables.  #.
8720: 20 20 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65    drop_all_table
8730: 73 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79  s.  do_test fkey
8740: 32 2d 31 34 2e 31 61 75 78 2e 31 20 7b 0a 20 20  2-14.1aux.1 {.  
8750: 20 20 23 20 41 64 64 69 6e 67 20 61 20 63 6f 6c    # Adding a col
8760: 75 6d 6e 20 77 69 74 68 20 61 20 52 45 46 45 52  umn with a REFER
8770: 45 4e 43 45 53 20 63 6c 61 75 73 65 20 69 73 20  ENCES clause is 
8780: 6e 6f 74 20 73 75 70 70 6f 72 74 65 64 2e 0a 20  not supported.. 
8790: 20 20 20 65 78 65 63 73 71 6c 20 7b 20 0a 20 20     execsql { .  
87a0: 20 20 20 20 41 54 54 41 43 48 20 27 3a 6d 65 6d      ATTACH ':mem
87b0: 6f 72 79 3a 27 20 41 53 20 61 75 78 3b 0a 20 20  ory:' AS aux;.  
87c0: 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45      CREATE TABLE
87d0: 20 61 75 78 2e 74 31 28 61 20 50 52 49 4d 41 52   aux.t1(a PRIMAR
87e0: 59 20 4b 45 59 29 3b 0a 20 20 20 20 20 20 43 52  Y KEY);.      CR
87f0: 45 41 54 45 20 54 41 42 4c 45 20 61 75 78 2e 74  EATE TABLE aux.t
8800: 32 28 61 2c 20 62 29 3b 0a 20 20 20 20 7d 0a 20  2(a, b);.    }. 
8810: 20 20 20 63 61 74 63 68 73 71 6c 20 7b 20 41 4c     catchsql { AL
8820: 54 45 52 20 54 41 42 4c 45 20 74 32 20 41 44 44  TER TABLE t2 ADD
8830: 20 43 4f 4c 55 4d 4e 20 63 20 52 45 46 45 52 45   COLUMN c REFERE
8840: 4e 43 45 53 20 74 31 20 7d 0a 20 20 7d 20 7b 30  NCES t1 }.  } {0
8850: 20 7b 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66   {}}.  do_test f
8860: 6b 65 79 32 2d 31 34 2e 31 61 75 78 2e 32 20 7b  key2-14.1aux.2 {
8870: 0a 20 20 20 20 63 61 74 63 68 73 71 6c 20 7b 20  .    catchsql { 
8880: 41 4c 54 45 52 20 54 41 42 4c 45 20 74 32 20 41  ALTER TABLE t2 A
8890: 44 44 20 43 4f 4c 55 4d 4e 20 64 20 44 45 46 41  DD COLUMN d DEFA
88a0: 55 4c 54 20 4e 55 4c 4c 20 52 45 46 45 52 45 4e  ULT NULL REFEREN
88b0: 43 45 53 20 74 31 20 7d 0a 20 20 7d 20 7b 30 20  CES t1 }.  } {0 
88c0: 7b 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b  {}}.  do_test fk
88d0: 65 79 32 2d 31 34 2e 31 61 75 78 2e 33 20 7b 0a  ey2-14.1aux.3 {.
88e0: 20 20 20 20 63 61 74 63 68 73 71 6c 20 7b 20 41      catchsql { A
88f0: 4c 54 45 52 20 54 41 42 4c 45 20 74 32 20 41 44  LTER TABLE t2 AD
8900: 44 20 43 4f 4c 55 4d 4e 20 65 20 52 45 46 45 52  D COLUMN e REFER
8910: 45 4e 43 45 53 20 74 31 20 44 45 46 41 55 4c 54  ENCES t1 DEFAULT
8920: 20 4e 55 4c 4c 7d 0a 20 20 7d 20 7b 30 20 7b 7d   NULL}.  } {0 {}
8930: 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79  }.  do_test fkey
8940: 32 2d 31 34 2e 31 61 75 78 2e 34 20 7b 0a 20 20  2-14.1aux.4 {.  
8950: 20 20 63 61 74 63 68 73 71 6c 20 7b 20 41 4c 54    catchsql { ALT
8960: 45 52 20 54 41 42 4c 45 20 74 32 20 41 44 44 20  ER TABLE t2 ADD 
8970: 43 4f 4c 55 4d 4e 20 66 20 52 45 46 45 52 45 4e  COLUMN f REFEREN
8980: 43 45 53 20 74 31 20 44 45 46 41 55 4c 54 20 27  CES t1 DEFAULT '
8990: 74 65 78 74 27 7d 0a 20 20 7d 20 7b 31 20 7b 43  text'}.  } {1 {C
89a0: 61 6e 6e 6f 74 20 61 64 64 20 61 20 52 45 46 45  annot add a REFE
89b0: 52 45 4e 43 45 53 20 63 6f 6c 75 6d 6e 20 77 69  RENCES column wi
89c0: 74 68 20 6e 6f 6e 2d 4e 55 4c 4c 20 64 65 66 61  th non-NULL defa
89d0: 75 6c 74 20 76 61 6c 75 65 7d 7d 0a 20 20 64 6f  ult value}}.  do
89e0: 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 34 2e 31  _test fkey2-14.1
89f0: 61 75 78 2e 35 20 7b 0a 20 20 20 20 63 61 74 63  aux.5 {.    catc
8a00: 68 73 71 6c 20 7b 20 41 4c 54 45 52 20 54 41 42  hsql { ALTER TAB
8a10: 4c 45 20 74 32 20 41 44 44 20 43 4f 4c 55 4d 4e  LE t2 ADD COLUMN
8a20: 20 67 20 44 45 46 41 55 4c 54 20 43 55 52 52 45   g DEFAULT CURRE
8a30: 4e 54 5f 54 49 4d 45 20 52 45 46 45 52 45 4e 43  NT_TIME REFERENC
8a40: 45 53 20 74 31 20 7d 0a 20 20 7d 20 7b 31 20 7b  ES t1 }.  } {1 {
8a50: 43 61 6e 6e 6f 74 20 61 64 64 20 61 20 52 45 46  Cannot add a REF
8a60: 45 52 45 4e 43 45 53 20 63 6f 6c 75 6d 6e 20 77  ERENCES column w
8a70: 69 74 68 20 6e 6f 6e 2d 4e 55 4c 4c 20 64 65 66  ith non-NULL def
8a80: 61 75 6c 74 20 76 61 6c 75 65 7d 7d 0a 20 20 64  ault value}}.  d
8a90: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 34 2e  o_test fkey2-14.
8aa0: 31 61 75 78 2e 36 20 7b 0a 20 20 20 20 65 78 65  1aux.6 {.    exe
8ab0: 63 73 71 6c 20 7b 20 0a 20 20 20 20 20 20 50 52  csql { .      PR
8ac0: 41 47 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79  AGMA foreign_key
8ad0: 73 20 3d 20 6f 66 66 3b 0a 20 20 20 20 20 20 41  s = off;.      A
8ae0: 4c 54 45 52 20 54 41 42 4c 45 20 74 32 20 41 44  LTER TABLE t2 AD
8af0: 44 20 43 4f 4c 55 4d 4e 20 68 20 44 45 46 41 55  D COLUMN h DEFAU
8b00: 4c 54 20 27 74 65 78 74 27 20 52 45 46 45 52 45  LT 'text' REFERE
8b10: 4e 43 45 53 20 74 31 3b 0a 20 20 20 20 20 20 50  NCES t1;.      P
8b20: 52 41 47 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65  RAGMA foreign_ke
8b30: 79 73 20 3d 20 6f 6e 3b 0a 20 20 20 20 20 20 53  ys = on;.      S
8b40: 45 4c 45 43 54 20 73 71 6c 20 46 52 4f 4d 20 61  ELECT sql FROM a
8b50: 75 78 2e 73 71 6c 69 74 65 5f 6d 61 73 74 65 72  ux.sqlite_master
8b60: 20 57 48 45 52 45 20 6e 61 6d 65 3d 27 74 32 27   WHERE name='t2'
8b70: 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 7b 43 52  ;.    }.  } {{CR
8b80: 45 41 54 45 20 54 41 42 4c 45 20 74 32 28 61 2c  EATE TABLE t2(a,
8b90: 20 62 2c 20 63 20 52 45 46 45 52 45 4e 43 45 53   b, c REFERENCES
8ba0: 20 74 31 2c 20 64 20 44 45 46 41 55 4c 54 20 4e   t1, d DEFAULT N
8bb0: 55 4c 4c 20 52 45 46 45 52 45 4e 43 45 53 20 74  ULL REFERENCES t
8bc0: 31 2c 20 65 20 52 45 46 45 52 45 4e 43 45 53 20  1, e REFERENCES 
8bd0: 74 31 20 44 45 46 41 55 4c 54 20 4e 55 4c 4c 2c  t1 DEFAULT NULL,
8be0: 20 68 20 44 45 46 41 55 4c 54 20 27 74 65 78 74   h DEFAULT 'text
8bf0: 27 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 29  ' REFERENCES t1)
8c00: 7d 7d 0a 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b  }}..  do_test fk
8c10: 65 79 32 2d 31 34 2e 32 61 75 78 2e 31 2e 31 20  ey2-14.2aux.1.1 
8c20: 7b 0a 20 20 20 20 74 65 73 74 5f 72 65 6e 61 6d  {.    test_renam
8c30: 65 5f 70 61 72 65 6e 74 20 7b 43 52 45 41 54 45  e_parent {CREATE
8c40: 20 54 41 42 4c 45 20 74 31 28 61 20 52 45 46 45   TABLE t1(a REFE
8c50: 52 45 4e 43 45 53 20 74 32 29 7d 20 74 32 20 74  RENCES t2)} t2 t
8c60: 33 0a 20 20 7d 20 7b 7b 43 52 45 41 54 45 20 54  3.  } {{CREATE T
8c70: 41 42 4c 45 20 74 31 28 61 20 52 45 46 45 52 45  ABLE t1(a REFERE
8c80: 4e 43 45 53 20 22 74 33 22 29 7d 7d 0a 20 20 64  NCES "t3")}}.  d
8c90: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 34 2e  o_test fkey2-14.
8ca0: 32 61 75 78 2e 31 2e 32 20 7b 0a 20 20 20 20 74  2aux.1.2 {.    t
8cb0: 65 73 74 5f 72 65 6e 61 6d 65 5f 70 61 72 65 6e  est_rename_paren
8cc0: 74 20 7b 43 52 45 41 54 45 20 54 41 42 4c 45 20  t {CREATE TABLE 
8cd0: 74 31 28 61 20 52 45 46 45 52 45 4e 43 45 53 20  t1(a REFERENCES 
8ce0: 74 32 29 7d 20 74 34 20 74 33 0a 20 20 7d 20 7b  t2)} t4 t3.  } {
8cf0: 7b 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31  {CREATE TABLE t1
8d00: 28 61 20 52 45 46 45 52 45 4e 43 45 53 20 74 32  (a REFERENCES t2
8d10: 29 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b  )}}.  do_test fk
8d20: 65 79 32 2d 31 34 2e 32 61 75 78 2e 31 2e 33 20  ey2-14.2aux.1.3 
8d30: 7b 0a 20 20 20 20 74 65 73 74 5f 72 65 6e 61 6d  {.    test_renam
8d40: 65 5f 70 61 72 65 6e 74 20 7b 43 52 45 41 54 45  e_parent {CREATE
8d50: 20 54 41 42 4c 45 20 74 31 28 61 20 52 45 46 45   TABLE t1(a REFE
8d60: 52 45 4e 43 45 53 20 22 74 32 22 29 7d 20 74 32  RENCES "t2")} t2
8d70: 20 74 33 0a 20 20 7d 20 7b 7b 43 52 45 41 54 45   t3.  } {{CREATE
8d80: 20 54 41 42 4c 45 20 74 31 28 61 20 52 45 46 45   TABLE t1(a REFE
8d90: 52 45 4e 43 45 53 20 22 74 33 22 29 7d 7d 0a 20  RENCES "t3")}}. 
8da0: 20 0a 20 20 23 20 54 65 73 74 20 41 4c 54 45 52   .  # Test ALTER
8db0: 20 54 41 42 4c 45 20 52 45 4e 41 4d 45 20 54 41   TABLE RENAME TA
8dc0: 42 4c 45 20 61 20 62 69 74 2e 0a 20 20 23 0a 20  BLE a bit..  #. 
8dd0: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31   do_test fkey2-1
8de0: 34 2e 32 61 75 78 2e 32 2e 31 20 7b 0a 20 20 20  4.2aux.2.1 {.   
8df0: 20 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73   drop_all_tables
8e00: 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20  .    execsql {. 
8e10: 20 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c       CREATE TABL
8e20: 45 20 61 75 78 2e 74 31 28 61 20 50 52 49 4d 41  E aux.t1(a PRIMA
8e30: 52 59 20 4b 45 59 2c 20 62 20 52 45 46 45 52 45  RY KEY, b REFERE
8e40: 4e 43 45 53 20 74 31 29 3b 0a 20 20 20 20 20 20  NCES t1);.      
8e50: 43 52 45 41 54 45 20 54 41 42 4c 45 20 61 75 78  CREATE TABLE aux
8e60: 2e 74 32 28 61 20 50 52 49 4d 41 52 59 20 4b 45  .t2(a PRIMARY KE
8e70: 59 2c 20 62 20 52 45 46 45 52 45 4e 43 45 53 20  Y, b REFERENCES 
8e80: 74 31 2c 20 63 20 52 45 46 45 52 45 4e 43 45 53  t1, c REFERENCES
8e90: 20 74 32 29 3b 0a 20 20 20 20 20 20 43 52 45 41   t2);.      CREA
8ea0: 54 45 20 54 41 42 4c 45 20 61 75 78 2e 74 33 28  TE TABLE aux.t3(
8eb0: 61 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 2c  a REFERENCES t1,
8ec0: 20 62 20 52 45 46 45 52 45 4e 43 45 53 20 74 32   b REFERENCES t2
8ed0: 2c 20 63 20 52 45 46 45 52 45 4e 43 45 53 20 74  , c REFERENCES t
8ee0: 31 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 65 78  1);.    }.    ex
8ef0: 65 63 73 71 6c 20 7b 20 53 45 4c 45 43 54 20 73  ecsql { SELECT s
8f00: 71 6c 20 46 52 4f 4d 20 61 75 78 2e 73 71 6c 69  ql FROM aux.sqli
8f10: 74 65 5f 6d 61 73 74 65 72 20 57 48 45 52 45 20  te_master WHERE 
8f20: 74 79 70 65 20 3d 20 27 74 61 62 6c 65 27 7d 0a  type = 'table'}.
8f30: 20 20 7d 20 5b 6c 69 73 74 20 5c 0a 20 20 20 20    } [list \.    
8f40: 7b 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31  {CREATE TABLE t1
8f50: 28 61 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20  (a PRIMARY KEY, 
8f60: 62 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 29  b REFERENCES t1)
8f70: 7d 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  }               
8f80: 20 20 20 20 20 20 5c 0a 20 20 20 20 7b 43 52 45        \.    {CRE
8f90: 41 54 45 20 54 41 42 4c 45 20 74 32 28 61 20 50  ATE TABLE t2(a P
8fa0: 52 49 4d 41 52 59 20 4b 45 59 2c 20 62 20 52 45  RIMARY KEY, b RE
8fb0: 46 45 52 45 4e 43 45 53 20 74 31 2c 20 63 20 52  FERENCES t1, c R
8fc0: 45 46 45 52 45 4e 43 45 53 20 74 32 29 7d 20 20  EFERENCES t2)}  
8fd0: 20 20 5c 0a 20 20 20 20 7b 43 52 45 41 54 45 20    \.    {CREATE 
8fe0: 54 41 42 4c 45 20 74 33 28 61 20 52 45 46 45 52  TABLE t3(a REFER
8ff0: 45 4e 43 45 53 20 74 31 2c 20 62 20 52 45 46 45  ENCES t1, b REFE
9000: 52 45 4e 43 45 53 20 74 32 2c 20 63 20 52 45 46  RENCES t2, c REF
9010: 45 52 45 4e 43 45 53 20 74 31 29 7d 20 20 5c 0a  ERENCES t1)}  \.
9020: 20 20 5d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b    ].  do_test fk
9030: 65 79 32 2d 31 34 2e 32 61 75 78 2e 32 2e 32 20  ey2-14.2aux.2.2 
9040: 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20  {.    execsql { 
9050: 41 4c 54 45 52 20 54 41 42 4c 45 20 74 31 20 52  ALTER TABLE t1 R
9060: 45 4e 41 4d 45 20 54 4f 20 74 34 20 7d 0a 20 20  ENAME TO t4 }.  
9070: 20 20 65 78 65 63 73 71 6c 20 7b 20 53 45 4c 45    execsql { SELE
9080: 43 54 20 73 71 6c 20 46 52 4f 4d 20 61 75 78 2e  CT sql FROM aux.
9090: 73 71 6c 69 74 65 5f 6d 61 73 74 65 72 20 57 48  sqlite_master WH
90a0: 45 52 45 20 74 79 70 65 20 3d 20 27 74 61 62 6c  ERE type = 'tabl
90b0: 65 27 7d 0a 20 20 7d 20 5b 6c 69 73 74 20 5c 0a  e'}.  } [list \.
90c0: 20 20 20 20 7b 43 52 45 41 54 45 20 54 41 42 4c      {CREATE TABL
90d0: 45 20 22 74 34 22 28 61 20 50 52 49 4d 41 52 59  E "t4"(a PRIMARY
90e0: 20 4b 45 59 2c 20 62 20 52 45 46 45 52 45 4e 43   KEY, b REFERENC
90f0: 45 53 20 22 74 34 22 29 7d 20 20 20 20 20 20 20  ES "t4")}       
9100: 20 20 20 20 20 20 20 20 20 20 20 20 20 5c 0a 20               \. 
9110: 20 20 20 7b 43 52 45 41 54 45 20 54 41 42 4c 45     {CREATE TABLE
9120: 20 74 32 28 61 20 50 52 49 4d 41 52 59 20 4b 45   t2(a PRIMARY KE
9130: 59 2c 20 62 20 52 45 46 45 52 45 4e 43 45 53 20  Y, b REFERENCES 
9140: 22 74 34 22 2c 20 63 20 52 45 46 45 52 45 4e 43  "t4", c REFERENC
9150: 45 53 20 74 32 29 7d 20 20 20 20 20 5c 0a 20 20  ES t2)}     \.  
9160: 20 20 7b 43 52 45 41 54 45 20 54 41 42 4c 45 20    {CREATE TABLE 
9170: 74 33 28 61 20 52 45 46 45 52 45 4e 43 45 53 20  t3(a REFERENCES 
9180: 22 74 34 22 2c 20 62 20 52 45 46 45 52 45 4e 43  "t4", b REFERENC
9190: 45 53 20 74 32 2c 20 63 20 52 45 46 45 52 45 4e  ES t2, c REFEREN
91a0: 43 45 53 20 22 74 34 22 29 7d 20 5c 0a 20 20 5d  CES "t4")} \.  ]
91b0: 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  .  do_test fkey2
91c0: 2d 31 34 2e 32 61 75 78 2e 32 2e 33 20 7b 0a 20  -14.2aux.2.3 {. 
91d0: 20 20 20 63 61 74 63 68 73 71 6c 20 7b 20 49 4e     catchsql { IN
91e0: 53 45 52 54 20 49 4e 54 4f 20 74 33 20 56 41 4c  SERT INTO t3 VAL
91f0: 55 45 53 28 31 2c 20 32 2c 20 33 29 20 7d 0a 20  UES(1, 2, 3) }. 
9200: 20 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b   } {1 {foreign k
9210: 65 79 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61  ey constraint fa
9220: 69 6c 65 64 7d 7d 0a 20 20 64 6f 5f 74 65 73 74  iled}}.  do_test
9230: 20 66 6b 65 79 32 2d 31 34 2e 32 61 75 78 2e 32   fkey2-14.2aux.2
9240: 2e 34 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c  .4 {.    execsql
9250: 20 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74   { INSERT INTO t
9260: 34 20 56 41 4c 55 45 53 28 31 2c 20 4e 55 4c 4c  4 VALUES(1, NULL
9270: 29 20 7d 0a 20 20 7d 20 7b 7d 0a 20 20 64 6f 5f  ) }.  } {}.  do_
9280: 74 65 73 74 20 66 6b 65 79 32 2d 31 34 2e 32 61  test fkey2-14.2a
9290: 75 78 2e 32 2e 35 20 7b 0a 20 20 20 20 63 61 74  ux.2.5 {.    cat
92a0: 63 68 73 71 6c 20 7b 20 55 50 44 41 54 45 20 74  chsql { UPDATE t
92b0: 34 20 53 45 54 20 62 20 3d 20 35 20 7d 0a 20 20  4 SET b = 5 }.  
92c0: 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65  } {1 {foreign ke
92d0: 79 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69  y constraint fai
92e0: 6c 65 64 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20  led}}.  do_test 
92f0: 66 6b 65 79 32 2d 31 34 2e 32 61 75 78 2e 32 2e  fkey2-14.2aux.2.
9300: 36 20 7b 0a 20 20 20 20 63 61 74 63 68 73 71 6c  6 {.    catchsql
9310: 20 7b 20 55 50 44 41 54 45 20 74 34 20 53 45 54   { UPDATE t4 SET
9320: 20 62 20 3d 20 31 20 7d 0a 20 20 7d 20 7b 30 20   b = 1 }.  } {0 
9330: 7b 7d 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b  {}}.  do_test fk
9340: 65 79 32 2d 31 34 2e 32 61 75 78 2e 32 2e 37 20  ey2-14.2aux.2.7 
9350: 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20  {.    execsql { 
9360: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 33 20 56  INSERT INTO t3 V
9370: 41 4c 55 45 53 28 31 2c 20 4e 55 4c 4c 2c 20 31  ALUES(1, NULL, 1
9380: 29 20 7d 0a 20 20 7d 20 7b 7d 0a 7d 0a 0a 64 6f  ) }.  } {}.}..do
9390: 5f 74 65 73 74 20 66 6b 65 79 2d 32 2e 31 34 2e  _test fkey-2.14.
93a0: 33 2e 31 20 7b 0a 20 20 64 72 6f 70 5f 61 6c 6c  3.1 {.  drop_all
93b0: 5f 74 61 62 6c 65 73 0a 20 20 65 78 65 63 73 71  _tables.  execsq
93c0: 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54  l {.    CREATE T
93d0: 41 42 4c 45 20 74 31 28 61 2c 20 62 20 52 45 46  ABLE t1(a, b REF
93e0: 45 52 45 4e 43 45 53 20 6e 6f 73 75 63 68 74 61  ERENCES nosuchta
93f0: 62 6c 65 29 3b 0a 20 20 20 20 44 52 4f 50 20 54  ble);.    DROP T
9400: 41 42 4c 45 20 74 31 3b 0a 20 20 7d 0a 7d 20 7b  ABLE t1;.  }.} {
9410: 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 2d 32  }.do_test fkey-2
9420: 2e 31 34 2e 33 2e 32 20 7b 0a 20 20 65 78 65 63  .14.3.2 {.  exec
9430: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
9440: 20 54 41 42 4c 45 20 74 31 28 61 20 50 52 49 4d   TABLE t1(a PRIM
9450: 41 52 59 20 4b 45 59 2c 20 62 29 3b 0a 20 20 20  ARY KEY, b);.   
9460: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
9470: 56 41 4c 55 45 53 28 27 61 27 2c 20 31 29 3b 0a  VALUES('a', 1);.
9480: 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45      CREATE TABLE
9490: 20 74 32 28 78 20 52 45 46 45 52 45 4e 43 45 53   t2(x REFERENCES
94a0: 20 74 31 29 3b 0a 20 20 20 20 49 4e 53 45 52 54   t1);.    INSERT
94b0: 20 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28   INTO t2 VALUES(
94c0: 27 61 27 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64  'a');.  }.} {}.d
94d0: 6f 5f 74 65 73 74 20 66 6b 65 79 2d 32 2e 31 34  o_test fkey-2.14
94e0: 2e 33 2e 33 20 7b 0a 20 20 63 61 74 63 68 73 71  .3.3 {.  catchsq
94f0: 6c 20 7b 20 44 52 4f 50 20 54 41 42 4c 45 20 74  l { DROP TABLE t
9500: 31 20 7d 0a 7d 20 7b 31 20 7b 66 6f 72 65 69 67  1 }.} {1 {foreig
9510: 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e 74  n key constraint
9520: 20 66 61 69 6c 65 64 7d 7d 0a 64 6f 5f 74 65 73   failed}}.do_tes
9530: 74 20 66 6b 65 79 2d 32 2e 31 34 2e 33 2e 34 20  t fkey-2.14.3.4 
9540: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
9550: 20 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 74 32    DELETE FROM t2
9560: 3b 0a 20 20 20 20 44 52 4f 50 20 54 41 42 4c 45  ;.    DROP TABLE
9570: 20 74 31 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f   t1;.  }.} {}.do
9580: 5f 74 65 73 74 20 66 6b 65 79 2d 32 2e 31 34 2e  _test fkey-2.14.
9590: 33 2e 34 20 7b 0a 20 20 63 61 74 63 68 73 71 6c  3.4 {.  catchsql
95a0: 20 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74   { INSERT INTO t
95b0: 32 20 56 41 4c 55 45 53 28 27 78 27 29 20 7d 0a  2 VALUES('x') }.
95c0: 7d 20 7b 31 20 7b 6e 6f 20 73 75 63 68 20 74 61  } {1 {no such ta
95d0: 62 6c 65 3a 20 6d 61 69 6e 2e 74 31 7d 7d 0a 64  ble: main.t1}}.d
95e0: 6f 5f 74 65 73 74 20 66 6b 65 79 2d 32 2e 31 34  o_test fkey-2.14
95f0: 2e 33 2e 35 20 7b 0a 20 20 65 78 65 63 73 71 6c  .3.5 {.  execsql
9600: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41   {.    CREATE TA
9610: 42 4c 45 20 74 31 28 78 20 50 52 49 4d 41 52 59  BLE t1(x PRIMARY
9620: 20 4b 45 59 29 3b 0a 20 20 20 20 49 4e 53 45 52   KEY);.    INSER
9630: 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53  T INTO t1 VALUES
9640: 28 27 78 27 29 3b 0a 20 20 7d 0a 20 20 65 78 65  ('x');.  }.  exe
9650: 63 73 71 6c 20 7b 20 49 4e 53 45 52 54 20 49 4e  csql { INSERT IN
9660: 54 4f 20 74 32 20 56 41 4c 55 45 53 28 27 78 27  TO t2 VALUES('x'
9670: 29 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74  ) }.} {}.do_test
9680: 20 66 6b 65 79 2d 32 2e 31 34 2e 33 2e 36 20 7b   fkey-2.14.3.6 {
9690: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 20 44 52  .  catchsql { DR
96a0: 4f 50 20 54 41 42 4c 45 20 74 31 20 7d 0a 7d 20  OP TABLE t1 }.} 
96b0: 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65 79 20  {1 {foreign key 
96c0: 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65  constraint faile
96d0: 64 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79  d}}.do_test fkey
96e0: 2d 32 2e 31 34 2e 33 2e 37 20 7b 0a 20 20 65 78  -2.14.3.7 {.  ex
96f0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50  ecsql {.    DROP
9700: 20 54 41 42 4c 45 20 74 32 3b 0a 20 20 20 20 44   TABLE t2;.    D
9710: 52 4f 50 20 54 41 42 4c 45 20 74 31 3b 0a 20 20  ROP TABLE t1;.  
9720: 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66  }.} {}.do_test f
9730: 6b 65 79 2d 32 2e 31 34 2e 33 2e 38 20 7b 0a 20  key-2.14.3.8 {. 
9740: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43   execsql {.    C
9750: 52 45 41 54 45 20 54 41 42 4c 45 20 70 70 28 78  REATE TABLE pp(x
9760: 2c 20 79 2c 20 50 52 49 4d 41 52 59 20 4b 45 59  , y, PRIMARY KEY
9770: 28 78 2c 20 79 29 29 3b 0a 20 20 20 20 43 52 45  (x, y));.    CRE
9780: 41 54 45 20 54 41 42 4c 45 20 63 63 28 61 2c 20  ATE TABLE cc(a, 
9790: 62 2c 20 46 4f 52 45 49 47 4e 20 4b 45 59 28 61  b, FOREIGN KEY(a
97a0: 2c 20 62 29 20 52 45 46 45 52 45 4e 43 45 53 20  , b) REFERENCES 
97b0: 70 70 28 78 2c 20 7a 29 29 3b 0a 20 20 7d 0a 20  pp(x, z));.  }. 
97c0: 20 63 61 74 63 68 73 71 6c 20 7b 20 49 4e 53 45   catchsql { INSE
97d0: 52 54 20 49 4e 54 4f 20 63 63 20 56 41 4c 55 45  RT INTO cc VALUE
97e0: 53 28 31 2c 20 32 29 20 7d 0a 7d 20 7b 31 20 7b  S(1, 2) }.} {1 {
97f0: 66 6f 72 65 69 67 6e 20 6b 65 79 20 6d 69 73 6d  foreign key mism
9800: 61 74 63 68 7d 7d 0a 64 6f 5f 74 65 73 74 20 66  atch}}.do_test f
9810: 6b 65 79 2d 32 2e 31 34 2e 33 2e 39 20 7b 0a 20  key-2.14.3.9 {. 
9820: 20 65 78 65 63 73 71 6c 20 7b 20 44 52 4f 50 20   execsql { DROP 
9830: 54 41 42 4c 45 20 63 63 20 7d 0a 7d 20 7b 7d 0a  TABLE cc }.} {}.
9840: 64 6f 5f 74 65 73 74 20 66 6b 65 79 2d 32 2e 31  do_test fkey-2.1
9850: 34 2e 33 2e 31 30 20 7b 0a 20 20 65 78 65 63 73  4.3.10 {.  execs
9860: 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  ql {.    CREATE 
9870: 54 41 42 4c 45 20 63 63 28 61 2c 20 62 2c 20 0a  TABLE cc(a, b, .
9880: 20 20 20 20 20 20 46 4f 52 45 49 47 4e 20 4b 45        FOREIGN KE
9890: 59 28 61 2c 20 62 29 20 52 45 46 45 52 45 4e 43  Y(a, b) REFERENC
98a0: 45 53 20 70 70 20 44 45 46 45 52 52 41 42 4c 45  ES pp DEFERRABLE
98b0: 20 49 4e 49 54 49 41 4c 4c 59 20 44 45 46 45 52   INITIALLY DEFER
98c0: 52 45 44 0a 20 20 20 20 29 3b 0a 20 20 7d 0a 20  RED.    );.  }. 
98d0: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 49   execsql {.    I
98e0: 4e 53 45 52 54 20 49 4e 54 4f 20 70 70 20 56 41  NSERT INTO pp VA
98f0: 4c 55 45 53 28 27 61 27 2c 20 27 62 27 29 3b 0a  LUES('a', 'b');.
9900: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
9910: 63 63 20 56 41 4c 55 45 53 28 27 61 27 2c 20 27  cc VALUES('a', '
9920: 62 27 29 3b 0a 20 20 20 20 42 45 47 49 4e 3b 0a  b');.    BEGIN;.
9930: 20 20 20 20 20 20 44 52 4f 50 20 54 41 42 4c 45        DROP TABLE
9940: 20 70 70 3b 0a 20 20 20 20 20 20 43 52 45 41 54   pp;.      CREAT
9950: 45 20 54 41 42 4c 45 20 70 70 28 61 2c 20 62 2c  E TABLE pp(a, b,
9960: 20 63 2c 20 50 52 49 4d 41 52 59 20 4b 45 59 28   c, PRIMARY KEY(
9970: 62 2c 20 63 29 29 3b 0a 20 20 20 20 20 20 49 4e  b, c));.      IN
9980: 53 45 52 54 20 49 4e 54 4f 20 70 70 20 56 41 4c  SERT INTO pp VAL
9990: 55 45 53 28 31 2c 20 27 61 27 2c 20 27 62 27 29  UES(1, 'a', 'b')
99a0: 3b 0a 20 20 20 20 43 4f 4d 4d 49 54 3b 0a 20 20  ;.    COMMIT;.  
99b0: 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66  }.} {}.do_test f
99c0: 6b 65 79 2d 32 2e 31 34 2e 33 2e 31 31 20 7b 0a  key-2.14.3.11 {.
99d0: 20 20 65 78 65 63 73 71 6c 20 7b 20 0a 20 20 20    execsql { .   
99e0: 20 42 45 47 49 4e 3b 0a 20 20 20 20 20 20 44 52   BEGIN;.      DR
99f0: 4f 50 20 54 41 42 4c 45 20 63 63 3b 0a 20 20 20  OP TABLE cc;.   
9a00: 20 20 20 44 52 4f 50 20 54 41 42 4c 45 20 70 70     DROP TABLE pp
9a10: 3b 0a 20 20 20 20 43 4f 4d 4d 49 54 3b 0a 20 20  ;.    COMMIT;.  
9a20: 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66  }.} {}.do_test f
9a30: 6b 65 79 2d 32 2e 31 34 2e 33 2e 31 32 20 7b 0a  key-2.14.3.12 {.
9a40: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
9a50: 43 52 45 41 54 45 20 54 41 42 4c 45 20 62 31 28  CREATE TABLE b1(
9a60: 61 2c 20 62 29 3b 0a 20 20 20 20 43 52 45 41 54  a, b);.    CREAT
9a70: 45 20 54 41 42 4c 45 20 62 32 28 61 2c 20 62 20  E TABLE b2(a, b 
9a80: 52 45 46 45 52 45 4e 43 45 53 20 62 31 29 3b 0a  REFERENCES b1);.
9a90: 20 20 20 20 44 52 4f 50 20 54 41 42 4c 45 20 62      DROP TABLE b
9aa0: 31 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74  1;.  }.} {}.do_t
9ab0: 65 73 74 20 66 6b 65 79 2d 32 2e 31 34 2e 33 2e  est fkey-2.14.3.
9ac0: 31 33 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  13 {.  execsql {
9ad0: 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  .    CREATE TABL
9ae0: 45 20 62 33 28 61 2c 20 62 20 52 45 46 45 52 45  E b3(a, b REFERE
9af0: 4e 43 45 53 20 62 32 20 44 45 46 45 52 52 41 42  NCES b2 DEFERRAB
9b00: 4c 45 20 49 4e 49 54 49 41 4c 4c 59 20 44 45 46  LE INITIALLY DEF
9b10: 45 52 52 45 44 29 3b 0a 20 20 20 20 44 52 4f 50  ERRED);.    DROP
9b20: 20 54 41 42 4c 45 20 62 32 3b 0a 20 20 7d 0a 7d   TABLE b2;.  }.}
9b30: 20 7b 7d 0a 0a 23 20 54 65 73 74 20 74 68 61 74   {}..# Test that
9b40: 20 6e 6f 74 68 69 6e 67 20 67 6f 65 73 20 77 72   nothing goes wr
9b50: 6f 6e 67 20 77 68 65 6e 20 64 72 6f 70 70 69 6e  ong when droppin
9b60: 67 20 61 20 74 61 62 6c 65 20 74 68 61 74 20 72  g a table that r
9b70: 65 66 65 72 73 20 74 6f 20 61 20 76 69 65 77 2e  efers to a view.
9b80: 0a 23 20 4f 72 20 64 72 6f 70 70 69 6e 67 20 61  .# Or dropping a
9b90: 20 76 69 65 77 20 74 68 61 74 20 61 6e 20 65 78   view that an ex
9ba0: 69 73 74 69 6e 67 20 46 4b 20 28 69 6e 63 6f 72  isting FK (incor
9bb0: 72 65 63 74 6c 79 29 20 72 65 66 65 72 73 20 74  rectly) refers t
9bc0: 6f 2e 20 4f 72 20 65 69 74 68 65 72 0a 23 20 6f  o. Or either.# o
9bd0: 66 20 74 68 65 20 61 62 6f 76 65 20 73 63 65 6e  f the above scen
9be0: 61 72 69 6f 73 20 77 69 74 68 20 61 20 76 69 72  arios with a vir
9bf0: 74 75 61 6c 20 74 61 62 6c 65 2e 0a 64 72 6f 70  tual table..drop
9c00: 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a 64 6f 5f 74  _all_tables.do_t
9c10: 65 73 74 20 66 6b 65 79 2d 32 2e 31 34 2e 34 2e  est fkey-2.14.4.
9c20: 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  1 {.  execsql {.
9c30: 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45      CREATE TABLE
9c40: 20 74 31 28 78 20 52 45 46 45 52 45 4e 43 45 53   t1(x REFERENCES
9c50: 20 76 29 3b 20 0a 20 20 20 20 43 52 45 41 54 45   v); .    CREATE
9c60: 20 56 49 45 57 20 76 20 41 53 20 53 45 4c 45 43   VIEW v AS SELEC
9c70: 54 20 2a 20 46 52 4f 4d 20 74 31 3b 0a 20 20 7d  T * FROM t1;.  }
9c80: 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b  .} {}.do_test fk
9c90: 65 79 2d 32 2e 31 34 2e 34 2e 32 20 7b 0a 20 20  ey-2.14.4.2 {.  
9ca0: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 44 52  execsql {.    DR
9cb0: 4f 50 20 56 49 45 57 20 76 3b 0a 20 20 7d 0a 7d  OP VIEW v;.  }.}
9cc0: 20 7b 7d 0a 69 66 63 61 70 61 62 6c 65 20 76 74   {}.ifcapable vt
9cd0: 61 62 20 7b 0a 20 20 72 65 67 69 73 74 65 72 5f  ab {.  register_
9ce0: 65 63 68 6f 5f 6d 6f 64 75 6c 65 20 64 62 0a 20  echo_module db. 
9cf0: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 2d 32 2e   do_test fkey-2.
9d00: 31 34 2e 34 2e 33 20 7b 0a 20 20 20 20 65 78 65  14.4.3 {.    exe
9d10: 63 73 71 6c 20 7b 20 43 52 45 41 54 45 20 56 49  csql { CREATE VI
9d20: 52 54 55 41 4c 20 54 41 42 4c 45 20 76 20 55 53  RTUAL TABLE v US
9d30: 49 4e 47 20 65 63 68 6f 28 74 31 29 20 7d 0a 20  ING echo(t1) }. 
9d40: 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74 65 73 74 20   } {}.  do_test 
9d50: 66 6b 65 79 2d 32 2e 31 34 2e 34 2e 32 20 7b 0a  fkey-2.14.4.2 {.
9d60: 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20      execsql {.  
9d70: 20 20 20 20 44 52 4f 50 20 54 41 42 4c 45 20 76      DROP TABLE v
9d80: 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 7d 0a 7d  ;.    }.  } {}.}
9d90: 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ..#-------------
9da0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
9db0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
9dc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
9dd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 54  ------------.# T
9de0: 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 74 65 73  he following tes
9df0: 74 73 2c 20 66 6b 65 79 32 2d 31 35 2e 2a 2c 20  ts, fkey2-15.*, 
9e00: 74 65 73 74 20 74 68 61 74 20 75 6e 6e 65 63 65  test that unnece
9e10: 73 73 61 72 79 20 46 4b 20 72 65 6c 61 74 65 64  ssary FK related
9e20: 20 73 63 61 6e 73 20 0a 23 20 61 6e 64 20 6c 6f   scans .# and lo
9e30: 6f 6b 75 70 73 20 61 72 65 20 61 76 6f 69 64 65  okups are avoide
9e40: 64 20 77 68 65 6e 20 74 68 65 20 63 6f 6e 73 74  d when the const
9e50: 72 61 69 6e 74 20 63 6f 75 6e 74 65 72 73 20 61  raint counters a
9e60: 72 65 20 7a 65 72 6f 2e 0a 23 0a 64 72 6f 70 5f  re zero..#.drop_
9e70: 61 6c 6c 5f 74 61 62 6c 65 73 0a 70 72 6f 63 20  all_tables.proc 
9e80: 65 78 65 63 73 71 6c 53 20 7b 7a 53 71 6c 7d 20  execsqlS {zSql} 
9e90: 7b 0a 20 20 73 65 74 20 3a 3a 73 71 6c 69 74 65  {.  set ::sqlite
9ea0: 5f 73 65 61 72 63 68 5f 63 6f 75 6e 74 20 30 0a  _search_count 0.
9eb0: 20 20 73 65 74 20 3a 3a 73 71 6c 69 74 65 5f 66    set ::sqlite_f
9ec0: 6f 75 6e 64 5f 63 6f 75 6e 74 20 30 0a 20 20 73  ound_count 0.  s
9ed0: 65 74 20 72 65 73 20 5b 75 70 6c 65 76 65 6c 20  et res [uplevel 
9ee0: 5b 6c 69 73 74 20 65 78 65 63 73 71 6c 20 24 7a  [list execsql $z
9ef0: 53 71 6c 5d 5d 0a 20 20 63 6f 6e 63 61 74 20 5b  Sql]].  concat [
9f00: 65 78 70 72 20 24 3a 3a 73 71 6c 69 74 65 5f 66  expr $::sqlite_f
9f10: 6f 75 6e 64 5f 63 6f 75 6e 74 20 2b 20 24 3a 3a  ound_count + $::
9f20: 73 71 6c 69 74 65 5f 73 65 61 72 63 68 5f 63 6f  sqlite_search_co
9f30: 75 6e 74 5d 20 24 72 65 73 0a 7d 0a 64 6f 5f 74  unt] $res.}.do_t
9f40: 65 73 74 20 66 6b 65 79 32 2d 31 35 2e 31 2e 31  est fkey2-15.1.1
9f50: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   {.  execsql {. 
9f60: 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20     CREATE TABLE 
9f70: 70 70 28 61 20 50 52 49 4d 41 52 59 20 4b 45 59  pp(a PRIMARY KEY
9f80: 2c 20 62 29 3b 0a 20 20 20 20 43 52 45 41 54 45  , b);.    CREATE
9f90: 20 54 41 42 4c 45 20 63 63 28 78 2c 20 79 20 52   TABLE cc(x, y R
9fa0: 45 46 45 52 45 4e 43 45 53 20 70 70 20 44 45 46  EFERENCES pp DEF
9fb0: 45 52 52 41 42 4c 45 20 49 4e 49 54 49 41 4c 4c  ERRABLE INITIALL
9fc0: 59 20 44 45 46 45 52 52 45 44 29 3b 0a 20 20 20  Y DEFERRED);.   
9fd0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 70 70 20   INSERT INTO pp 
9fe0: 56 41 4c 55 45 53 28 31 2c 20 27 6f 6e 65 27 29  VALUES(1, 'one')
9ff0: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
a000: 4f 20 70 70 20 56 41 4c 55 45 53 28 32 2c 20 27  O pp VALUES(2, '
a010: 74 77 6f 27 29 3b 0a 20 20 20 20 49 4e 53 45 52  two');.    INSER
a020: 54 20 49 4e 54 4f 20 63 63 20 56 41 4c 55 45 53  T INTO cc VALUES
a030: 28 27 6e 65 75 6e 67 27 2c 20 31 29 3b 0a 20 20  ('neung', 1);.  
a040: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 63 63    INSERT INTO cc
a050: 20 56 41 4c 55 45 53 28 27 73 6f 6e 67 27 2c 20   VALUES('song', 
a060: 32 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f  2);.  }.} {}.do_
a070: 74 65 73 74 20 66 6b 65 79 32 2d 31 35 2e 31 2e  test fkey2-15.1.
a080: 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 53 20 7b  2 {.  execsqlS {
a090: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 70 70 20   INSERT INTO pp 
a0a0: 56 41 4c 55 45 53 28 33 2c 20 27 74 68 72 65 65  VALUES(3, 'three
a0b0: 27 29 20 7d 0a 7d 20 7b 30 7d 0a 64 6f 5f 74 65  ') }.} {0}.do_te
a0c0: 73 74 20 66 6b 65 79 32 2d 31 35 2e 31 2e 33 20  st fkey2-15.1.3 
a0d0: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
a0e0: 20 20 42 45 47 49 4e 3b 0a 20 20 20 20 20 20 49    BEGIN;.      I
a0f0: 4e 53 45 52 54 20 49 4e 54 4f 20 63 63 20 56 41  NSERT INTO cc VA
a100: 4c 55 45 53 28 27 73 65 65 27 2c 20 34 29 3b 20  LUES('see', 4); 
a110: 20 20 20 2d 2d 20 56 69 6f 6c 61 74 65 73 20 64     -- Violates d
a120: 65 66 65 72 72 65 64 20 63 6f 6e 73 74 72 61 69  eferred constrai
a130: 6e 74 0a 20 20 7d 0a 20 20 65 78 65 63 73 71 6c  nt.  }.  execsql
a140: 53 20 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f 20  S { INSERT INTO 
a150: 70 70 20 56 41 4c 55 45 53 28 35 2c 20 27 66 69  pp VALUES(5, 'fi
a160: 76 65 27 29 20 7d 0a 7d 20 7b 32 7d 0a 64 6f 5f  ve') }.} {2}.do_
a170: 74 65 73 74 20 66 6b 65 79 32 2d 31 35 2e 31 2e  test fkey2-15.1.
a180: 34 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 20  4 {.  execsql { 
a190: 44 45 4c 45 54 45 20 46 52 4f 4d 20 63 63 20 57  DELETE FROM cc W
a1a0: 48 45 52 45 20 78 20 3d 20 27 73 65 65 27 20 7d  HERE x = 'see' }
a1b0: 0a 20 20 65 78 65 63 73 71 6c 53 20 7b 20 49 4e  .  execsqlS { IN
a1c0: 53 45 52 54 20 49 4e 54 4f 20 70 70 20 56 41 4c  SERT INTO pp VAL
a1d0: 55 45 53 28 36 2c 20 27 73 69 78 27 29 20 7d 0a  UES(6, 'six') }.
a1e0: 7d 20 7b 30 7d 0a 64 6f 5f 74 65 73 74 20 66 6b  } {0}.do_test fk
a1f0: 65 79 32 2d 31 35 2e 31 2e 35 20 7b 0a 20 20 65  ey2-15.1.5 {.  e
a200: 78 65 63 73 71 6c 20 43 4f 4d 4d 49 54 0a 7d 20  xecsql COMMIT.} 
a210: 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  {}.do_test fkey2
a220: 2d 31 35 2e 31 2e 36 20 7b 0a 20 20 65 78 65 63  -15.1.6 {.  exec
a230: 73 71 6c 20 42 45 47 49 4e 0a 20 20 65 78 65 63  sql BEGIN.  exec
a240: 73 71 6c 53 20 7b 0a 20 20 20 20 44 45 4c 45 54  sqlS {.    DELET
a250: 45 20 46 52 4f 4d 20 63 63 20 57 48 45 52 45 20  E FROM cc WHERE 
a260: 78 20 3d 20 27 6e 65 75 6e 67 27 3b 0a 20 20 20  x = 'neung';.   
a270: 20 52 4f 4c 4c 42 41 43 4b 3b 0a 20 20 7d 0a 7d   ROLLBACK;.  }.}
a280: 20 7b 31 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65   {1}.do_test fke
a290: 79 32 2d 31 35 2e 31 2e 37 20 7b 0a 20 20 65 78  y2-15.1.7 {.  ex
a2a0: 65 63 73 71 6c 20 7b 20 0a 20 20 20 20 42 45 47  ecsql { .    BEG
a2b0: 49 4e 3b 0a 20 20 20 20 44 45 4c 45 54 45 20 46  IN;.    DELETE F
a2c0: 52 4f 4d 20 70 70 20 57 48 45 52 45 20 61 20 3d  ROM pp WHERE a =
a2d0: 20 32 3b 0a 20 20 7d 0a 20 20 65 78 65 63 73 71   2;.  }.  execsq
a2e0: 6c 53 20 7b 0a 20 20 20 20 44 45 4c 45 54 45 20  lS {.    DELETE 
a2f0: 46 52 4f 4d 20 63 63 20 57 48 45 52 45 20 78 20  FROM cc WHERE x 
a300: 3d 20 27 6e 65 75 6e 67 27 3b 0a 20 20 20 20 52  = 'neung';.    R
a310: 4f 4c 4c 42 41 43 4b 3b 0a 20 20 7d 0a 7d 20 7b  OLLBACK;.  }.} {
a320: 32 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  2}..#-----------
a330: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
a340: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
a350: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
a360: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23  --------------.#
a370: 20 54 68 69 73 20 6e 65 78 74 20 62 6c 6f 63 6b   This next block
a380: 20 6f 66 20 74 65 73 74 73 2c 20 66 6b 65 79 32   of tests, fkey2
a390: 2d 31 36 2e 2a 2c 20 74 65 73 74 20 74 68 61 74  -16.*, test that
a3a0: 20 72 6f 77 73 20 74 68 61 74 20 72 65 66 65 72   rows that refer
a3b0: 20 74 6f 0a 23 20 74 68 65 6d 73 65 6c 76 65 73   to.# themselves
a3c0: 20 6d 61 79 20 62 65 20 69 6e 73 65 72 74 65 64   may be inserted
a3d0: 20 61 6e 64 20 64 65 6c 65 74 65 64 2e 0a 23 0a   and deleted..#.
a3e0: 66 6f 72 65 61 63 68 20 7b 74 6e 20 7a 53 63 68  foreach {tn zSch
a3f0: 65 6d 61 7d 20 7b 0a 20 20 31 20 7b 20 43 52 45  ema} {.  1 { CRE
a400: 41 54 45 20 54 41 42 4c 45 20 73 65 6c 66 28 61  ATE TABLE self(a
a410: 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59   INTEGER PRIMARY
a420: 20 4b 45 59 2c 20 62 20 52 45 46 45 52 45 4e 43   KEY, b REFERENC
a430: 45 53 20 73 65 6c 66 28 61 29 29 20 7d 0a 20 20  ES self(a)) }.  
a440: 32 20 7b 20 43 52 45 41 54 45 20 54 41 42 4c 45  2 { CREATE TABLE
a450: 20 73 65 6c 66 28 61 20 50 52 49 4d 41 52 59 20   self(a PRIMARY 
a460: 4b 45 59 2c 20 62 20 52 45 46 45 52 45 4e 43 45  KEY, b REFERENCE
a470: 53 20 73 65 6c 66 28 61 29 29 20 7d 0a 20 20 33  S self(a)) }.  3
a480: 20 7b 20 43 52 45 41 54 45 20 54 41 42 4c 45 20   { CREATE TABLE 
a490: 73 65 6c 66 28 61 20 55 4e 49 51 55 45 2c 20 62  self(a UNIQUE, b
a4a0: 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59   INTEGER PRIMARY
a4b0: 20 4b 45 59 20 52 45 46 45 52 45 4e 43 45 53 20   KEY REFERENCES 
a4c0: 73 65 6c 66 28 61 29 29 20 7d 0a 7d 20 7b 0a 20  self(a)) }.} {. 
a4d0: 20 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65 73   drop_all_tables
a4e0: 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  .  do_test fkey2
a4f0: 2d 31 36 2e 31 2e 24 74 6e 2e 31 20 7b 0a 20 20  -16.1.$tn.1 {.  
a500: 20 20 65 78 65 63 73 71 6c 20 24 7a 53 63 68 65    execsql $zSche
a510: 6d 61 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b  ma.    execsql {
a520: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 73 65 6c   INSERT INTO sel
a530: 66 20 56 41 4c 55 45 53 28 31 33 2c 20 31 33 29  f VALUES(13, 13)
a540: 20 7d 0a 20 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74   }.  } {}.  do_t
a550: 65 73 74 20 66 6b 65 79 32 2d 31 36 2e 31 2e 24  est fkey2-16.1.$
a560: 74 6e 2e 32 20 7b 0a 20 20 20 20 65 78 65 63 73  tn.2 {.    execs
a570: 71 6c 20 7b 20 55 50 44 41 54 45 20 73 65 6c 66  ql { UPDATE self
a580: 20 53 45 54 20 61 20 3d 20 31 34 2c 20 62 20 3d   SET a = 14, b =
a590: 20 31 34 20 7d 0a 20 20 7d 20 7b 7d 0a 0a 20 20   14 }.  } {}..  
a5a0: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 36  do_test fkey2-16
a5b0: 2e 31 2e 24 74 6e 2e 33 20 7b 0a 20 20 20 20 63  .1.$tn.3 {.    c
a5c0: 61 74 63 68 73 71 6c 20 7b 20 55 50 44 41 54 45  atchsql { UPDATE
a5d0: 20 73 65 6c 66 20 53 45 54 20 62 20 3d 20 31 35   self SET b = 15
a5e0: 20 7d 0a 20 20 7d 20 7b 31 20 7b 66 6f 72 65 69   }.  } {1 {forei
a5f0: 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e  gn key constrain
a600: 74 20 66 61 69 6c 65 64 7d 7d 0a 0a 20 20 64 6f  t failed}}..  do
a610: 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 36 2e 31  _test fkey2-16.1
a620: 2e 24 74 6e 2e 34 20 7b 0a 20 20 20 20 63 61 74  .$tn.4 {.    cat
a630: 63 68 73 71 6c 20 7b 20 55 50 44 41 54 45 20 73  chsql { UPDATE s
a640: 65 6c 66 20 53 45 54 20 61 20 3d 20 31 35 20 7d  elf SET a = 15 }
a650: 0a 20 20 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e  .  } {1 {foreign
a660: 20 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e 74 20   key constraint 
a670: 66 61 69 6c 65 64 7d 7d 0a 0a 20 20 64 6f 5f 74  failed}}..  do_t
a680: 65 73 74 20 66 6b 65 79 32 2d 31 36 2e 31 2e 24  est fkey2-16.1.$
a690: 74 6e 2e 35 20 7b 0a 20 20 20 20 63 61 74 63 68  tn.5 {.    catch
a6a0: 73 71 6c 20 7b 20 55 50 44 41 54 45 20 73 65 6c  sql { UPDATE sel
a6b0: 66 20 53 45 54 20 61 20 3d 20 31 35 2c 20 62 20  f SET a = 15, b 
a6c0: 3d 20 31 36 20 7d 0a 20 20 7d 20 7b 31 20 7b 66  = 16 }.  } {1 {f
a6d0: 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73 74  oreign key const
a6e0: 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 0a  raint failed}}..
a6f0: 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d    do_test fkey2-
a700: 31 36 2e 31 2e 24 74 6e 2e 36 20 7b 0a 20 20 20  16.1.$tn.6 {.   
a710: 20 63 61 74 63 68 73 71 6c 20 7b 20 55 50 44 41   catchsql { UPDA
a720: 54 45 20 73 65 6c 66 20 53 45 54 20 61 20 3d 20  TE self SET a = 
a730: 31 37 2c 20 62 20 3d 20 31 37 20 7d 0a 20 20 7d  17, b = 17 }.  }
a740: 20 7b 30 20 7b 7d 7d 0a 0a 20 20 64 6f 5f 74 65   {0 {}}..  do_te
a750: 73 74 20 66 6b 65 79 32 2d 31 36 2e 31 2e 24 74  st fkey2-16.1.$t
a760: 6e 2e 37 20 7b 0a 20 20 20 20 65 78 65 63 73 71  n.7 {.    execsq
a770: 6c 20 7b 20 44 45 4c 45 54 45 20 46 52 4f 4d 20  l { DELETE FROM 
a780: 73 65 6c 66 20 7d 0a 20 20 7d 20 7b 7d 0a 20 20  self }.  } {}.  
a790: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 36  do_test fkey2-16
a7a0: 2e 31 2e 24 74 6e 2e 38 20 7b 0a 20 20 20 20 63  .1.$tn.8 {.    c
a7b0: 61 74 63 68 73 71 6c 20 7b 20 49 4e 53 45 52 54  atchsql { INSERT
a7c0: 20 49 4e 54 4f 20 73 65 6c 66 20 56 41 4c 55 45   INTO self VALUE
a7d0: 53 28 32 30 2c 20 32 31 29 20 7d 0a 20 20 7d 20  S(20, 21) }.  } 
a7e0: 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65 79 20  {1 {foreign key 
a7f0: 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65  constraint faile
a800: 64 7d 7d 0a 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d  d}}.}..#--------
a810: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
a820: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
a830: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
a840: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
a850: 2d 0a 23 20 54 68 69 73 20 6e 65 78 74 20 62 6c  -.# This next bl
a860: 6f 63 6b 20 6f 66 20 74 65 73 74 73 2c 20 66 6b  ock of tests, fk
a870: 65 79 32 2d 31 37 2e 2a 2c 20 74 65 73 74 73 20  ey2-17.*, tests 
a880: 74 68 61 74 20 69 66 20 22 50 52 41 47 4d 41 20  that if "PRAGMA 
a890: 63 6f 75 6e 74 5f 63 68 61 6e 67 65 73 22 0a 23  count_changes".#
a8a0: 20 69 73 20 74 75 72 6e 65 64 20 6f 6e 20 73 74   is turned on st
a8b0: 61 74 65 6d 65 6e 74 73 20 74 68 61 74 20 76 69  atements that vi
a8c0: 6f 6c 61 74 65 20 69 6d 6d 65 64 69 61 74 65 20  olate immediate 
a8d0: 46 4b 20 63 6f 6e 73 74 72 61 69 6e 74 73 20 72  FK constraints r
a8e0: 65 74 75 72 6e 0a 23 20 53 51 4c 49 54 45 5f 43  eturn.# SQLITE_C
a8f0: 4f 4e 53 54 52 41 49 4e 54 20 69 6d 6d 65 64 69  ONSTRAINT immedi
a900: 61 74 65 6c 79 2c 20 6e 6f 74 20 61 66 74 65 72  ately, not after
a910: 20 72 65 74 75 72 6e 69 6e 67 20 61 20 6e 75 6d   returning a num
a920: 62 65 72 20 6f 66 20 72 6f 77 73 2e 0a 23 20 57  ber of rows..# W
a930: 68 65 72 65 61 73 20 73 74 61 74 65 6d 65 6e 74  hereas statement
a940: 73 20 74 68 61 74 20 76 69 6f 6c 61 74 65 20 64  s that violate d
a950: 65 66 65 72 72 65 64 20 46 4b 20 63 6f 6e 73 74  eferred FK const
a960: 72 61 69 6e 74 73 20 72 65 74 75 72 6e 20 74 68  raints return th
a970: 65 20 6e 75 6d 62 65 72 0a 23 20 6f 66 20 72 6f  e number.# of ro
a980: 77 73 20 62 65 66 6f 72 65 20 66 61 69 6c 69 6e  ws before failin
a990: 67 2e 0a 23 0a 23 20 41 6c 73 6f 20 74 65 73 74  g..#.# Also test
a9a0: 20 74 68 61 74 20 72 6f 77 73 20 6d 6f 64 69 66   that rows modif
a9b0: 69 65 64 20 62 79 20 46 4b 20 61 63 74 69 6f 6e  ied by FK action
a9c0: 73 20 61 72 65 20 6e 6f 74 20 63 6f 75 6e 74 65  s are not counte
a9d0: 64 20 69 6e 20 65 69 74 68 65 72 20 74 68 65 0a  d in either the.
a9e0: 23 20 72 65 74 75 72 6e 65 64 20 72 6f 77 20 63  # returned row c
a9f0: 6f 75 6e 74 20 6f 72 20 74 68 65 20 76 61 6c 75  ount or the valu
aa00: 65 73 20 72 65 74 75 72 6e 65 64 20 62 79 20 73  es returned by s
aa10: 71 6c 69 74 65 33 5f 63 68 61 6e 67 65 73 28 29  qlite3_changes()
aa20: 2e 20 4c 69 6b 65 0a 23 20 74 72 69 67 67 65 72  . Like.# trigger
aa30: 20 72 65 6c 61 74 65 64 20 63 68 61 6e 67 65 73   related changes
aa40: 2c 20 74 68 65 79 20 61 72 65 20 69 6e 63 6c 75  , they are inclu
aa50: 64 65 64 20 69 6e 20 73 71 6c 69 74 65 33 5f 74  ded in sqlite3_t
aa60: 6f 74 61 6c 5f 63 68 61 6e 67 65 73 28 29 20 74  otal_changes() t
aa70: 68 6f 75 67 68 2e 0a 23 0a 64 72 6f 70 5f 61 6c  hough..#.drop_al
aa80: 6c 5f 74 61 62 6c 65 73 0a 64 6f 5f 74 65 73 74  l_tables.do_test
aa90: 20 66 6b 65 79 32 2d 31 37 2e 31 2e 31 20 7b 0a   fkey2-17.1.1 {.
aaa0: 20 20 65 78 65 63 73 71 6c 20 7b 20 50 52 41 47    execsql { PRAG
aab0: 4d 41 20 63 6f 75 6e 74 5f 63 68 61 6e 67 65 73  MA count_changes
aac0: 20 3d 20 31 20 7d 0a 20 20 65 78 65 63 73 71 6c   = 1 }.  execsql
aad0: 20 7b 20 0a 20 20 20 20 43 52 45 41 54 45 20 54   { .    CREATE T
aae0: 41 42 4c 45 20 6f 6e 65 28 61 2c 20 62 2c 20 63  ABLE one(a, b, c
aaf0: 2c 20 55 4e 49 51 55 45 28 62 2c 20 63 29 29 3b  , UNIQUE(b, c));
ab00: 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  .    CREATE TABL
ab10: 45 20 74 77 6f 28 64 2c 20 65 2c 20 66 2c 20 46  E two(d, e, f, F
ab20: 4f 52 45 49 47 4e 20 4b 45 59 28 65 2c 20 66 29  OREIGN KEY(e, f)
ab30: 20 52 45 46 45 52 45 4e 43 45 53 20 6f 6e 65 28   REFERENCES one(
ab40: 62 2c 20 63 29 29 3b 0a 20 20 20 20 49 4e 53 45  b, c));.    INSE
ab50: 52 54 20 49 4e 54 4f 20 6f 6e 65 20 56 41 4c 55  RT INTO one VALU
ab60: 45 53 28 31 2c 20 32 2c 20 33 29 3b 0a 20 20 7d  ES(1, 2, 3);.  }
ab70: 0a 7d 20 7b 31 7d 0a 64 6f 5f 74 65 73 74 20 66  .} {1}.do_test f
ab80: 6b 65 79 32 2d 31 37 2e 31 2e 32 20 7b 0a 20 20  key2-17.1.2 {.  
ab90: 73 65 74 20 53 54 4d 54 20 5b 73 71 6c 69 74 65  set STMT [sqlite
aba0: 33 5f 70 72 65 70 61 72 65 5f 76 32 20 64 62 20  3_prepare_v2 db 
abb0: 22 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 77 6f  "INSERT INTO two
abc0: 20 56 41 4c 55 45 53 28 34 2c 20 35 2c 20 36 29   VALUES(4, 5, 6)
abd0: 22 20 2d 31 20 64 75 6d 6d 79 5d 0a 20 20 73 71  " -1 dummy].  sq
abe0: 6c 69 74 65 33 5f 73 74 65 70 20 24 53 54 4d 54  lite3_step $STMT
abf0: 0a 7d 20 7b 53 51 4c 49 54 45 5f 43 4f 4e 53 54  .} {SQLITE_CONST
ac00: 52 41 49 4e 54 7d 0a 69 66 63 61 70 61 62 6c 65  RAINT}.ifcapable
ac10: 20 61 75 74 6f 72 65 73 65 74 20 7b 0a 20 20 64   autoreset {.  d
ac20: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 37 2e  o_test fkey2-17.
ac30: 31 2e 33 20 7b 0a 20 20 20 20 73 71 6c 69 74 65  1.3 {.    sqlite
ac40: 33 5f 73 74 65 70 20 24 53 54 4d 54 0a 20 20 7d  3_step $STMT.  }
ac50: 20 7b 53 51 4c 49 54 45 5f 43 4f 4e 53 54 52 41   {SQLITE_CONSTRA
ac60: 49 4e 54 7d 0a 7d 20 65 6c 73 65 20 7b 0a 20 20  INT}.} else {.  
ac70: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 37  do_test fkey2-17
ac80: 2e 31 2e 33 20 7b 0a 20 20 20 20 73 71 6c 69 74  .1.3 {.    sqlit
ac90: 65 33 5f 73 74 65 70 20 24 53 54 4d 54 0a 20 20  e3_step $STMT.  
aca0: 7d 20 7b 53 51 4c 49 54 45 5f 4d 49 53 55 53 45  } {SQLITE_MISUSE
acb0: 7d 0a 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79  }.}.do_test fkey
acc0: 32 2d 31 37 2e 31 2e 34 20 7b 0a 20 20 73 71 6c  2-17.1.4 {.  sql
acd0: 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 20 24 53  ite3_finalize $S
ace0: 54 4d 54 0a 7d 20 7b 53 51 4c 49 54 45 5f 43 4f  TMT.} {SQLITE_CO
acf0: 4e 53 54 52 41 49 4e 54 7d 0a 64 6f 5f 74 65 73  NSTRAINT}.do_tes
ad00: 74 20 66 6b 65 79 32 2d 31 37 2e 31 2e 35 20 7b  t fkey2-17.1.5 {
ad10: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
ad20: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 6f 6e 65   INSERT INTO one
ad30: 20 56 41 4c 55 45 53 28 32 2c 20 33 2c 20 34 29   VALUES(2, 3, 4)
ad40: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
ad50: 4f 20 6f 6e 65 20 56 41 4c 55 45 53 28 33 2c 20  O one VALUES(3, 
ad60: 34 2c 20 35 29 3b 0a 20 20 20 20 49 4e 53 45 52  4, 5);.    INSER
ad70: 54 20 49 4e 54 4f 20 74 77 6f 20 56 41 4c 55 45  T INTO two VALUE
ad80: 53 28 31 2c 20 32 2c 20 33 29 3b 0a 20 20 20 20  S(1, 2, 3);.    
ad90: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 77 6f 20  INSERT INTO two 
ada0: 56 41 4c 55 45 53 28 32 2c 20 33 2c 20 34 29 3b  VALUES(2, 3, 4);
adb0: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
adc0: 20 74 77 6f 20 56 41 4c 55 45 53 28 33 2c 20 34   two VALUES(3, 4
add0: 2c 20 35 29 3b 0a 20 20 7d 0a 7d 20 7b 31 20 31  , 5);.  }.} {1 1
ade0: 20 31 20 31 20 31 7d 0a 64 6f 5f 74 65 73 74 20   1 1 1}.do_test 
adf0: 66 6b 65 79 32 2d 31 37 2e 31 2e 36 20 7b 0a 20  fkey2-17.1.6 {. 
ae00: 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20   catchsql {.    
ae10: 42 45 47 49 4e 3b 0a 20 20 20 20 20 20 49 4e 53  BEGIN;.      INS
ae20: 45 52 54 20 49 4e 54 4f 20 6f 6e 65 20 56 41 4c  ERT INTO one VAL
ae30: 55 45 53 28 30 2c 20 30 2c 20 30 29 3b 0a 20 20  UES(0, 0, 0);.  
ae40: 20 20 20 20 55 50 44 41 54 45 20 74 77 6f 20 53      UPDATE two S
ae50: 45 54 20 65 3d 65 2b 31 2c 20 66 3d 66 2b 31 3b  ET e=e+1, f=f+1;
ae60: 0a 20 20 7d 0a 7d 20 7b 31 20 7b 66 6f 72 65 69  .  }.} {1 {forei
ae70: 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e  gn key constrain
ae80: 74 20 66 61 69 6c 65 64 7d 7d 0a 64 6f 5f 74 65  t failed}}.do_te
ae90: 73 74 20 66 6b 65 79 32 2d 31 37 2e 31 2e 37 20  st fkey2-17.1.7 
aea0: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 53 45  {.  execsql { SE
aeb0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 6f 6e 65 20  LECT * FROM one 
aec0: 7d 0a 7d 20 7b 31 20 32 20 33 20 32 20 33 20 34  }.} {1 2 3 2 3 4
aed0: 20 33 20 34 20 35 20 30 20 30 20 30 7d 0a 64 6f   3 4 5 0 0 0}.do
aee0: 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 37 2e 31  _test fkey2-17.1
aef0: 2e 38 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .8 {.  execsql {
af00: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
af10: 77 6f 20 7d 0a 7d 20 7b 31 20 32 20 33 20 32 20  wo }.} {1 2 3 2 
af20: 33 20 34 20 33 20 34 20 35 7d 0a 64 6f 5f 74 65  3 4 3 4 5}.do_te
af30: 73 74 20 66 6b 65 79 32 2d 31 37 2e 31 2e 39 20  st fkey2-17.1.9 
af40: 7b 0a 20 20 65 78 65 63 73 71 6c 20 43 4f 4d 4d  {.  execsql COMM
af50: 49 54 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20  IT.} {}.do_test 
af60: 66 6b 65 79 32 2d 31 37 2e 31 2e 31 30 20 7b 0a  fkey2-17.1.10 {.
af70: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
af80: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 68 72  CREATE TABLE thr
af90: 65 65 28 0a 20 20 20 20 20 20 67 2c 20 68 2c 20  ee(.      g, h, 
afa0: 69 2c 20 0a 20 20 20 20 20 20 46 4f 52 45 49 47  i, .      FOREIG
afb0: 4e 20 4b 45 59 28 68 2c 20 69 29 20 52 45 46 45  N KEY(h, i) REFE
afc0: 52 45 4e 43 45 53 20 6f 6e 65 28 62 2c 20 63 29  RENCES one(b, c)
afd0: 20 44 45 46 45 52 52 41 42 4c 45 20 49 4e 49 54   DEFERRABLE INIT
afe0: 49 41 4c 4c 59 20 44 45 46 45 52 52 45 44 0a 20  IALLY DEFERRED. 
aff0: 20 20 20 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64     );.  }.} {}.d
b000: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 37 2e  o_test fkey2-17.
b010: 31 2e 31 31 20 7b 0a 20 20 73 65 74 20 53 54 4d  1.11 {.  set STM
b020: 54 20 5b 73 71 6c 69 74 65 33 5f 70 72 65 70 61  T [sqlite3_prepa
b030: 72 65 5f 76 32 20 64 62 20 22 49 4e 53 45 52 54  re_v2 db "INSERT
b040: 20 49 4e 54 4f 20 74 68 72 65 65 20 56 41 4c 55   INTO three VALU
b050: 45 53 28 37 2c 20 38 2c 20 39 29 22 20 2d 31 20  ES(7, 8, 9)" -1 
b060: 64 75 6d 6d 79 5d 0a 20 20 73 71 6c 69 74 65 33  dummy].  sqlite3
b070: 5f 73 74 65 70 20 24 53 54 4d 54 0a 7d 20 7b 53  _step $STMT.} {S
b080: 51 4c 49 54 45 5f 52 4f 57 7d 0a 64 6f 5f 74 65  QLITE_ROW}.do_te
b090: 73 74 20 66 6b 65 79 32 2d 31 37 2e 31 2e 31 32  st fkey2-17.1.12
b0a0: 20 7b 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c   {.  sqlite3_col
b0b0: 75 6d 6e 5f 74 65 78 74 20 24 53 54 4d 54 20 30  umn_text $STMT 0
b0c0: 0a 7d 20 7b 31 7d 0a 64 6f 5f 74 65 73 74 20 66  .} {1}.do_test f
b0d0: 6b 65 79 32 2d 31 37 2e 31 2e 31 33 20 7b 0a 20  key2-17.1.13 {. 
b0e0: 20 73 71 6c 69 74 65 33 5f 73 74 65 70 20 24 53   sqlite3_step $S
b0f0: 54 4d 54 0a 7d 20 7b 53 51 4c 49 54 45 5f 43 4f  TMT.} {SQLITE_CO
b100: 4e 53 54 52 41 49 4e 54 7d 0a 64 6f 5f 74 65 73  NSTRAINT}.do_tes
b110: 74 20 66 6b 65 79 32 2d 31 37 2e 31 2e 31 34 20  t fkey2-17.1.14 
b120: 7b 0a 20 20 73 71 6c 69 74 65 33 5f 66 69 6e 61  {.  sqlite3_fina
b130: 6c 69 7a 65 20 24 53 54 4d 54 0a 7d 20 7b 53 51  lize $STMT.} {SQ
b140: 4c 49 54 45 5f 43 4f 4e 53 54 52 41 49 4e 54 7d  LITE_CONSTRAINT}
b150: 0a 0a 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65  ..drop_all_table
b160: 73 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d  s.do_test fkey2-
b170: 31 37 2e 32 2e 31 20 7b 0a 20 20 65 78 65 63 73  17.2.1 {.  execs
b180: 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  ql {.    CREATE 
b190: 54 41 42 4c 45 20 68 69 67 68 28 22 61 27 62 21  TABLE high("a'b!
b1a0: 22 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62  " PRIMARY KEY, b
b1b0: 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41  );.    CREATE TA
b1c0: 42 4c 45 20 6c 6f 77 28 0a 20 20 20 20 20 20 63  BLE low(.      c
b1d0: 2c 20 0a 20 20 20 20 20 20 22 64 26 36 22 20 52  , .      "d&6" R
b1e0: 45 46 45 52 45 4e 43 45 53 20 68 69 67 68 20 4f  EFERENCES high O
b1f0: 4e 20 55 50 44 41 54 45 20 43 41 53 43 41 44 45  N UPDATE CASCADE
b200: 20 4f 4e 20 44 45 4c 45 54 45 20 43 41 53 43 41   ON DELETE CASCA
b210: 44 45 0a 20 20 20 20 29 3b 0a 20 20 7d 0a 7d 20  DE.    );.  }.} 
b220: 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  {}.do_test fkey2
b230: 2d 31 37 2e 32 2e 32 20 7b 0a 20 20 65 78 65 63  -17.2.2 {.  exec
b240: 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52 54  sql {.    INSERT
b250: 20 49 4e 54 4f 20 68 69 67 68 20 56 41 4c 55 45   INTO high VALUE
b260: 53 28 27 61 27 2c 20 27 62 27 29 3b 0a 20 20 20  S('a', 'b');.   
b270: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 6c 6f 77   INSERT INTO low
b280: 20 56 41 4c 55 45 53 28 27 62 27 2c 20 27 61 27   VALUES('b', 'a'
b290: 29 3b 0a 20 20 7d 0a 20 20 64 62 20 63 68 61 6e  );.  }.  db chan
b2a0: 67 65 73 0a 7d 20 7b 31 7d 0a 73 65 74 20 6e 54  ges.} {1}.set nT
b2b0: 6f 74 61 6c 20 5b 64 62 20 74 6f 74 61 6c 5f 63  otal [db total_c
b2c0: 68 61 6e 67 65 73 5d 0a 64 6f 5f 74 65 73 74 20  hanges].do_test 
b2d0: 66 6b 65 79 32 2d 31 37 2e 32 2e 33 20 7b 0a 20  fkey2-17.2.3 {. 
b2e0: 20 65 78 65 63 73 71 6c 20 7b 20 55 50 44 41 54   execsql { UPDAT
b2f0: 45 20 68 69 67 68 20 53 45 54 20 22 61 27 62 21  E high SET "a'b!
b300: 22 20 3d 20 27 63 27 20 7d 0a 7d 20 7b 31 7d 0a  " = 'c' }.} {1}.
b310: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 37  do_test fkey2-17
b320: 2e 32 2e 34 20 7b 0a 20 20 64 62 20 63 68 61 6e  .2.4 {.  db chan
b330: 67 65 73 0a 7d 20 7b 31 7d 0a 64 6f 5f 74 65 73  ges.} {1}.do_tes
b340: 74 20 66 6b 65 79 32 2d 31 37 2e 32 2e 35 20 7b  t fkey2-17.2.5 {
b350: 0a 20 20 65 78 70 72 20 5b 64 62 20 74 6f 74 61  .  expr [db tota
b360: 6c 5f 63 68 61 6e 67 65 73 5d 20 2d 20 24 6e 54  l_changes] - $nT
b370: 6f 74 61 6c 0a 7d 20 7b 32 7d 0a 64 6f 5f 74 65  otal.} {2}.do_te
b380: 73 74 20 66 6b 65 79 32 2d 31 37 2e 32 2e 36 20  st fkey2-17.2.6 
b390: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 53 45  {.  execsql { SE
b3a0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 68 69 67 68  LECT * FROM high
b3b0: 20 3b 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d   ; SELECT * FROM
b3c0: 20 6c 6f 77 20 7d 0a 7d 20 7b 63 20 62 20 62 20   low }.} {c b b 
b3d0: 63 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  c}.do_test fkey2
b3e0: 2d 31 37 2e 32 2e 37 20 7b 0a 20 20 65 78 65 63  -17.2.7 {.  exec
b3f0: 73 71 6c 20 7b 20 44 45 4c 45 54 45 20 46 52 4f  sql { DELETE FRO
b400: 4d 20 68 69 67 68 20 7d 0a 7d 20 7b 31 7d 0a 64  M high }.} {1}.d
b410: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 37 2e  o_test fkey2-17.
b420: 32 2e 38 20 7b 0a 20 20 64 62 20 63 68 61 6e 67  2.8 {.  db chang
b430: 65 73 0a 7d 20 7b 31 7d 0a 64 6f 5f 74 65 73 74  es.} {1}.do_test
b440: 20 66 6b 65 79 32 2d 31 37 2e 32 2e 39 20 7b 0a   fkey2-17.2.9 {.
b450: 20 20 65 78 70 72 20 5b 64 62 20 74 6f 74 61 6c    expr [db total
b460: 5f 63 68 61 6e 67 65 73 5d 20 2d 20 24 6e 54 6f  _changes] - $nTo
b470: 74 61 6c 0a 7d 20 7b 34 7d 0a 64 6f 5f 74 65 73  tal.} {4}.do_tes
b480: 74 20 66 6b 65 79 32 2d 31 37 2e 32 2e 31 30 20  t fkey2-17.2.10 
b490: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 53 45  {.  execsql { SE
b4a0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 68 69 67 68  LECT * FROM high
b4b0: 20 3b 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d   ; SELECT * FROM
b4c0: 20 6c 6f 77 20 7d 0a 7d 20 7b 7d 0a 65 78 65 63   low }.} {}.exec
b4d0: 73 71 6c 20 7b 20 50 52 41 47 4d 41 20 63 6f 75  sql { PRAGMA cou
b4e0: 6e 74 5f 63 68 61 6e 67 65 73 20 3d 20 30 20 7d  nt_changes = 0 }
b4f0: 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ..#-------------
b500: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
b510: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
b520: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
b530: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 54  ------------.# T
b540: 65 73 74 20 74 68 61 74 20 74 68 65 20 61 75 74  est that the aut
b550: 68 6f 72 69 7a 61 74 69 6f 6e 20 63 61 6c 6c 62  horization callb
b560: 61 63 6b 20 77 6f 72 6b 73 2e 0a 23 0a 0a 69 66  ack works..#..if
b570: 63 61 70 61 62 6c 65 20 61 75 74 68 20 7b 0a 20  capable auth {. 
b580: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 31   do_test fkey2-1
b590: 38 2e 31 20 7b 0a 20 20 20 20 65 78 65 63 73 71  8.1 {.    execsq
b5a0: 6c 20 7b 0a 20 20 20 20 20 20 43 52 45 41 54 45  l {.      CREATE
b5b0: 20 54 41 42 4c 45 20 6c 6f 6e 67 28 61 2c 20 62   TABLE long(a, b
b5c0: 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 63 29   PRIMARY KEY, c)
b5d0: 3b 0a 20 20 20 20 20 20 43 52 45 41 54 45 20 54  ;.      CREATE T
b5e0: 41 42 4c 45 20 73 68 6f 72 74 28 64 2c 20 65 2c  ABLE short(d, e,
b5f0: 20 66 20 52 45 46 45 52 45 4e 43 45 53 20 6c 6f   f REFERENCES lo
b600: 6e 67 29 3b 0a 20 20 20 20 20 20 43 52 45 41 54  ng);.      CREAT
b610: 45 20 54 41 42 4c 45 20 6d 69 64 28 67 2c 20 68  E TABLE mid(g, h
b620: 2c 20 69 20 52 45 46 45 52 45 4e 43 45 53 20 6c  , i REFERENCES l
b630: 6f 6e 67 20 44 45 46 45 52 52 41 42 4c 45 20 49  ong DEFERRABLE I
b640: 4e 49 54 49 41 4c 4c 59 20 44 45 46 45 52 52 45  NITIALLY DEFERRE
b650: 44 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 7d  D);.    }.  } {}
b660: 0a 0a 20 20 70 72 6f 63 20 61 75 74 68 20 7b 61  ..  proc auth {a
b670: 72 67 73 7d 20 7b 65 76 61 6c 20 6c 61 70 70 65  rgs} {eval lappe
b680: 6e 64 20 3a 3a 61 75 74 68 61 72 67 73 20 24 61  nd ::authargs $a
b690: 72 67 73 20 3b 20 72 65 74 75 72 6e 20 53 51 4c  rgs ; return SQL
b6a0: 49 54 45 5f 4f 4b 7d 0a 20 20 64 62 20 61 75 74  ITE_OK}.  db aut
b6b0: 68 20 61 75 74 68 0a 0a 20 20 23 20 41 6e 20 69  h auth..  # An i
b6c0: 6e 73 65 72 74 20 6f 6e 20 74 68 65 20 70 61 72  nsert on the par
b6d0: 65 6e 74 20 74 61 62 6c 65 20 6d 75 73 74 20 72  ent table must r
b6e0: 65 61 64 20 74 68 65 20 63 68 69 6c 64 20 6b 65  ead the child ke
b6f0: 79 20 6f 66 20 61 6e 79 20 64 65 66 65 72 72 65  y of any deferre
b700: 64 0a 20 20 23 20 66 6f 72 65 69 67 6e 20 6b 65  d.  # foreign ke
b710: 79 20 63 6f 6e 73 74 72 61 69 6e 74 73 2e 20 42  y constraints. B
b720: 75 74 20 6e 6f 74 20 74 68 65 20 63 68 69 6c 64  ut not the child
b730: 20 6b 65 79 20 6f 66 20 69 6d 6d 65 64 69 61 74   key of immediat
b740: 65 20 63 6f 6e 73 74 72 61 69 6e 74 73 2e 0a 20  e constraints.. 
b750: 20 73 65 74 20 61 75 74 68 61 72 67 73 20 7b 7d   set authargs {}
b760: 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  .  do_test fkey2
b770: 2d 31 38 2e 32 20 7b 0a 20 20 20 20 65 78 65 63  -18.2 {.    exec
b780: 73 71 6c 20 7b 20 49 4e 53 45 52 54 20 49 4e 54  sql { INSERT INT
b790: 4f 20 6c 6f 6e 67 20 56 41 4c 55 45 53 28 31 2c  O long VALUES(1,
b7a0: 20 32 2c 20 33 29 20 7d 0a 20 20 20 20 73 65 74   2, 3) }.    set
b7b0: 20 61 75 74 68 61 72 67 73 0a 20 20 7d 20 7b 53   authargs.  } {S
b7c0: 51 4c 49 54 45 5f 49 4e 53 45 52 54 20 6c 6f 6e  QLITE_INSERT lon
b7d0: 67 20 7b 7d 20 6d 61 69 6e 20 7b 7d 20 53 51 4c  g {} main {} SQL
b7e0: 49 54 45 5f 52 45 41 44 20 6d 69 64 20 69 20 6d  ITE_READ mid i m
b7f0: 61 69 6e 20 7b 7d 7d 0a 0a 20 20 23 20 41 6e 20  ain {}}..  # An 
b800: 69 6e 73 65 72 74 20 6f 6e 20 74 68 65 20 63 68  insert on the ch
b810: 69 6c 64 20 74 61 62 6c 65 20 6f 66 20 61 6e 20  ild table of an 
b820: 69 6d 6d 65 64 69 61 74 65 20 63 6f 6e 73 74 72  immediate constr
b830: 61 69 6e 74 20 6d 75 73 74 20 72 65 61 64 20 74  aint must read t
b840: 68 65 0a 20 20 23 20 70 61 72 65 6e 74 20 6b 65  he.  # parent ke
b850: 79 20 63 6f 6c 75 6d 6e 73 20 28 74 6f 20 73 65  y columns (to se
b860: 65 20 69 66 20 69 74 20 69 73 20 61 20 76 69 6f  e if it is a vio
b870: 6c 61 74 69 6f 6e 20 6f 72 20 6e 6f 74 29 2e 0a  lation or not)..
b880: 20 20 73 65 74 20 61 75 74 68 61 72 67 73 20 7b    set authargs {
b890: 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79  }.  do_test fkey
b8a0: 32 2d 31 38 2e 33 20 7b 0a 20 20 20 20 65 78 65  2-18.3 {.    exe
b8b0: 63 73 71 6c 20 7b 20 49 4e 53 45 52 54 20 49 4e  csql { INSERT IN
b8c0: 54 4f 20 73 68 6f 72 74 20 56 41 4c 55 45 53 28  TO short VALUES(
b8d0: 31 2c 20 33 2c 20 32 29 20 7d 0a 20 20 20 20 73  1, 3, 2) }.    s
b8e0: 65 74 20 61 75 74 68 61 72 67 73 0a 20 20 7d 20  et authargs.  } 
b8f0: 7b 53 51 4c 49 54 45 5f 49 4e 53 45 52 54 20 73  {SQLITE_INSERT s
b900: 68 6f 72 74 20 7b 7d 20 6d 61 69 6e 20 7b 7d 20  hort {} main {} 
b910: 53 51 4c 49 54 45 5f 52 45 41 44 20 6c 6f 6e 67  SQLITE_READ long
b920: 20 62 20 6d 61 69 6e 20 7b 7d 7d 0a 20 20 0a 20   b main {}}.  . 
b930: 20 23 20 41 73 20 6d 75 73 74 20 61 6e 20 69 6e   # As must an in
b940: 73 65 72 74 20 6f 6e 20 74 68 65 20 63 68 69 6c  sert on the chil
b950: 64 20 74 61 62 6c 65 20 6f 66 20 61 20 64 65 66  d table of a def
b960: 65 72 72 65 64 20 63 6f 6e 73 74 72 61 69 6e 74  erred constraint
b970: 2e 0a 20 20 73 65 74 20 61 75 74 68 61 72 67 73  ..  set authargs
b980: 20 7b 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b   {}.  do_test fk
b990: 65 79 32 2d 31 38 2e 34 20 7b 0a 20 20 20 20 65  ey2-18.4 {.    e
b9a0: 78 65 63 73 71 6c 20 7b 20 49 4e 53 45 52 54 20  xecsql { INSERT 
b9b0: 49 4e 54 4f 20 6d 69 64 20 56 41 4c 55 45 53 28  INTO mid VALUES(
b9c0: 31 2c 20 33 2c 20 32 29 20 7d 0a 20 20 20 20 73  1, 3, 2) }.    s
b9d0: 65 74 20 61 75 74 68 61 72 67 73 0a 20 20 7d 20  et authargs.  } 
b9e0: 7b 53 51 4c 49 54 45 5f 49 4e 53 45 52 54 20 6d  {SQLITE_INSERT m
b9f0: 69 64 20 7b 7d 20 6d 61 69 6e 20 7b 7d 20 53 51  id {} main {} SQ
ba00: 4c 49 54 45 5f 52 45 41 44 20 6c 6f 6e 67 20 62  LITE_READ long b
ba10: 20 6d 61 69 6e 20 7b 7d 7d 0a 0a 20 20 64 6f 5f   main {}}..  do_
ba20: 74 65 73 74 20 66 6b 65 79 32 2d 31 38 2e 35 20  test fkey2-18.5 
ba30: 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a  {.    execsql {.
ba40: 20 20 20 20 20 20 43 52 45 41 54 45 20 54 41 42        CREATE TAB
ba50: 4c 45 20 6e 6f 75 67 68 74 28 61 2c 20 62 20 50  LE nought(a, b P
ba60: 52 49 4d 41 52 59 20 4b 45 59 2c 20 63 29 3b 0a  RIMARY KEY, c);.
ba70: 20 20 20 20 20 20 43 52 45 41 54 45 20 54 41 42        CREATE TAB
ba80: 4c 45 20 63 72 6f 73 73 28 64 2c 20 65 2c 20 66  LE cross(d, e, f
ba90: 2c 0a 20 20 20 20 20 20 20 20 46 4f 52 45 49 47  ,.        FOREIG
baa0: 4e 20 4b 45 59 28 65 29 20 52 45 46 45 52 45 4e  N KEY(e) REFEREN
bab0: 43 45 53 20 6e 6f 75 67 68 74 28 62 29 20 4f 4e  CES nought(b) ON
bac0: 20 55 50 44 41 54 45 20 43 41 53 43 41 44 45 0a   UPDATE CASCADE.
bad0: 20 20 20 20 20 20 29 3b 0a 20 20 20 20 7d 0a 20        );.    }. 
bae0: 20 20 20 65 78 65 63 73 71 6c 20 7b 20 49 4e 53     execsql { INS
baf0: 45 52 54 20 49 4e 54 4f 20 6e 6f 75 67 68 74 20  ERT INTO nought 
bb00: 56 41 4c 55 45 53 28 32 2c 20 31 2c 20 32 29 20  VALUES(2, 1, 2) 
bb10: 7d 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20  }.    execsql { 
bb20: 49 4e 53 45 52 54 20 49 4e 54 4f 20 63 72 6f 73  INSERT INTO cros
bb30: 73 20 56 41 4c 55 45 53 28 30 2c 20 31 2c 20 30  s VALUES(0, 1, 0
bb40: 29 20 7d 0a 20 20 20 20 73 65 74 20 61 75 74 68  ) }.    set auth
bb50: 61 72 67 73 20 5b 6c 69 73 74 5d 0a 20 20 20 20  args [list].    
bb60: 65 78 65 63 73 71 6c 20 7b 20 55 50 44 41 54 45  execsql { UPDATE
bb70: 20 6e 6f 75 67 68 74 20 53 45 54 20 62 20 3d 20   nought SET b = 
bb80: 35 20 7d 0a 20 20 20 20 73 65 74 20 61 75 74 68  5 }.    set auth
bb90: 61 72 67 73 0a 20 20 7d 20 7b 53 51 4c 49 54 45  args.  } {SQLITE
bba0: 5f 55 50 44 41 54 45 20 6e 6f 75 67 68 74 20 62  _UPDATE nought b
bbb0: 20 6d 61 69 6e 20 7b 7d 20 53 51 4c 49 54 45 5f   main {} SQLITE_
bbc0: 52 45 41 44 20 63 72 6f 73 73 20 65 20 6d 61 69  READ cross e mai
bbd0: 6e 20 7b 7d 20 53 51 4c 49 54 45 5f 52 45 41 44  n {} SQLITE_READ
bbe0: 20 63 72 6f 73 73 20 65 20 6d 61 69 6e 20 7b 7d   cross e main {}
bbf0: 20 53 51 4c 49 54 45 5f 52 45 41 44 20 6e 6f 75   SQLITE_READ nou
bc00: 67 68 74 20 62 20 6d 61 69 6e 20 7b 7d 20 53 51  ght b main {} SQ
bc10: 4c 49 54 45 5f 52 45 41 44 20 6e 6f 75 67 68 74  LITE_READ nought
bc20: 20 62 20 6d 61 69 6e 20 7b 7d 20 53 51 4c 49 54   b main {} SQLIT
bc30: 45 5f 52 45 41 44 20 6e 6f 75 67 68 74 20 62 20  E_READ nought b 
bc40: 6d 61 69 6e 20 7b 7d 20 53 51 4c 49 54 45 5f 55  main {} SQLITE_U
bc50: 50 44 41 54 45 20 63 72 6f 73 73 20 65 20 6d 61  PDATE cross e ma
bc60: 69 6e 20 7b 7d 20 53 51 4c 49 54 45 5f 52 45 41  in {} SQLITE_REA
bc70: 44 20 6e 6f 75 67 68 74 20 62 20 6d 61 69 6e 20  D nought b main 
bc80: 7b 7d 20 53 51 4c 49 54 45 5f 52 45 41 44 20 63  {} SQLITE_READ c
bc90: 72 6f 73 73 20 65 20 6d 61 69 6e 20 7b 7d 20 53  ross e main {} S
bca0: 51 4c 49 54 45 5f 52 45 41 44 20 6e 6f 75 67 68  QLITE_READ nough
bcb0: 74 20 62 20 6d 61 69 6e 20 7b 7d 20 53 51 4c 49  t b main {} SQLI
bcc0: 54 45 5f 52 45 41 44 20 6e 6f 75 67 68 74 20 62  TE_READ nought b
bcd0: 20 6d 61 69 6e 20 7b 7d 7d 0a 0a 20 20 64 6f 5f   main {}}..  do_
bce0: 74 65 73 74 20 66 6b 65 79 32 2d 31 38 2e 36 20  test fkey2-18.6 
bcf0: 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 53  {.    execsql {S
bd00: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 63 72 6f  ELECT * FROM cro
bd10: 73 73 7d 0a 20 20 7d 20 7b 30 20 35 20 30 7d 0a  ss}.  } {0 5 0}.
bd20: 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  .  do_test fkey2
bd30: 2d 31 38 2e 37 20 7b 0a 20 20 20 20 65 78 65 63  -18.7 {.    exec
bd40: 73 71 6c 20 7b 0a 20 20 20 20 20 20 43 52 45 41  sql {.      CREA
bd50: 54 45 20 54 41 42 4c 45 20 6f 6e 65 28 61 20 49  TE TABLE one(a I
bd60: 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b  NTEGER PRIMARY K
bd70: 45 59 2c 20 62 29 3b 0a 20 20 20 20 20 20 43 52  EY, b);.      CR
bd80: 45 41 54 45 20 54 41 42 4c 45 20 74 77 6f 28 62  EATE TABLE two(b
bd90: 2c 20 63 20 52 45 46 45 52 45 4e 43 45 53 20 6f  , c REFERENCES o
bda0: 6e 65 29 3b 0a 20 20 20 20 20 20 49 4e 53 45 52  ne);.      INSER
bdb0: 54 20 49 4e 54 4f 20 6f 6e 65 20 56 41 4c 55 45  T INTO one VALUE
bdc0: 53 28 31 30 31 2c 20 31 30 32 29 3b 0a 20 20 20  S(101, 102);.   
bdd0: 20 7d 0a 20 20 20 20 73 65 74 20 61 75 74 68 61   }.    set autha
bde0: 72 67 73 20 5b 6c 69 73 74 5d 0a 20 20 20 20 65  rgs [list].    e
bdf0: 78 65 63 73 71 6c 20 7b 20 49 4e 53 45 52 54 20  xecsql { INSERT 
be00: 49 4e 54 4f 20 74 77 6f 20 56 41 4c 55 45 53 28  INTO two VALUES(
be10: 31 30 30 2c 20 31 30 31 29 3b 20 7d 0a 20 20 20  100, 101); }.   
be20: 20 73 65 74 20 61 75 74 68 61 72 67 73 0a 20 20   set authargs.  
be30: 7d 20 7b 53 51 4c 49 54 45 5f 49 4e 53 45 52 54  } {SQLITE_INSERT
be40: 20 74 77 6f 20 7b 7d 20 6d 61 69 6e 20 7b 7d 20   two {} main {} 
be50: 53 51 4c 49 54 45 5f 52 45 41 44 20 6f 6e 65 20  SQLITE_READ one 
be60: 61 20 6d 61 69 6e 20 7b 7d 7d 0a 0a 20 20 23 20  a main {}}..  # 
be70: 52 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 49 47  Return SQLITE_IG
be80: 4e 4f 52 45 20 74 6f 20 72 65 71 75 65 73 74 73  NORE to requests
be90: 20 74 6f 20 72 65 61 64 20 66 72 6f 6d 20 74 68   to read from th
bea0: 65 20 70 61 72 65 6e 74 20 74 61 62 6c 65 2e 20  e parent table. 
beb0: 54 68 69 73 0a 20 20 23 20 63 61 75 73 65 73 20  This.  # causes 
bec0: 69 6e 73 65 72 74 73 20 6f 66 20 6e 6f 6e 2d 4e  inserts of non-N
bed0: 55 4c 4c 20 6b 65 79 73 20 69 6e 74 6f 20 74 68  ULL keys into th
bee0: 65 20 63 68 69 6c 64 20 74 61 62 6c 65 20 74 6f  e child table to
bef0: 20 66 61 69 6c 2e 0a 20 20 23 0a 20 20 72 65 6e   fail..  #.  ren
bf00: 61 6d 65 20 61 75 74 68 20 7b 7d 0a 20 20 70 72  ame auth {}.  pr
bf10: 6f 63 20 61 75 74 68 20 7b 61 72 67 73 7d 20 7b  oc auth {args} {
bf20: 0a 20 20 20 20 69 66 20 7b 5b 6c 69 6e 64 65 78  .    if {[lindex
bf30: 20 24 61 72 67 73 20 31 5d 20 3d 3d 20 22 6c 6f   $args 1] == "lo
bf40: 6e 67 22 7d 20 7b 72 65 74 75 72 6e 20 53 51 4c  ng"} {return SQL
bf50: 49 54 45 5f 49 47 4e 4f 52 45 7d 0a 20 20 20 20  ITE_IGNORE}.    
bf60: 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b  return SQLITE_OK
bf70: 0a 20 20 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66  .  }.  do_test f
bf80: 6b 65 79 32 2d 31 38 2e 38 20 7b 0a 20 20 20 20  key2-18.8 {.    
bf90: 63 61 74 63 68 73 71 6c 20 7b 20 49 4e 53 45 52  catchsql { INSER
bfa0: 54 20 49 4e 54 4f 20 73 68 6f 72 74 20 56 41 4c  T INTO short VAL
bfb0: 55 45 53 28 31 2c 20 33 2c 20 32 29 20 7d 0a 20  UES(1, 3, 2) }. 
bfc0: 20 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b   } {1 {foreign k
bfd0: 65 79 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61  ey constraint fa
bfe0: 69 6c 65 64 7d 7d 0a 20 20 64 6f 5f 74 65 73 74  iled}}.  do_test
bff0: 20 66 6b 65 79 32 2d 31 38 2e 39 20 7b 0a 20 20   fkey2-18.9 {.  
c000: 20 20 65 78 65 63 73 71 6c 20 7b 20 49 4e 53 45    execsql { INSE
c010: 52 54 20 49 4e 54 4f 20 73 68 6f 72 74 20 56 41  RT INTO short VA
c020: 4c 55 45 53 28 31 2c 20 33 2c 20 4e 55 4c 4c 29  LUES(1, 3, NULL)
c030: 20 7d 0a 20 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74   }.  } {}.  do_t
c040: 65 73 74 20 66 6b 65 79 32 2d 31 38 2e 31 30 20  est fkey2-18.10 
c050: 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20  {.    execsql { 
c060: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 73 68  SELECT * FROM sh
c070: 6f 72 74 20 7d 0a 20 20 7d 20 7b 31 20 33 20 32  ort }.  } {1 3 2
c080: 20 31 20 33 20 7b 7d 7d 0a 20 20 64 6f 5f 74 65   1 3 {}}.  do_te
c090: 73 74 20 66 6b 65 79 32 2d 31 38 2e 31 31 20 7b  st fkey2-18.11 {
c0a0: 0a 20 20 20 20 63 61 74 63 68 73 71 6c 20 7b 20  .    catchsql { 
c0b0: 55 50 44 41 54 45 20 73 68 6f 72 74 20 53 45 54  UPDATE short SET
c0c0: 20 66 20 3d 20 32 20 57 48 45 52 45 20 66 20 49   f = 2 WHERE f I
c0d0: 53 20 4e 55 4c 4c 20 7d 0a 20 20 7d 20 7b 31 20  S NULL }.  } {1 
c0e0: 7b 66 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e  {foreign key con
c0f0: 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d  straint failed}}
c100: 0a 0a 20 20 64 62 20 61 75 74 68 20 7b 7d 0a 20  ..  db auth {}. 
c110: 20 75 6e 73 65 74 20 61 75 74 68 61 72 67 73 0a   unset authargs.
c120: 7d 0a 0a 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79  }...do_test fkey
c130: 32 2d 31 39 2e 31 20 7b 0a 20 20 65 78 65 63 73  2-19.1 {.  execs
c140: 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  ql {.    CREATE 
c150: 54 41 42 4c 45 20 6d 61 69 6e 28 69 64 20 49 4e  TABLE main(id IN
c160: 54 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b 45  TEGER PRIMARY KE
c170: 59 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54  Y);.    CREATE T
c180: 41 42 4c 45 20 73 75 62 28 69 64 20 49 4e 54 20  ABLE sub(id INT 
c190: 52 45 46 45 52 45 4e 43 45 53 20 6d 61 69 6e 28  REFERENCES main(
c1a0: 69 64 29 29 3b 0a 20 20 20 20 49 4e 53 45 52 54  id));.    INSERT
c1b0: 20 49 4e 54 4f 20 6d 61 69 6e 20 56 41 4c 55 45   INTO main VALUE
c1c0: 53 28 31 29 3b 0a 20 20 20 20 49 4e 53 45 52 54  S(1);.    INSERT
c1d0: 20 49 4e 54 4f 20 6d 61 69 6e 20 56 41 4c 55 45   INTO main VALUE
c1e0: 53 28 32 29 3b 0a 20 20 20 20 49 4e 53 45 52 54  S(2);.    INSERT
c1f0: 20 49 4e 54 4f 20 73 75 62 20 56 41 4c 55 45 53   INTO sub VALUES
c200: 28 32 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f  (2);.  }.} {}.do
c210: 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 39 2e 32  _test fkey2-19.2
c220: 20 7b 0a 20 20 73 65 74 20 53 20 5b 73 71 6c 69   {.  set S [sqli
c230: 74 65 33 5f 70 72 65 70 61 72 65 5f 76 32 20 64  te3_prepare_v2 d
c240: 62 20 22 44 45 4c 45 54 45 20 46 52 4f 4d 20 6d  b "DELETE FROM m
c250: 61 69 6e 20 57 48 45 52 45 20 69 64 20 3d 20 3f  ain WHERE id = ?
c260: 22 20 2d 31 20 64 75 6d 6d 79 5d 0a 20 20 73 71  " -1 dummy].  sq
c270: 6c 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74 20 24  lite3_bind_int $
c280: 53 20 31 20 32 0a 20 20 73 71 6c 69 74 65 33 5f  S 1 2.  sqlite3_
c290: 73 74 65 70 20 24 53 0a 7d 20 7b 53 51 4c 49 54  step $S.} {SQLIT
c2a0: 45 5f 43 4f 4e 53 54 52 41 49 4e 54 7d 0a 64 6f  E_CONSTRAINT}.do
c2b0: 5f 74 65 73 74 20 66 6b 65 79 32 2d 31 39 2e 33  _test fkey2-19.3
c2c0: 20 7b 0a 20 20 73 71 6c 69 74 65 33 5f 72 65 73   {.  sqlite3_res
c2d0: 65 74 20 24 53 0a 7d 20 7b 53 51 4c 49 54 45 5f  et $S.} {SQLITE_
c2e0: 43 4f 4e 53 54 52 41 49 4e 54 7d 0a 64 6f 5f 74  CONSTRAINT}.do_t
c2f0: 65 73 74 20 66 6b 65 79 32 2d 31 39 2e 34 20 7b  est fkey2-19.4 {
c300: 0a 20 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f  .  sqlite3_bind_
c310: 69 6e 74 20 24 53 20 31 20 31 0a 20 20 73 71 6c  int $S 1 1.  sql
c320: 69 74 65 33 5f 73 74 65 70 20 24 53 0a 7d 20 7b  ite3_step $S.} {
c330: 53 51 4c 49 54 45 5f 44 4f 4e 45 7d 0a 64 6f 5f  SQLITE_DONE}.do_
c340: 74 65 73 74 20 66 6b 65 79 32 2d 31 39 2e 34 20  test fkey2-19.4 
c350: 7b 0a 20 20 73 71 6c 69 74 65 33 5f 66 69 6e 61  {.  sqlite3_fina
c360: 6c 69 7a 65 20 24 53 0a 7d 20 7b 53 51 4c 49 54  lize $S.} {SQLIT
c370: 45 5f 4f 4b 7d 0a 0a 64 72 6f 70 5f 61 6c 6c 5f  E_OK}..drop_all_
c380: 74 61 62 6c 65 73 0a 64 6f 5f 74 65 73 74 20 66  tables.do_test f
c390: 6b 65 79 32 2d 32 30 2e 31 20 7b 0a 20 20 65 78  key2-20.1 {.  ex
c3a0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41  ecsql {.    CREA
c3b0: 54 45 20 54 41 42 4c 45 20 70 70 28 61 20 50 52  TE TABLE pp(a PR
c3c0: 49 4d 41 52 59 20 4b 45 59 2c 20 62 29 3b 0a 20  IMARY KEY, b);. 
c3d0: 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20     CREATE TABLE 
c3e0: 63 63 28 63 20 50 52 49 4d 41 52 59 20 4b 45 59  cc(c PRIMARY KEY
c3f0: 2c 20 64 20 52 45 46 45 52 45 4e 43 45 53 20 70  , d REFERENCES p
c400: 70 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 0a 66 6f  p);.  }.} {}..fo
c410: 72 65 61 63 68 20 7b 74 6e 20 69 6e 73 65 72 74  reach {tn insert
c420: 7d 20 7b 0a 20 20 31 20 22 49 4e 53 45 52 54 22  } {.  1 "INSERT"
c430: 0a 20 20 32 20 22 49 4e 53 45 52 54 20 4f 52 20  .  2 "INSERT OR 
c440: 49 47 4e 4f 52 45 22 0a 20 20 33 20 22 49 4e 53  IGNORE".  3 "INS
c450: 45 52 54 20 4f 52 20 41 42 4f 52 54 22 0a 20 20  ERT OR ABORT".  
c460: 34 20 22 49 4e 53 45 52 54 20 4f 52 20 52 4f 4c  4 "INSERT OR ROL
c470: 4c 42 41 43 4b 22 0a 20 20 35 20 22 49 4e 53 45  LBACK".  5 "INSE
c480: 52 54 20 4f 52 20 52 45 50 4c 41 43 45 22 0a 20  RT OR REPLACE". 
c490: 20 36 20 22 49 4e 53 45 52 54 20 4f 52 20 46 41   6 "INSERT OR FA
c4a0: 49 4c 22 0a 7d 20 7b 0a 20 20 64 6f 5f 74 65 73  IL".} {.  do_tes
c4b0: 74 20 66 6b 65 79 32 2d 32 30 2e 32 2e 24 74 6e  t fkey2-20.2.$tn
c4c0: 2e 31 20 7b 0a 20 20 20 20 63 61 74 63 68 73 71  .1 {.    catchsq
c4d0: 6c 20 22 24 69 6e 73 65 72 74 20 49 4e 54 4f 20  l "$insert INTO 
c4e0: 63 63 20 56 41 4c 55 45 53 28 31 2c 20 32 29 22  cc VALUES(1, 2)"
c4f0: 0a 20 20 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e  .  } {1 {foreign
c500: 20 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e 74 20   key constraint 
c510: 66 61 69 6c 65 64 7d 7d 0a 20 20 64 6f 5f 74 65  failed}}.  do_te
c520: 73 74 20 66 6b 65 79 32 2d 32 30 2e 32 2e 24 74  st fkey2-20.2.$t
c530: 6e 2e 32 20 7b 0a 20 20 20 20 65 78 65 63 73 71  n.2 {.    execsq
c540: 6c 20 7b 20 53 45 4c 45 43 54 20 2a 20 46 52 4f  l { SELECT * FRO
c550: 4d 20 63 63 20 7d 0a 20 20 7d 20 7b 7d 0a 20 20  M cc }.  } {}.  
c560: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 32 30  do_test fkey2-20
c570: 2e 32 2e 24 74 6e 2e 33 20 7b 0a 20 20 20 20 65  .2.$tn.3 {.    e
c580: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 20 20 42  xecsql {.      B
c590: 45 47 49 4e 3b 0a 20 20 20 20 20 20 20 20 49 4e  EGIN;.        IN
c5a0: 53 45 52 54 20 49 4e 54 4f 20 70 70 20 56 41 4c  SERT INTO pp VAL
c5b0: 55 45 53 28 32 2c 20 27 74 77 6f 27 29 3b 0a 20  UES(2, 'two');. 
c5c0: 20 20 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e         INSERT IN
c5d0: 54 4f 20 63 63 20 56 41 4c 55 45 53 28 31 2c 20  TO cc VALUES(1, 
c5e0: 32 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61  2);.    }.    ca
c5f0: 74 63 68 73 71 6c 20 22 24 69 6e 73 65 72 74 20  tchsql "$insert 
c600: 49 4e 54 4f 20 63 63 20 56 41 4c 55 45 53 28 33  INTO cc VALUES(3
c610: 2c 20 34 29 22 0a 20 20 7d 20 7b 31 20 7b 66 6f  , 4)".  } {1 {fo
c620: 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72  reign key constr
c630: 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 20 20  aint failed}}.  
c640: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 32 30  do_test fkey2-20
c650: 2e 32 2e 24 74 6e 2e 34 20 7b 0a 20 20 20 20 65  .2.$tn.4 {.    e
c660: 78 65 63 73 71 6c 20 7b 20 43 4f 4d 4d 49 54 20  xecsql { COMMIT 
c670: 3b 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  ; SELECT * FROM 
c680: 63 63 20 7d 0a 20 20 7d 20 7b 31 20 32 7d 0a 20  cc }.  } {1 2}. 
c690: 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 32   do_test fkey2-2
c6a0: 30 2e 32 2e 24 74 6e 2e 35 20 7b 0a 20 20 20 20  0.2.$tn.5 {.    
c6b0: 65 78 65 63 73 71 6c 20 7b 20 44 45 4c 45 54 45  execsql { DELETE
c6c0: 20 46 52 4f 4d 20 63 63 20 3b 20 44 45 4c 45 54   FROM cc ; DELET
c6d0: 45 20 46 52 4f 4d 20 70 70 20 7d 0a 20 20 7d 20  E FROM pp }.  } 
c6e0: 7b 7d 0a 7d 0a 0a 66 6f 72 65 61 63 68 20 7b 74  {}.}..foreach {t
c6f0: 6e 20 75 70 64 61 74 65 7d 20 7b 0a 20 20 31 20  n update} {.  1 
c700: 22 55 50 44 41 54 45 22 0a 20 20 32 20 22 55 50  "UPDATE".  2 "UP
c710: 44 41 54 45 20 4f 52 20 49 47 4e 4f 52 45 22 0a  DATE OR IGNORE".
c720: 20 20 33 20 22 55 50 44 41 54 45 20 4f 52 20 41    3 "UPDATE OR A
c730: 42 4f 52 54 22 0a 20 20 34 20 22 55 50 44 41 54  BORT".  4 "UPDAT
c740: 45 20 4f 52 20 52 4f 4c 4c 42 41 43 4b 22 0a 20  E OR ROLLBACK". 
c750: 20 35 20 22 55 50 44 41 54 45 20 4f 52 20 52 45   5 "UPDATE OR RE
c760: 50 4c 41 43 45 22 0a 20 20 36 20 22 55 50 44 41  PLACE".  6 "UPDA
c770: 54 45 20 4f 52 20 46 41 49 4c 22 0a 7d 20 7b 0a  TE OR FAIL".} {.
c780: 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d    do_test fkey2-
c790: 32 30 2e 33 2e 24 74 6e 2e 31 20 7b 0a 20 20 20  20.3.$tn.1 {.   
c7a0: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 20   execsql {.     
c7b0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 70 70 20   INSERT INTO pp 
c7c0: 56 41 4c 55 45 53 28 32 2c 20 27 74 77 6f 27 29  VALUES(2, 'two')
c7d0: 3b 0a 20 20 20 20 20 20 49 4e 53 45 52 54 20 49  ;.      INSERT I
c7e0: 4e 54 4f 20 63 63 20 56 41 4c 55 45 53 28 31 2c  NTO cc VALUES(1,
c7f0: 20 32 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b   2);.    }.  } {
c800: 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79  }.  do_test fkey
c810: 32 2d 32 30 2e 33 2e 24 74 6e 2e 32 20 7b 0a 20  2-20.3.$tn.2 {. 
c820: 20 20 20 63 61 74 63 68 73 71 6c 20 22 24 75 70     catchsql "$up
c830: 64 61 74 65 20 70 70 20 53 45 54 20 61 20 3d 20  date pp SET a = 
c840: 31 22 0a 20 20 7d 20 7b 31 20 7b 66 6f 72 65 69  1".  } {1 {forei
c850: 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e  gn key constrain
c860: 74 20 66 61 69 6c 65 64 7d 7d 0a 20 20 64 6f 5f  t failed}}.  do_
c870: 74 65 73 74 20 66 6b 65 79 32 2d 32 30 2e 33 2e  test fkey2-20.3.
c880: 24 74 6e 2e 33 20 7b 0a 20 20 20 20 65 78 65 63  $tn.3 {.    exec
c890: 73 71 6c 20 7b 20 53 45 4c 45 43 54 20 2a 20 46  sql { SELECT * F
c8a0: 52 4f 4d 20 70 70 20 7d 0a 20 20 7d 20 7b 32 20  ROM pp }.  } {2 
c8b0: 74 77 6f 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66  two}.  do_test f
c8c0: 6b 65 79 32 2d 32 30 2e 33 2e 24 74 6e 2e 34 20  key2-20.3.$tn.4 
c8d0: 7b 0a 20 20 20 20 63 61 74 63 68 73 71 6c 20 22  {.    catchsql "
c8e0: 24 75 70 64 61 74 65 20 63 63 20 53 45 54 20 64  $update cc SET d
c8f0: 20 3d 20 31 22 0a 20 20 7d 20 7b 31 20 7b 66 6f   = 1".  } {1 {fo
c900: 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72  reign key constr
c910: 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 20 20  aint failed}}.  
c920: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 32 30  do_test fkey2-20
c930: 2e 33 2e 24 74 6e 2e 35 20 7b 0a 20 20 20 20 65  .3.$tn.5 {.    e
c940: 78 65 63 73 71 6c 20 7b 20 53 45 4c 45 43 54 20  xecsql { SELECT 
c950: 2a 20 46 52 4f 4d 20 63 63 20 7d 0a 20 20 7d 20  * FROM cc }.  } 
c960: 7b 31 20 32 7d 0a 20 20 64 6f 5f 74 65 73 74 20  {1 2}.  do_test 
c970: 66 6b 65 79 32 2d 32 30 2e 33 2e 24 74 6e 2e 36  fkey2-20.3.$tn.6
c980: 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b   {.    execsql {
c990: 0a 20 20 20 20 20 20 42 45 47 49 4e 3b 0a 20 20  .      BEGIN;.  
c9a0: 20 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54        INSERT INT
c9b0: 4f 20 70 70 20 56 41 4c 55 45 53 28 33 2c 20 27  O pp VALUES(3, '
c9c0: 74 68 72 65 65 27 29 3b 0a 20 20 20 20 7d 0a 20  three');.    }. 
c9d0: 20 20 20 63 61 74 63 68 73 71 6c 20 22 24 75 70     catchsql "$up
c9e0: 64 61 74 65 20 70 70 20 53 45 54 20 61 20 3d 20  date pp SET a = 
c9f0: 31 20 57 48 45 52 45 20 61 20 3d 20 32 22 0a 20  1 WHERE a = 2". 
ca00: 20 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b   } {1 {foreign k
ca10: 65 79 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61  ey constraint fa
ca20: 69 6c 65 64 7d 7d 0a 20 20 64 6f 5f 74 65 73 74  iled}}.  do_test
ca30: 20 66 6b 65 79 32 2d 32 30 2e 33 2e 24 74 6e 2e   fkey2-20.3.$tn.
ca40: 37 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20  7 {.    execsql 
ca50: 7b 20 43 4f 4d 4d 49 54 20 3b 20 53 45 4c 45 43  { COMMIT ; SELEC
ca60: 54 20 2a 20 46 52 4f 4d 20 70 70 20 7d 0a 20 20  T * FROM pp }.  
ca70: 7d 20 7b 32 20 74 77 6f 20 33 20 74 68 72 65 65  } {2 two 3 three
ca80: 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79  }.  do_test fkey
ca90: 32 2d 32 30 2e 33 2e 24 74 6e 2e 38 20 7b 0a 20  2-20.3.$tn.8 {. 
caa0: 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20     execsql {.   
cab0: 20 20 20 42 45 47 49 4e 3b 0a 20 20 20 20 20 20     BEGIN;.      
cac0: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 63 63    INSERT INTO cc
cad0: 20 56 41 4c 55 45 53 28 32 2c 20 32 29 3b 0a 20   VALUES(2, 2);. 
cae0: 20 20 20 7d 0a 20 20 20 20 63 61 74 63 68 73 71     }.    catchsq
caf0: 6c 20 22 24 75 70 64 61 74 65 20 63 63 20 53 45  l "$update cc SE
cb00: 54 20 64 20 3d 20 31 20 57 48 45 52 45 20 63 20  T d = 1 WHERE c 
cb10: 3d 20 31 22 0a 20 20 7d 20 7b 31 20 7b 66 6f 72  = 1".  } {1 {for
cb20: 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61  eign key constra
cb30: 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 20 20 64  int failed}}.  d
cb40: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 32 30 2e  o_test fkey2-20.
cb50: 33 2e 24 74 6e 2e 39 20 7b 0a 20 20 20 20 65 78  3.$tn.9 {.    ex
cb60: 65 63 73 71 6c 20 7b 20 43 4f 4d 4d 49 54 20 3b  ecsql { COMMIT ;
cb70: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 63   SELECT * FROM c
cb80: 63 20 7d 0a 20 20 7d 20 7b 31 20 32 20 32 20 32  c }.  } {1 2 2 2
cb90: 7d 0a 20 20 64 6f 5f 74 65 73 74 20 66 6b 65 79  }.  do_test fkey
cba0: 32 2d 32 30 2e 33 2e 24 74 6e 2e 31 30 20 7b 0a  2-20.3.$tn.10 {.
cbb0: 20 20 20 20 65 78 65 63 73 71 6c 20 7b 20 44 45      execsql { DE
cbc0: 4c 45 54 45 20 46 52 4f 4d 20 63 63 20 3b 20 44  LETE FROM cc ; D
cbd0: 45 4c 45 54 45 20 46 52 4f 4d 20 70 70 20 7d 0a  ELETE FROM pp }.
cbe0: 20 20 7d 20 7b 7d 0a 7d 0a 0a 23 2d 2d 2d 2d 2d    } {}.}..#-----
cbf0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
cc00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
cc10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
cc20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
cc30: 2d 2d 2d 2d 0a 23 20 54 68 65 20 66 6f 6c 6c 6f  ----.# The follo
cc40: 77 69 6e 67 20 62 6c 6f 63 6b 20 6f 66 20 74 65  wing block of te
cc50: 73 74 73 2c 20 74 68 6f 73 65 20 70 72 65 66 69  sts, those prefi
cc60: 78 65 64 20 77 69 74 68 20 22 66 6b 65 79 32 2d  xed with "fkey2-
cc70: 67 65 6e 66 6b 65 79 2e 22 2c 20 61 72 65 20 0a  genfkey.", are .
cc80: 23 20 74 68 65 20 73 61 6d 65 20 74 65 73 74 73  # the same tests
cc90: 20 74 68 61 74 20 77 65 72 65 20 75 73 65 64 20   that were used 
cca0: 74 6f 20 74 65 73 74 20 74 68 65 20 22 2e 67 65  to test the ".ge
ccb0: 6e 66 6b 65 79 22 20 63 6f 6d 6d 61 6e 64 20 70  nfkey" command p
ccc0: 72 6f 76 69 64 65 64 20 0a 23 20 62 79 20 74 68  rovided .# by th
ccd0: 65 20 73 68 65 6c 6c 20 74 6f 6f 6c 2e 20 53 6f  e shell tool. So
cce0: 20 74 68 65 73 65 20 74 65 73 74 73 20 73 68 6f   these tests sho
ccf0: 77 20 74 68 61 74 20 74 68 65 20 62 75 69 6c 74  w that the built
cd00: 2d 69 6e 20 66 6f 72 65 69 67 6e 20 6b 65 79 20  -in foreign key 
cd10: 0a 23 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69 6f  .# implementatio
cd20: 6e 20 69 73 20 6d 6f 72 65 20 6f 72 20 6c 65 73  n is more or les
cd30: 73 20 63 6f 6d 70 61 74 69 62 6c 65 20 77 69 74  s compatible wit
cd40: 68 20 74 68 65 20 74 72 69 67 67 65 72 73 20 67  h the triggers g
cd50: 65 6e 65 72 61 74 65 64 20 0a 23 20 62 79 20 67  enerated .# by g
cd60: 65 6e 66 6b 65 79 2e 0a 23 0a 64 72 6f 70 5f 61  enfkey..#.drop_a
cd70: 6c 6c 5f 74 61 62 6c 65 73 0a 64 6f 5f 74 65 73  ll_tables.do_tes
cd80: 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b 65 79 2e  t fkey2-genfkey.
cd90: 31 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  1.1 {.  execsql 
cda0: 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42  {.    CREATE TAB
cdb0: 4c 45 20 74 31 28 61 20 49 4e 54 45 47 45 52 20  LE t1(a INTEGER 
cdc0: 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62 2c 20  PRIMARY KEY, b, 
cdd0: 63 2c 20 55 4e 49 51 55 45 28 62 2c 20 63 29 29  c, UNIQUE(b, c))
cde0: 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42  ;.    CREATE TAB
cdf0: 4c 45 20 74 32 28 65 20 52 45 46 45 52 45 4e 43  LE t2(e REFERENC
ce00: 45 53 20 74 31 2c 20 66 29 3b 0a 20 20 20 20 43  ES t1, f);.    C
ce10: 52 45 41 54 45 20 54 41 42 4c 45 20 74 33 28 67  REATE TABLE t3(g
ce20: 2c 20 68 2c 20 69 2c 20 46 4f 52 45 49 47 4e 20  , h, i, FOREIGN 
ce30: 4b 45 59 20 28 68 2c 20 69 29 20 52 45 46 45 52  KEY (h, i) REFER
ce40: 45 4e 43 45 53 20 74 31 28 62 2c 20 63 29 29 3b  ENCES t1(b, c));
ce50: 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73  .  }.} {}.do_tes
ce60: 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b 65 79 2e  t fkey2-genfkey.
ce70: 31 2e 32 20 7b 0a 20 20 63 61 74 63 68 73 71 6c  1.2 {.  catchsql
ce80: 20 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74   { INSERT INTO t
ce90: 32 20 56 41 4c 55 45 53 28 31 2c 20 32 29 20 7d  2 VALUES(1, 2) }
cea0: 0a 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b  .} {1 {foreign k
ceb0: 65 79 20 63 6f 6e 73 74 72 61 69 6e 74 20 66 61  ey constraint fa
cec0: 69 6c 65 64 7d 7d 0a 64 6f 5f 74 65 73 74 20 66  iled}}.do_test f
ced0: 6b 65 79 32 2d 67 65 6e 66 6b 65 79 2e 31 2e 33  key2-genfkey.1.3
cee0: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   {.  execsql {. 
cef0: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
cf00: 31 20 56 41 4c 55 45 53 28 31 2c 20 32 2c 20 33  1 VALUES(1, 2, 3
cf10: 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  );.    INSERT IN
cf20: 54 4f 20 74 32 20 56 41 4c 55 45 53 28 31 2c 20  TO t2 VALUES(1, 
cf30: 32 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f  2);.  }.} {}.do_
cf40: 74 65 73 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b  test fkey2-genfk
cf50: 65 79 2e 31 2e 34 20 7b 0a 20 20 65 78 65 63 73  ey.1.4 {.  execs
cf60: 71 6c 20 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f  ql { INSERT INTO
cf70: 20 74 32 20 56 41 4c 55 45 53 28 4e 55 4c 4c 2c   t2 VALUES(NULL,
cf80: 20 33 29 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65   3) }.} {}.do_te
cf90: 73 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b 65 79  st fkey2-genfkey
cfa0: 2e 31 2e 35 20 7b 0a 20 20 63 61 74 63 68 73 71  .1.5 {.  catchsq
cfb0: 6c 20 7b 20 55 50 44 41 54 45 20 74 32 20 53 45  l { UPDATE t2 SE
cfc0: 54 20 65 20 3d 20 35 20 57 48 45 52 45 20 65 20  T e = 5 WHERE e 
cfd0: 49 53 20 4e 55 4c 4c 20 7d 0a 7d 20 7b 31 20 7b  IS NULL }.} {1 {
cfe0: 66 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73  foreign key cons
cff0: 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a  traint failed}}.
d000: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 67 65  do_test fkey2-ge
d010: 6e 66 6b 65 79 2e 31 2e 36 20 7b 0a 20 20 65 78  nfkey.1.6 {.  ex
d020: 65 63 73 71 6c 20 7b 20 55 50 44 41 54 45 20 74  ecsql { UPDATE t
d030: 32 20 53 45 54 20 65 20 3d 20 31 20 57 48 45 52  2 SET e = 1 WHER
d040: 45 20 65 20 49 53 20 4e 55 4c 4c 20 7d 0a 7d 20  E e IS NULL }.} 
d050: 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  {}.do_test fkey2
d060: 2d 67 65 6e 66 6b 65 79 2e 31 2e 37 20 7b 0a 20  -genfkey.1.7 {. 
d070: 20 65 78 65 63 73 71 6c 20 7b 20 55 50 44 41 54   execsql { UPDAT
d080: 45 20 74 32 20 53 45 54 20 65 20 3d 20 4e 55 4c  E t2 SET e = NUL
d090: 4c 20 57 48 45 52 45 20 66 20 3d 20 33 20 7d 0a  L WHERE f = 3 }.
d0a0: 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65  } {}.do_test fke
d0b0: 79 32 2d 67 65 6e 66 6b 65 79 2e 31 2e 38 20 7b  y2-genfkey.1.8 {
d0c0: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 20 55 50  .  catchsql { UP
d0d0: 44 41 54 45 20 74 31 20 53 45 54 20 61 20 3d 20  DATE t1 SET a = 
d0e0: 31 30 20 7d 0a 7d 20 7b 31 20 7b 66 6f 72 65 69  10 }.} {1 {forei
d0f0: 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e  gn key constrain
d100: 74 20 66 61 69 6c 65 64 7d 7d 0a 64 6f 5f 74 65  t failed}}.do_te
d110: 73 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b 65 79  st fkey2-genfkey
d120: 2e 31 2e 39 20 7b 0a 20 20 63 61 74 63 68 73 71  .1.9 {.  catchsq
d130: 6c 20 7b 20 55 50 44 41 54 45 20 74 31 20 53 45  l { UPDATE t1 SE
d140: 54 20 61 20 3d 20 4e 55 4c 4c 20 7d 0a 7d 20 7b  T a = NULL }.} {
d150: 31 20 7b 64 61 74 61 74 79 70 65 20 6d 69 73 6d  1 {datatype mism
d160: 61 74 63 68 7d 7d 0a 64 6f 5f 74 65 73 74 20 66  atch}}.do_test f
d170: 6b 65 79 32 2d 67 65 6e 66 6b 65 79 2e 31 2e 31  key2-genfkey.1.1
d180: 30 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b  0 {.  catchsql {
d190: 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 74 31 20   DELETE FROM t1 
d1a0: 7d 0a 7d 20 7b 31 20 7b 66 6f 72 65 69 67 6e 20  }.} {1 {foreign 
d1b0: 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e 74 20 66  key constraint f
d1c0: 61 69 6c 65 64 7d 7d 0a 64 6f 5f 74 65 73 74 20  ailed}}.do_test 
d1d0: 66 6b 65 79 32 2d 67 65 6e 66 6b 65 79 2e 31 2e  fkey2-genfkey.1.
d1e0: 31 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  11 {.  execsql {
d1f0: 20 55 50 44 41 54 45 20 74 32 20 53 45 54 20 65   UPDATE t2 SET e
d200: 20 3d 20 4e 55 4c 4c 20 7d 0a 7d 20 7b 7d 0a 64   = NULL }.} {}.d
d210: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 67 65 6e  o_test fkey2-gen
d220: 66 6b 65 79 2e 31 2e 31 32 20 7b 0a 20 20 65 78  fkey.1.12 {.  ex
d230: 65 63 73 71 6c 20 7b 20 0a 20 20 20 20 55 50 44  ecsql { .    UPD
d240: 41 54 45 20 74 31 20 53 45 54 20 61 20 3d 20 31  ATE t1 SET a = 1
d250: 30 3b 0a 20 20 20 20 44 45 4c 45 54 45 20 46 52  0;.    DELETE FR
d260: 4f 4d 20 74 31 3b 0a 20 20 20 20 44 45 4c 45 54  OM t1;.    DELET
d270: 45 20 46 52 4f 4d 20 74 32 3b 0a 20 20 7d 0a 7d  E FROM t2;.  }.}
d280: 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79   {}.do_test fkey
d290: 32 2d 67 65 6e 66 6b 65 79 2e 31 2e 31 33 20 7b  2-genfkey.1.13 {
d2a0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
d2b0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 33 20   INSERT INTO t3 
d2c0: 56 41 4c 55 45 53 28 31 2c 20 4e 55 4c 4c 2c 20  VALUES(1, NULL, 
d2d0: 4e 55 4c 4c 29 3b 0a 20 20 20 20 49 4e 53 45 52  NULL);.    INSER
d2e0: 54 20 49 4e 54 4f 20 74 33 20 56 41 4c 55 45 53  T INTO t3 VALUES
d2f0: 28 31 2c 20 32 2c 20 4e 55 4c 4c 29 3b 0a 20 20  (1, 2, NULL);.  
d300: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 33    INSERT INTO t3
d310: 20 56 41 4c 55 45 53 28 31 2c 20 4e 55 4c 4c 2c   VALUES(1, NULL,
d320: 20 33 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f   3);.  }.} {}.do
d330: 5f 74 65 73 74 20 66 6b 65 79 32 2d 67 65 6e 66  _test fkey2-genf
d340: 6b 65 79 2e 31 2e 31 34 20 7b 0a 20 20 63 61 74  key.1.14 {.  cat
d350: 63 68 73 71 6c 20 7b 20 49 4e 53 45 52 54 20 49  chsql { INSERT I
d360: 4e 54 4f 20 74 33 20 56 41 4c 55 45 53 28 33 2c  NTO t3 VALUES(3,
d370: 20 31 2c 20 34 29 20 7d 0a 7d 20 7b 31 20 7b 66   1, 4) }.} {1 {f
d380: 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73 74  oreign key const
d390: 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 64  raint failed}}.d
d3a0: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 67 65 6e  o_test fkey2-gen
d3b0: 66 6b 65 79 2e 31 2e 31 35 20 7b 0a 20 20 65 78  fkey.1.15 {.  ex
d3c0: 65 63 73 71 6c 20 7b 20 0a 20 20 20 20 49 4e 53  ecsql { .    INS
d3d0: 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55  ERT INTO t1 VALU
d3e0: 45 53 28 31 2c 20 31 2c 20 34 29 3b 0a 20 20 20  ES(1, 1, 4);.   
d3f0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 33 20   INSERT INTO t3 
d400: 56 41 4c 55 45 53 28 33 2c 20 31 2c 20 34 29 3b  VALUES(3, 1, 4);
d410: 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73  .  }.} {}.do_tes
d420: 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b 65 79 2e  t fkey2-genfkey.
d430: 31 2e 31 36 20 7b 0a 20 20 63 61 74 63 68 73 71  1.16 {.  catchsq
d440: 6c 20 7b 20 44 45 4c 45 54 45 20 46 52 4f 4d 20  l { DELETE FROM 
d450: 74 31 20 7d 0a 7d 20 7b 31 20 7b 66 6f 72 65 69  t1 }.} {1 {forei
d460: 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e  gn key constrain
d470: 74 20 66 61 69 6c 65 64 7d 7d 0a 64 6f 5f 74 65  t failed}}.do_te
d480: 73 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b 65 79  st fkey2-genfkey
d490: 2e 31 2e 31 37 20 7b 0a 20 20 63 61 74 63 68 73  .1.17 {.  catchs
d4a0: 71 6c 20 7b 20 55 50 44 41 54 45 20 74 31 20 53  ql { UPDATE t1 S
d4b0: 45 54 20 62 20 3d 20 31 30 7d 0a 7d 20 7b 31 20  ET b = 10}.} {1 
d4c0: 7b 66 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e  {foreign key con
d4d0: 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d  straint failed}}
d4e0: 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 67  .do_test fkey2-g
d4f0: 65 6e 66 6b 65 79 2e 31 2e 31 38 20 7b 0a 20 20  enfkey.1.18 {.  
d500: 65 78 65 63 73 71 6c 20 7b 20 55 50 44 41 54 45  execsql { UPDATE
d510: 20 74 31 20 53 45 54 20 61 20 3d 20 31 30 7d 0a   t1 SET a = 10}.
d520: 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65  } {}.do_test fke
d530: 79 32 2d 67 65 6e 66 6b 65 79 2e 31 2e 31 39 20  y2-genfkey.1.19 
d540: 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 20 55  {.  catchsql { U
d550: 50 44 41 54 45 20 74 33 20 53 45 54 20 68 20 3d  PDATE t3 SET h =
d560: 20 27 68 65 6c 6c 6f 27 20 57 48 45 52 45 20 69   'hello' WHERE i
d570: 20 3d 20 33 7d 0a 7d 20 7b 31 20 7b 66 6f 72 65   = 3}.} {1 {fore
d580: 69 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61 69  ign key constrai
d590: 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 0a 64 72 6f  nt failed}}..dro
d5a0: 70 5f 61 6c 6c 5f 74 61 62 6c 65 73 0a 64 6f 5f  p_all_tables.do_
d5b0: 74 65 73 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b  test fkey2-genfk
d5c0: 65 79 2e 32 2e 31 20 7b 0a 20 20 65 78 65 63 73  ey.2.1 {.  execs
d5d0: 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  ql {.    CREATE 
d5e0: 54 41 42 4c 45 20 74 31 28 61 20 49 4e 54 45 47  TABLE t1(a INTEG
d5f0: 45 52 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20  ER PRIMARY KEY, 
d600: 62 2c 20 63 2c 20 55 4e 49 51 55 45 28 62 2c 20  b, c, UNIQUE(b, 
d610: 63 29 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20  c));.    CREATE 
d620: 54 41 42 4c 45 20 74 32 28 65 20 52 45 46 45 52  TABLE t2(e REFER
d630: 45 4e 43 45 53 20 74 31 20 4f 4e 20 55 50 44 41  ENCES t1 ON UPDA
d640: 54 45 20 43 41 53 43 41 44 45 20 4f 4e 20 44 45  TE CASCADE ON DE
d650: 4c 45 54 45 20 43 41 53 43 41 44 45 2c 20 66 29  LETE CASCADE, f)
d660: 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42  ;.    CREATE TAB
d670: 4c 45 20 74 33 28 67 2c 20 68 2c 20 69 2c 20 0a  LE t3(g, h, i, .
d680: 20 20 20 20 20 20 20 20 46 4f 52 45 49 47 4e 20          FOREIGN 
d690: 4b 45 59 20 28 68 2c 20 69 29 20 0a 20 20 20 20  KEY (h, i) .    
d6a0: 20 20 20 20 52 45 46 45 52 45 4e 43 45 53 20 74      REFERENCES t
d6b0: 31 28 62 2c 20 63 29 20 4f 4e 20 55 50 44 41 54  1(b, c) ON UPDAT
d6c0: 45 20 43 41 53 43 41 44 45 20 4f 4e 20 44 45 4c  E CASCADE ON DEL
d6d0: 45 54 45 20 43 41 53 43 41 44 45 0a 20 20 20 20  ETE CASCADE.    
d6e0: 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74  );.  }.} {}.do_t
d6f0: 65 73 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b 65  est fkey2-genfke
d700: 79 2e 32 2e 32 20 7b 0a 20 20 65 78 65 63 73 71  y.2.2 {.  execsq
d710: 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  l {.    INSERT I
d720: 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 31 2c  NTO t1 VALUES(1,
d730: 20 32 2c 20 33 29 3b 0a 20 20 20 20 49 4e 53 45   2, 3);.    INSE
d740: 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45  RT INTO t1 VALUE
d750: 53 28 34 2c 20 35 2c 20 36 29 3b 0a 20 20 20 20  S(4, 5, 6);.    
d760: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 20 56  INSERT INTO t2 V
d770: 41 4c 55 45 53 28 31 2c 20 27 6f 6e 65 27 29 3b  ALUES(1, 'one');
d780: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
d790: 20 74 32 20 56 41 4c 55 45 53 28 34 2c 20 27 66   t2 VALUES(4, 'f
d7a0: 6f 75 72 27 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a  our');.  }.} {}.
d7b0: 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 67 65  do_test fkey2-ge
d7c0: 6e 66 6b 65 79 2e 32 2e 33 20 7b 0a 20 20 65 78  nfkey.2.3 {.  ex
d7d0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 55 50 44 41  ecsql {.    UPDA
d7e0: 54 45 20 74 31 20 53 45 54 20 61 20 3d 20 32 20  TE t1 SET a = 2 
d7f0: 57 48 45 52 45 20 61 20 3d 20 31 3b 0a 20 20 20  WHERE a = 1;.   
d800: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
d810: 32 3b 0a 20 20 7d 0a 7d 20 7b 32 20 6f 6e 65 20  2;.  }.} {2 one 
d820: 34 20 66 6f 75 72 7d 0a 64 6f 5f 74 65 73 74 20  4 four}.do_test 
d830: 66 6b 65 79 32 2d 67 65 6e 66 6b 65 79 2e 32 2e  fkey2-genfkey.2.
d840: 34 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  4 {.  execsql {.
d850: 20 20 20 20 44 45 4c 45 54 45 20 46 52 4f 4d 20      DELETE FROM 
d860: 74 31 20 57 48 45 52 45 20 61 20 3d 20 34 3b 0a  t1 WHERE a = 4;.
d870: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
d880: 4d 20 74 32 3b 0a 20 20 7d 0a 7d 20 7b 32 20 6f  M t2;.  }.} {2 o
d890: 6e 65 7d 0a 0a 64 6f 5f 74 65 73 74 20 66 6b 65  ne}..do_test fke
d8a0: 79 32 2d 67 65 6e 66 6b 65 79 2e 32 2e 35 20 7b  y2-genfkey.2.5 {
d8b0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
d8c0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 33 20   INSERT INTO t3 
d8d0: 56 41 4c 55 45 53 28 27 68 65 6c 6c 6f 27 2c 20  VALUES('hello', 
d8e0: 32 2c 20 33 29 3b 0a 20 20 20 20 55 50 44 41 54  2, 3);.    UPDAT
d8f0: 45 20 74 31 20 53 45 54 20 63 20 3d 20 32 3b 0a  E t1 SET c = 2;.
d900: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
d910: 4d 20 74 33 3b 0a 20 20 7d 0a 7d 20 7b 68 65 6c  M t3;.  }.} {hel
d920: 6c 6f 20 32 20 32 7d 0a 64 6f 5f 74 65 73 74 20  lo 2 2}.do_test 
d930: 66 6b 65 79 32 2d 67 65 6e 66 6b 65 79 2e 32 2e  fkey2-genfkey.2.
d940: 36 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  6 {.  execsql {.
d950: 20 20 20 20 44 45 4c 45 54 45 20 46 52 4f 4d 20      DELETE FROM 
d960: 74 31 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a  t1;.    SELECT *
d970: 20 46 52 4f 4d 20 74 33 3b 0a 20 20 7d 0a 7d 20   FROM t3;.  }.} 
d980: 7b 7d 0a 0a 64 72 6f 70 5f 61 6c 6c 5f 74 61 62  {}..drop_all_tab
d990: 6c 65 73 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79  les.do_test fkey
d9a0: 32 2d 67 65 6e 66 6b 65 79 2e 33 2e 31 20 7b 0a  2-genfkey.3.1 {.
d9b0: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
d9c0: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28  CREATE TABLE t1(
d9d0: 61 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52  a INTEGER PRIMAR
d9e0: 59 20 4b 45 59 2c 20 62 2c 20 63 2c 20 55 4e 49  Y KEY, b, c, UNI
d9f0: 51 55 45 28 63 2c 20 62 29 29 3b 0a 20 20 20 20  QUE(c, b));.    
da00: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 32 28  CREATE TABLE t2(
da10: 65 20 52 45 46 45 52 45 4e 43 45 53 20 74 31 20  e REFERENCES t1 
da20: 4f 4e 20 55 50 44 41 54 45 20 53 45 54 20 4e 55  ON UPDATE SET NU
da30: 4c 4c 20 4f 4e 20 44 45 4c 45 54 45 20 53 45 54  LL ON DELETE SET
da40: 20 4e 55 4c 4c 2c 20 66 29 3b 0a 20 20 20 20 43   NULL, f);.    C
da50: 52 45 41 54 45 20 54 41 42 4c 45 20 74 33 28 67  REATE TABLE t3(g
da60: 2c 20 68 2c 20 69 2c 20 0a 20 20 20 20 20 20 20  , h, i, .       
da70: 20 46 4f 52 45 49 47 4e 20 4b 45 59 20 28 68 2c   FOREIGN KEY (h,
da80: 20 69 29 20 0a 20 20 20 20 20 20 20 20 52 45 46   i) .        REF
da90: 45 52 45 4e 43 45 53 20 74 31 28 62 2c 20 63 29  ERENCES t1(b, c)
daa0: 20 4f 4e 20 55 50 44 41 54 45 20 53 45 54 20 4e   ON UPDATE SET N
dab0: 55 4c 4c 20 4f 4e 20 44 45 4c 45 54 45 20 53 45  ULL ON DELETE SE
dac0: 54 20 4e 55 4c 4c 0a 20 20 20 20 29 3b 0a 20 20  T NULL.    );.  
dad0: 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 66  }.} {}.do_test f
dae0: 6b 65 79 32 2d 67 65 6e 66 6b 65 79 2e 33 2e 32  key2-genfkey.3.2
daf0: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   {.  execsql {. 
db00: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
db10: 31 20 56 41 4c 55 45 53 28 31 2c 20 32 2c 20 33  1 VALUES(1, 2, 3
db20: 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  );.    INSERT IN
db30: 54 4f 20 74 31 20 56 41 4c 55 45 53 28 34 2c 20  TO t1 VALUES(4, 
db40: 35 2c 20 36 29 3b 0a 20 20 20 20 49 4e 53 45 52  5, 6);.    INSER
db50: 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53  T INTO t2 VALUES
db60: 28 31 2c 20 27 6f 6e 65 27 29 3b 0a 20 20 20 20  (1, 'one');.    
db70: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 20 56  INSERT INTO t2 V
db80: 41 4c 55 45 53 28 34 2c 20 27 66 6f 75 72 27 29  ALUES(4, 'four')
db90: 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65  ;.  }.} {}.do_te
dba0: 73 74 20 66 6b 65 79 32 2d 67 65 6e 66 6b 65 79  st fkey2-genfkey
dbb0: 2e 33 2e 33 20 7b 0a 20 20 65 78 65 63 73 71 6c  .3.3 {.  execsql
dbc0: 20 7b 0a 20 20 20 20 55 50 44 41 54 45 20 74 31   {.    UPDATE t1
dbd0: 20 53 45 54 20 61 20 3d 20 32 20 57 48 45 52 45   SET a = 2 WHERE
dbe0: 20 61 20 3d 20 31 3b 0a 20 20 20 20 53 45 4c 45   a = 1;.    SELE
dbf0: 43 54 20 2a 20 46 52 4f 4d 20 74 32 3b 0a 20 20  CT * FROM t2;.  
dc00: 7d 0a 7d 20 7b 7b 7d 20 6f 6e 65 20 34 20 66 6f  }.} {{} one 4 fo
dc10: 75 72 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79  ur}.do_test fkey
dc20: 32 2d 67 65 6e 66 6b 65 79 2e 33 2e 34 20 7b 0a  2-genfkey.3.4 {.
dc30: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
dc40: 44 45 4c 45 54 45 20 46 52 4f 4d 20 74 31 20 57  DELETE FROM t1 W
dc50: 48 45 52 45 20 61 20 3d 20 34 3b 0a 20 20 20 20  HERE a = 4;.    
dc60: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 32  SELECT * FROM t2
dc70: 3b 0a 20 20 7d 0a 7d 20 7b 7b 7d 20 6f 6e 65 20  ;.  }.} {{} one 
dc80: 7b 7d 20 66 6f 75 72 7d 0a 64 6f 5f 74 65 73 74  {} four}.do_test
dc90: 20 66 6b 65 79 32 2d 67 65 6e 66 6b 65 79 2e 33   fkey2-genfkey.3
dca0: 2e 35 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .5 {.  execsql {
dcb0: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
dcc0: 20 74 33 20 56 41 4c 55 45 53 28 27 68 65 6c 6c   t3 VALUES('hell
dcd0: 6f 27 2c 20 32 2c 20 33 29 3b 0a 20 20 20 20 55  o', 2, 3);.    U
dce0: 50 44 41 54 45 20 74 31 20 53 45 54 20 63 20 3d  PDATE t1 SET c =
dcf0: 20 32 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a   2;.    SELECT *
dd00: 20 46 52 4f 4d 20 74 33 3b 0a 20 20 7d 0a 7d 20   FROM t3;.  }.} 
dd10: 7b 68 65 6c 6c 6f 20 7b 7d 20 7b 7d 7d 0a 64 6f  {hello {} {}}.do
dd20: 5f 74 65 73 74 20 66 6b 65 79 32 2d 67 65 6e 66  _test fkey2-genf
dd30: 6b 65 79 2e 33 2e 36 20 7b 0a 20 20 65 78 65 63  key.3.6 {.  exec
dd40: 73 71 6c 20 7b 0a 20 20 20 20 55 50 44 41 54 45  sql {.    UPDATE
dd50: 20 74 33 20 53 45 54 20 68 20 3d 20 32 2c 20 69   t3 SET h = 2, i
dd60: 20 3d 20 32 3b 0a 20 20 20 20 44 45 4c 45 54 45   = 2;.    DELETE
dd70: 20 46 52 4f 4d 20 74 31 3b 0a 20 20 20 20 53 45   FROM t1;.    SE
dd80: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 33 3b 0a  LECT * FROM t3;.
dd90: 20 20 7d 0a 7d 20 7b 68 65 6c 6c 6f 20 7b 7d 20    }.} {hello {} 
dda0: 7b 7d 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  {}}..#----------
ddb0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
ddc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
ddd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
dde0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a  ---------------.
ddf0: 23 20 56 65 72 69 66 79 20 74 68 61 74 20 74 69  # Verify that ti
de00: 63 6b 65 74 20 64 64 30 38 65 35 61 39 38 38 64  cket dd08e5a988d
de10: 30 30 64 65 63 63 34 61 35 34 33 64 61 61 38 64  00decc4a543daa8d
de20: 62 62 66 61 62 39 63 35 37 37 61 64 38 20 68 61  bbfab9c577ad8 ha
de30: 73 20 62 65 65 6e 0a 23 20 66 69 78 65 64 2e 0a  s been.# fixed..
de40: 23 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d  #.do_test fkey2-
de50: 64 64 30 38 65 35 2e 31 2e 31 20 7b 0a 20 20 65  dd08e5.1.1 {.  e
de60: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 50 52 41  xecsql {.    PRA
de70: 47 4d 41 20 66 6f 72 65 69 67 6e 5f 6b 65 79 73  GMA foreign_keys
de80: 3d 4f 4e 3b 0a 20 20 20 20 43 52 45 41 54 45 20  =ON;.    CREATE 
de90: 54 41 42 4c 45 20 74 64 64 30 38 28 61 20 49 4e  TABLE tdd08(a IN
dea0: 54 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b 45  TEGER PRIMARY KE
deb0: 59 2c 20 62 29 3b 0a 20 20 20 20 43 52 45 41 54  Y, b);.    CREAT
dec0: 45 20 55 4e 49 51 55 45 20 49 4e 44 45 58 20 69  E UNIQUE INDEX i
ded0: 64 64 30 38 20 4f 4e 20 74 64 64 30 38 28 61 2c  dd08 ON tdd08(a,
dee0: 62 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  b);.    INSERT I
def0: 4e 54 4f 20 74 64 64 30 38 20 56 41 4c 55 45 53  NTO tdd08 VALUES
df00: 28 32 30 30 2c 33 30 30 29 3b 0a 0a 20 20 20 20  (200,300);..    
df10: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 64 64  CREATE TABLE tdd
df20: 30 38 5f 62 28 77 2c 78 2c 79 2c 20 46 4f 52 45  08_b(w,x,y, FORE
df30: 49 47 4e 20 4b 45 59 28 78 2c 79 29 20 52 45 46  IGN KEY(x,y) REF
df40: 45 52 45 4e 43 45 53 20 74 64 64 30 38 28 61 2c  ERENCES tdd08(a,
df50: 62 29 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  b));.    INSERT 
df60: 49 4e 54 4f 20 74 64 64 30 38 5f 62 20 56 41 4c  INTO tdd08_b VAL
df70: 55 45 53 28 31 30 30 2c 32 30 30 2c 33 30 30 29  UES(100,200,300)
df80: 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65  ;.  }.} {}.do_te
df90: 73 74 20 66 6b 65 79 32 2d 64 64 30 38 65 35 2e  st fkey2-dd08e5.
dfa0: 31 2e 32 20 7b 0a 20 20 63 61 74 63 68 73 71 6c  1.2 {.  catchsql
dfb0: 20 7b 0a 20 20 20 20 44 45 4c 45 54 45 20 46 52   {.    DELETE FR
dfc0: 4f 4d 20 74 64 64 30 38 3b 0a 20 20 7d 0a 7d 20  OM tdd08;.  }.} 
dfd0: 7b 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65 79 20  {1 {foreign key 
dfe0: 63 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65  constraint faile
dff0: 64 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79  d}}.do_test fkey
e000: 32 2d 64 64 30 38 65 35 2e 31 2e 33 20 7b 0a 20  2-dd08e5.1.3 {. 
e010: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53   execsql {.    S
e020: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 64 64  ELECT * FROM tdd
e030: 30 38 3b 0a 20 20 7d 0a 7d 20 7b 32 30 30 20 33  08;.  }.} {200 3
e040: 30 30 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79  00}.do_test fkey
e050: 32 2d 64 64 30 38 65 35 2e 31 2e 34 20 7b 0a 20  2-dd08e5.1.4 {. 
e060: 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20   catchsql {.    
e070: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 64 64 30  INSERT INTO tdd0
e080: 38 5f 62 20 56 41 4c 55 45 53 28 34 30 30 2c 35  8_b VALUES(400,5
e090: 30 30 2c 33 30 30 29 3b 0a 20 20 7d 0a 7d 20 7b  00,300);.  }.} {
e0a0: 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65 79 20 63  1 {foreign key c
e0b0: 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64  onstraint failed
e0c0: 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  }}.do_test fkey2
e0d0: 2d 64 64 30 38 65 35 2e 31 2e 35 20 7b 0a 20 20  -dd08e5.1.5 {.  
e0e0: 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 55  catchsql {.    U
e0f0: 50 44 41 54 45 20 74 64 64 30 38 5f 62 20 53 45  PDATE tdd08_b SE
e100: 54 20 78 3d 78 2b 31 3b 0a 20 20 7d 0a 7d 20 7b  T x=x+1;.  }.} {
e110: 31 20 7b 66 6f 72 65 69 67 6e 20 6b 65 79 20 63  1 {foreign key c
e120: 6f 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64  onstraint failed
e130: 7d 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32  }}.do_test fkey2
e140: 2d 64 64 30 38 65 35 2e 31 2e 36 20 7b 0a 20 20  -dd08e5.1.6 {.  
e150: 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 55  catchsql {.    U
e160: 50 44 41 54 45 20 74 64 64 30 38 20 53 45 54 20  PDATE tdd08 SET 
e170: 61 3d 61 2b 31 3b 0a 20 20 7d 0a 7d 20 7b 31 20  a=a+1;.  }.} {1 
e180: 7b 66 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e  {foreign key con
e190: 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d  straint failed}}
e1a0: 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ..#-------------
e1b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
e1c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
e1d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
e1e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 56  ------------.# V
e1f0: 65 72 69 66 79 20 74 68 61 74 20 74 69 63 6b 65  erify that ticke
e200: 74 20 63 65 37 63 31 33 33 65 61 36 63 63 39 63  t ce7c133ea6cc9c
e210: 63 64 63 31 61 36 30 64 38 30 34 34 31 66 38 30  cdc1a60d80441f80
e220: 62 36 31 38 30 66 35 65 62 61 0a 23 20 66 69 78  b6180f5eba.# fix
e230: 65 64 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 66 6b  ed..#.do_test fk
e240: 65 79 32 2d 63 65 37 63 31 33 2e 31 2e 31 20 7b  ey2-ce7c13.1.1 {
e250: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
e260: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 63   CREATE TABLE tc
e270: 65 37 31 28 61 20 49 4e 54 45 47 45 52 20 50 52  e71(a INTEGER PR
e280: 49 4d 41 52 59 20 4b 45 59 2c 20 62 29 3b 0a 20  IMARY KEY, b);. 
e290: 20 20 20 43 52 45 41 54 45 20 55 4e 49 51 55 45     CREATE UNIQUE
e2a0: 20 49 4e 44 45 58 20 69 63 65 37 31 20 4f 4e 20   INDEX ice71 ON 
e2b0: 74 63 65 37 31 28 61 2c 62 29 3b 0a 20 20 20 20  tce71(a,b);.    
e2c0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 63 65 37  INSERT INTO tce7
e2d0: 31 20 56 41 4c 55 45 53 28 31 30 30 2c 32 30 30  1 VALUES(100,200
e2e0: 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41  );.    CREATE TA
e2f0: 42 4c 45 20 74 63 65 37 32 28 77 2c 20 78 2c 20  BLE tce72(w, x, 
e300: 79 2c 20 46 4f 52 45 49 47 4e 20 4b 45 59 28 78  y, FOREIGN KEY(x
e310: 2c 79 29 20 52 45 46 45 52 45 4e 43 45 53 20 74  ,y) REFERENCES t
e320: 63 65 37 31 28 61 2c 62 29 29 3b 0a 20 20 20 20  ce71(a,b));.    
e330: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 63 65 37  INSERT INTO tce7
e340: 32 20 56 41 4c 55 45 53 28 33 30 30 2c 31 30 30  2 VALUES(300,100
e350: 2c 32 30 30 29 3b 0a 20 20 20 20 55 50 44 41 54  ,200);.    UPDAT
e360: 45 20 74 63 65 37 31 20 73 65 74 20 62 20 3d 20  E tce71 set b = 
e370: 32 30 30 20 77 68 65 72 65 20 61 20 3d 20 31 30  200 where a = 10
e380: 30 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20  0;.    SELECT * 
e390: 46 52 4f 4d 20 74 63 65 37 31 2c 20 74 63 65 37  FROM tce71, tce7
e3a0: 32 3b 0a 20 20 7d 0a 7d 20 7b 31 30 30 20 32 30  2;.  }.} {100 20
e3b0: 30 20 33 30 30 20 31 30 30 20 32 30 30 7d 0a 64  0 300 100 200}.d
e3c0: 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d 63 65 37  o_test fkey2-ce7
e3d0: 63 31 33 2e 31 2e 32 20 7b 0a 20 20 63 61 74 63  c13.1.2 {.  catc
e3e0: 68 73 71 6c 20 7b 0a 20 20 20 20 55 50 44 41 54  hsql {.    UPDAT
e3f0: 45 20 74 63 65 37 31 20 73 65 74 20 62 20 3d 20  E tce71 set b = 
e400: 32 30 31 20 77 68 65 72 65 20 61 20 3d 20 31 30  201 where a = 10
e410: 30 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 66 6f 72  0;.  }.} {1 {for
e420: 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61  eign key constra
e430: 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a 64 6f 5f  int failed}}.do_
e440: 74 65 73 74 20 66 6b 65 79 32 2d 63 65 37 63 31  test fkey2-ce7c1
e450: 33 2e 31 2e 33 20 7b 0a 20 20 63 61 74 63 68 73  3.1.3 {.  catchs
e460: 71 6c 20 7b 0a 20 20 20 20 55 50 44 41 54 45 20  ql {.    UPDATE 
e470: 74 63 65 37 31 20 73 65 74 20 61 20 3d 20 31 30  tce71 set a = 10
e480: 31 20 77 68 65 72 65 20 61 20 3d 20 31 30 30 3b  1 where a = 100;
e490: 0a 20 20 7d 0a 7d 20 7b 31 20 7b 66 6f 72 65 69  .  }.} {1 {forei
e4a0: 67 6e 20 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e  gn key constrain
e4b0: 74 20 66 61 69 6c 65 64 7d 7d 0a 64 6f 5f 74 65  t failed}}.do_te
e4c0: 73 74 20 66 6b 65 79 32 2d 63 65 37 63 31 33 2e  st fkey2-ce7c13.
e4d0: 31 2e 34 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  1.4 {.  execsql 
e4e0: 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42  {.    CREATE TAB
e4f0: 4c 45 20 74 63 65 37 33 28 61 20 49 4e 54 45 47  LE tce73(a INTEG
e500: 45 52 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20  ER PRIMARY KEY, 
e510: 62 2c 20 55 4e 49 51 55 45 28 61 2c 62 29 29 3b  b, UNIQUE(a,b));
e520: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
e530: 20 74 63 65 37 33 20 56 41 4c 55 45 53 28 31 30   tce73 VALUES(10
e540: 30 2c 32 30 30 29 3b 0a 20 20 20 20 43 52 45 41  0,200);.    CREA
e550: 54 45 20 54 41 42 4c 45 20 74 63 65 37 34 28 77  TE TABLE tce74(w
e560: 2c 20 78 2c 20 79 2c 20 46 4f 52 45 49 47 4e 20  , x, y, FOREIGN 
e570: 4b 45 59 28 78 2c 79 29 20 52 45 46 45 52 45 4e  KEY(x,y) REFEREN
e580: 43 45 53 20 74 63 65 37 33 28 61 2c 62 29 29 3b  CES tce73(a,b));
e590: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
e5a0: 20 74 63 65 37 34 20 56 41 4c 55 45 53 28 33 30   tce74 VALUES(30
e5b0: 30 2c 31 30 30 2c 32 30 30 29 3b 0a 20 20 20 20  0,100,200);.    
e5c0: 55 50 44 41 54 45 20 74 63 65 37 33 20 73 65 74  UPDATE tce73 set
e5d0: 20 62 20 3d 20 32 30 30 20 77 68 65 72 65 20 61   b = 200 where a
e5e0: 20 3d 20 31 30 30 3b 0a 20 20 20 20 53 45 4c 45   = 100;.    SELE
e5f0: 43 54 20 2a 20 46 52 4f 4d 20 74 63 65 37 33 2c  CT * FROM tce73,
e600: 20 74 63 65 37 34 3b 0a 20 20 7d 0a 7d 20 7b 31   tce74;.  }.} {1
e610: 30 30 20 32 30 30 20 33 30 30 20 31 30 30 20 32  00 200 300 100 2
e620: 30 30 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79  00}.do_test fkey
e630: 32 2d 63 65 37 63 31 33 2e 31 2e 35 20 7b 0a 20  2-ce7c13.1.5 {. 
e640: 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20   catchsql {.    
e650: 55 50 44 41 54 45 20 74 63 65 37 33 20 73 65 74  UPDATE tce73 set
e660: 20 62 20 3d 20 32 30 31 20 77 68 65 72 65 20 61   b = 201 where a
e670: 20 3d 20 31 30 30 3b 0a 20 20 7d 0a 7d 20 7b 31   = 100;.  }.} {1
e680: 20 7b 66 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f   {foreign key co
e690: 6e 73 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d  nstraint failed}
e6a0: 7d 0a 64 6f 5f 74 65 73 74 20 66 6b 65 79 32 2d  }.do_test fkey2-
e6b0: 63 65 37 63 31 33 2e 31 2e 36 20 7b 0a 20 20 63  ce7c13.1.6 {.  c
e6c0: 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 55 50  atchsql {.    UP
e6d0: 44 41 54 45 20 74 63 65 37 33 20 73 65 74 20 61  DATE tce73 set a
e6e0: 20 3d 20 31 30 31 20 77 68 65 72 65 20 61 20 3d   = 101 where a =
e6f0: 20 31 30 30 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b   100;.  }.} {1 {
e700: 66 6f 72 65 69 67 6e 20 6b 65 79 20 63 6f 6e 73  foreign key cons
e710: 74 72 61 69 6e 74 20 66 61 69 6c 65 64 7d 7d 0a  traint failed}}.
e720: 0a 66 69 6e 69 73 68 5f 74 65 73 74 0a           .finish_test.