/ Hex Artifact Content
Login
SQLite training in Houston TX on 2019-11-05 (details)
Part of the 2019 Tcl Conference

Artifact 906408621ea881fdb496d878b1822572a34e32c5:


0000: 23 20 32 30 30 36 20 4e 6f 76 65 6d 62 65 72 20  # 2006 November 
0010: 30 38 0a 23 0a 23 20 54 68 65 20 61 75 74 68 6f  08.#.# The autho
0020: 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70 79  r disclaims copy
0030: 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73 6f  right to this so
0040: 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20 70  urce code.  In p
0050: 6c 61 63 65 20 6f 66 0a 23 20 61 20 6c 65 67 61  lace of.# a lega
0060: 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65 20 69  l notice, here i
0070: 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a 23 0a  s a blessing:.#.
0080: 23 20 20 20 20 4d 61 79 20 79 6f 75 20 64 6f 20  #    May you do 
0090: 67 6f 6f 64 20 61 6e 64 20 6e 6f 74 20 65 76 69  good and not evi
00a0: 6c 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20  l..#    May you 
00b0: 66 69 6e 64 20 66 6f 72 67 69 76 65 6e 65 73 73  find forgiveness
00c0: 20 66 6f 72 20 79 6f 75 72 73 65 6c 66 20 61 6e   for yourself an
00d0: 64 20 66 6f 72 67 69 76 65 20 6f 74 68 65 72 73  d forgive others
00e0: 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20 73  ..#    May you s
00f0: 68 61 72 65 20 66 72 65 65 6c 79 2c 20 6e 65 76  hare freely, nev
0100: 65 72 20 74 61 6b 69 6e 67 20 6d 6f 72 65 20 74  er taking more t
0110: 68 61 6e 20 79 6f 75 20 67 69 76 65 2e 0a 23 0a  han you give..#.
0120: 23 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  #***************
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 2a 2a 2a 2a 2a 0a 23 20 54 68 69 73 20  ********.# This 
0170: 66 69 6c 65 20 69 6d 70 6c 65 6d 65 6e 74 73 20  file implements 
0180: 72 65 67 72 65 73 73 69 6f 6e 20 74 65 73 74 73  regression tests
0190: 20 66 6f 72 20 53 51 4c 69 74 65 20 6c 69 62 72   for SQLite libr
01a0: 61 72 79 2e 0a 23 0a 23 20 54 68 69 73 20 66 69  ary..#.# This fi
01b0: 6c 65 20 74 65 73 74 73 20 74 68 65 20 76 61 72  le tests the var
01c0: 69 6f 75 73 20 63 6f 6e 64 69 74 69 6f 6e 73 20  ious conditions 
01d0: 75 6e 64 65 72 20 77 68 69 63 68 20 61 6e 20 53  under which an S
01e0: 51 4c 49 54 45 5f 53 43 48 45 4d 41 0a 23 20 65  QLITE_SCHEMA.# e
01f0: 72 72 6f 72 20 73 68 6f 75 6c 64 20 62 65 20 72  rror should be r
0200: 65 74 75 72 6e 65 64 2e 20 20 54 68 69 73 20 69  eturned.  This i
0210: 73 20 61 20 63 6f 70 79 20 6f 66 20 73 63 68 65  s a copy of sche
0220: 6d 61 2e 74 65 73 74 20 74 68 61 74 0a 23 20 68  ma.test that.# h
0230: 61 73 20 62 65 65 6e 20 61 6c 74 65 72 65 64 20  as been altered 
0240: 74 6f 20 75 73 65 20 73 71 6c 69 74 65 33 5f 70  to use sqlite3_p
0250: 72 65 70 61 72 65 5f 76 32 20 69 6e 73 74 65 61  repare_v2 instea
0260: 64 20 6f 66 20 73 71 6c 69 74 65 33 5f 70 72 65  d of sqlite3_pre
0270: 70 61 72 65 0a 23 0a 23 20 24 49 64 3a 20 73 63  pare.#.# $Id: sc
0280: 68 65 6d 61 32 2e 74 65 73 74 2c 76 20 31 2e 34  hema2.test,v 1.4
0290: 20 32 30 30 39 2f 30 32 2f 30 34 20 31 37 3a 34   2009/02/04 17:4
02a0: 30 3a 35 38 20 64 72 68 20 45 78 70 20 24 0a 0a  0:58 drh Exp $..
02b0: 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  #---------------
02c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
02d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
02e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
02f0: 2d 2d 2d 2d 2d 2d 0a 23 20 57 68 65 6e 20 61 6e  ------.# When an
0300: 79 20 6f 66 20 74 68 65 20 66 6f 6c 6c 6f 77 69  y of the followi
0310: 6e 67 20 74 79 70 65 73 20 6f 66 20 53 51 4c 20  ng types of SQL 
0320: 73 74 61 74 65 6d 65 6e 74 73 20 6f 72 20 61 63  statements or ac
0330: 74 69 6f 6e 73 20 61 72 65 20 0a 23 20 65 78 65  tions are .# exe
0340: 63 75 74 65 64 2c 20 61 6c 6c 20 70 72 65 2d 63  cuted, all pre-c
0350: 6f 6d 70 69 6c 65 64 20 73 74 61 74 65 6d 65 6e  ompiled statemen
0360: 74 73 20 61 72 65 20 69 6e 76 61 6c 69 64 61 74  ts are invalidat
0370: 65 64 2e 20 41 6e 20 61 74 74 65 6d 70 74 0a 23  ed. An attempt.#
0380: 20 74 6f 20 65 78 65 63 75 74 65 20 61 6e 20 69   to execute an i
0390: 6e 76 61 6c 69 64 61 74 65 64 20 73 74 61 74 65  nvalidated state
03a0: 6d 65 6e 74 20 61 6c 77 61 79 73 20 72 65 74 75  ment always retu
03b0: 72 6e 73 20 53 51 4c 49 54 45 5f 53 43 48 45 4d  rns SQLITE_SCHEM
03c0: 41 2e 0a 23 0a 23 20 43 52 45 41 54 45 2f 44 52  A..#.# CREATE/DR
03d0: 4f 50 20 54 41 42 4c 45 2e 2e 2e 2e 2e 2e 2e 2e  OP TABLE........
03e0: 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e  ................
03f0: 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 73 63 68 65 6d  ...........schem
0400: 61 32 2d 31 2e 2a 0a 23 20 43 52 45 41 54 45 2f  a2-1.*.# CREATE/
0410: 44 52 4f 50 20 56 49 45 57 2e 2e 2e 2e 2e 2e 2e  DROP VIEW.......
0420: 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e  ................
0430: 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 73 63 68  .............sch
0440: 65 6d 61 32 2d 32 2e 2a 0a 23 20 43 52 45 41 54  ema2-2.*.# CREAT
0450: 45 2f 44 52 4f 50 20 54 52 49 47 47 45 52 2e 2e  E/DROP TRIGGER..
0460: 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e  ................
0470: 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 73  ...............s
0480: 63 68 65 6d 61 32 2d 33 2e 2a 0a 23 20 43 52 45  chema2-3.*.# CRE
0490: 41 54 45 2f 44 52 4f 50 20 49 4e 44 45 58 2e 2e  ATE/DROP INDEX..
04a0: 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e  ................
04b0: 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e  ................
04c0: 2e 73 63 68 65 6d 61 32 2d 34 2e 2a 0a 23 20 44  .schema2-4.*.# D
04d0: 45 54 41 43 48 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e  ETACH...........
04e0: 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e  ................
04f0: 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e  ................
0500: 2e 2e 2e 73 63 68 65 6d 61 32 2d 35 2e 2a 0a 23  ...schema2-5.*.#
0510: 20 44 65 6c 65 74 69 6e 67 20 61 20 75 73 65 72   Deleting a user
0520: 2d 66 75 6e 63 74 69 6f 6e 2e 2e 2e 2e 2e 2e 2e  -function.......
0530: 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e  ................
0540: 2e 2e 2e 2e 2e 73 63 68 65 6d 61 32 2d 36 2e 2a  .....schema2-6.*
0550: 0a 23 20 44 65 6c 65 74 69 6e 67 20 61 20 63 6f  .# Deleting a co
0560: 6c 6c 61 74 69 6f 6e 20 73 65 71 75 65 6e 63 65  llation sequence
0570: 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e  ................
0580: 2e 2e 2e 2e 2e 2e 2e 73 63 68 65 6d 61 32 2d 37  .......schema2-7
0590: 2e 2a 0a 23 20 53 65 74 74 69 6e 67 20 6f 72 20  .*.# Setting or 
05a0: 63 68 61 6e 67 69 6e 67 20 74 68 65 20 61 75 74  changing the aut
05b0: 68 6f 72 69 7a 61 74 69 6f 6e 20 66 75 6e 63 74  horization funct
05c0: 69 6f 6e 2e 2e 2e 2e 2e 2e 73 63 68 65 6d 61 32  ion......schema2
05d0: 2d 38 2e 2a 0a 23 0a 23 20 54 65 73 74 20 63 61  -8.*.#.# Test ca
05e0: 73 65 73 20 73 63 68 65 6d 61 32 2d 39 2e 2a 20  ses schema2-9.* 
05f0: 61 6e 64 20 73 63 68 65 6d 61 32 2d 31 30 2e 2a  and schema2-10.*
0600: 20 74 65 73 74 20 73 6f 6d 65 20 73 70 65 63 69   test some speci
0610: 66 69 63 20 62 75 67 73 0a 23 20 74 68 61 74 20  fic bugs.# that 
0620: 63 61 6d 65 20 75 70 20 64 75 72 69 6e 67 20 64  came up during d
0630: 65 76 65 6c 6f 70 6d 65 6e 74 2e 0a 23 0a 23 20  evelopment..#.# 
0640: 54 65 73 74 20 63 61 73 65 73 20 73 63 68 65 6d  Test cases schem
0650: 61 32 2d 31 31 2e 2a 20 74 65 73 74 20 74 68 61  a2-11.* test tha
0660: 74 20 69 74 20 69 73 20 69 6d 70 6f 73 73 69 62  t it is impossib
0670: 6c 65 20 74 6f 20 64 65 6c 65 74 65 20 6f 72 0a  le to delete or.
0680: 23 20 63 68 61 6e 67 65 20 61 20 63 6f 6c 6c 61  # change a colla
0690: 74 69 6f 6e 20 73 65 71 75 65 6e 63 65 20 6f 72  tion sequence or
06a0: 20 75 73 65 72 2d 66 75 6e 63 74 69 6f 6e 20 77   user-function w
06b0: 68 69 6c 65 20 53 51 4c 20 73 74 61 74 65 6d 65  hile SQL stateme
06c0: 6e 74 73 0a 23 20 61 72 65 20 65 78 65 63 75 74  nts.# are execut
06d0: 69 6e 67 2e 20 41 64 64 69 6e 67 20 6e 65 77 20  ing. Adding new 
06e0: 63 6f 6c 6c 61 74 69 6f 6e 73 20 6f 72 20 66 75  collations or fu
06f0: 6e 63 74 69 6f 6e 73 20 69 73 20 61 6c 6c 6f 77  nctions is allow
0700: 65 64 2e 0a 23 0a 0a 73 65 74 20 74 65 73 74 64  ed..#..set testd
0710: 69 72 20 5b 66 69 6c 65 20 64 69 72 6e 61 6d 65  ir [file dirname
0720: 20 24 61 72 67 76 30 5d 0a 73 6f 75 72 63 65 20   $argv0].source 
0730: 24 74 65 73 74 64 69 72 2f 74 65 73 74 65 72 2e  $testdir/tester.
0740: 74 63 6c 0a 0a 64 6f 5f 74 65 73 74 20 73 63 68  tcl..do_test sch
0750: 65 6d 61 32 2d 31 2e 31 20 7b 0a 20 20 73 65 74  ema2-1.1 {.  set
0760: 20 3a 3a 53 54 4d 54 20 5b 73 71 6c 69 74 65 33   ::STMT [sqlite3
0770: 5f 70 72 65 70 61 72 65 5f 76 32 20 24 3a 3a 44  _prepare_v2 $::D
0780: 42 20 7b 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d  B {SELECT * FROM
0790: 20 73 71 6c 69 74 65 5f 6d 61 73 74 65 72 7d 20   sqlite_master} 
07a0: 2d 31 20 54 41 49 4c 5d 0a 20 20 65 78 65 63 73  -1 TAIL].  execs
07b0: 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  ql {.    CREATE 
07c0: 54 41 42 4c 45 20 61 62 63 28 61 2c 20 62 2c 20  TABLE abc(a, b, 
07d0: 63 29 3b 0a 20 20 7d 0a 20 20 73 71 6c 69 74 65  c);.  }.  sqlite
07e0: 33 5f 73 74 65 70 20 24 3a 3a 53 54 4d 54 0a 7d  3_step $::STMT.}
07f0: 20 7b 53 51 4c 49 54 45 5f 52 4f 57 7d 0a 64 6f   {SQLITE_ROW}.do
0800: 5f 74 65 73 74 20 73 63 68 65 6d 61 32 2d 31 2e  _test schema2-1.
0810: 32 20 7b 0a 20 20 73 71 6c 69 74 65 33 5f 66 69  2 {.  sqlite3_fi
0820: 6e 61 6c 69 7a 65 20 24 3a 3a 53 54 4d 54 0a 7d  nalize $::STMT.}
0830: 20 7b 53 51 4c 49 54 45 5f 4f 4b 7d 0a 64 6f 5f   {SQLITE_OK}.do_
0840: 74 65 73 74 20 73 63 68 65 6d 61 32 2d 31 2e 33  test schema2-1.3
0850: 20 7b 0a 20 20 73 65 74 20 3a 3a 53 54 4d 54 20   {.  set ::STMT 
0860: 5b 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65  [sqlite3_prepare
0870: 5f 76 32 20 24 3a 3a 44 42 20 7b 53 45 4c 45 43  _v2 $::DB {SELEC
0880: 54 20 2a 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f  T * FROM sqlite_
0890: 6d 61 73 74 65 72 7d 20 2d 31 20 54 41 49 4c 5d  master} -1 TAIL]
08a0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
08b0: 20 44 52 4f 50 20 54 41 42 4c 45 20 61 62 63 3b   DROP TABLE abc;
08c0: 0a 20 20 7d 0a 20 20 73 71 6c 69 74 65 33 5f 73  .  }.  sqlite3_s
08d0: 74 65 70 20 24 3a 3a 53 54 4d 54 0a 7d 20 7b 53  tep $::STMT.} {S
08e0: 51 4c 49 54 45 5f 44 4f 4e 45 7d 0a 64 6f 5f 74  QLITE_DONE}.do_t
08f0: 65 73 74 20 73 63 68 65 6d 61 32 2d 31 2e 34 20  est schema2-1.4 
0900: 7b 0a 20 20 73 71 6c 69 74 65 33 5f 66 69 6e 61  {.  sqlite3_fina
0910: 6c 69 7a 65 20 24 3a 3a 53 54 4d 54 0a 7d 20 7b  lize $::STMT.} {
0920: 53 51 4c 49 54 45 5f 4f 4b 7d 0a 0a 0a 69 66 63  SQLITE_OK}...ifc
0930: 61 70 61 62 6c 65 20 76 69 65 77 20 7b 0a 20 20  apable view {.  
0940: 64 6f 5f 74 65 73 74 20 73 63 68 65 6d 61 32 2d  do_test schema2-
0950: 32 2e 31 20 7b 0a 20 20 20 20 73 65 74 20 3a 3a  2.1 {.    set ::
0960: 53 54 4d 54 20 5b 73 71 6c 69 74 65 33 5f 70 72  STMT [sqlite3_pr
0970: 65 70 61 72 65 5f 76 32 20 24 3a 3a 44 42 20 7b  epare_v2 $::DB {
0980: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 73 71  SELECT * FROM sq
0990: 6c 69 74 65 5f 6d 61 73 74 65 72 7d 20 2d 31 20  lite_master} -1 
09a0: 54 41 49 4c 5d 0a 20 20 20 20 65 78 65 63 73 71  TAIL].    execsq
09b0: 6c 20 7b 0a 20 20 20 20 20 20 43 52 45 41 54 45  l {.      CREATE
09c0: 20 56 49 45 57 20 76 31 20 41 53 20 53 45 4c 45   VIEW v1 AS SELE
09d0: 43 54 20 2a 20 46 52 4f 4d 20 73 71 6c 69 74 65  CT * FROM sqlite
09e0: 5f 6d 61 73 74 65 72 3b 0a 20 20 20 20 7d 0a 20  _master;.    }. 
09f0: 20 20 20 73 71 6c 69 74 65 33 5f 73 74 65 70 20     sqlite3_step 
0a00: 24 3a 3a 53 54 4d 54 0a 20 20 7d 20 7b 53 51 4c  $::STMT.  } {SQL
0a10: 49 54 45 5f 52 4f 57 7d 0a 20 20 64 6f 5f 74 65  ITE_ROW}.  do_te
0a20: 73 74 20 73 63 68 65 6d 61 32 2d 32 2e 32 20 7b  st schema2-2.2 {
0a30: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 66 69 6e  .    sqlite3_fin
0a40: 61 6c 69 7a 65 20 24 3a 3a 53 54 4d 54 0a 20 20  alize $::STMT.  
0a50: 7d 20 7b 53 51 4c 49 54 45 5f 4f 4b 7d 0a 20 20  } {SQLITE_OK}.  
0a60: 64 6f 5f 74 65 73 74 20 73 63 68 65 6d 61 32 2d  do_test schema2-
0a70: 32 2e 33 20 7b 0a 20 20 20 20 73 65 74 20 3a 3a  2.3 {.    set ::
0a80: 53 54 4d 54 20 5b 73 71 6c 69 74 65 33 5f 70 72  STMT [sqlite3_pr
0a90: 65 70 61 72 65 5f 76 32 20 24 3a 3a 44 42 20 7b  epare_v2 $::DB {
0aa0: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 73 71  SELECT * FROM sq
0ab0: 6c 69 74 65 5f 6d 61 73 74 65 72 7d 20 2d 31 20  lite_master} -1 
0ac0: 54 41 49 4c 5d 0a 20 20 20 20 65 78 65 63 73 71  TAIL].    execsq
0ad0: 6c 20 7b 0a 20 20 20 20 20 20 44 52 4f 50 20 56  l {.      DROP V
0ae0: 49 45 57 20 76 31 3b 0a 20 20 20 20 7d 0a 20 20  IEW v1;.    }.  
0af0: 20 20 73 71 6c 69 74 65 33 5f 73 74 65 70 20 24    sqlite3_step $
0b00: 3a 3a 53 54 4d 54 0a 20 20 7d 20 7b 53 51 4c 49  ::STMT.  } {SQLI
0b10: 54 45 5f 44 4f 4e 45 7d 0a 20 20 64 6f 5f 74 65  TE_DONE}.  do_te
0b20: 73 74 20 73 63 68 65 6d 61 32 2d 32 2e 34 20 7b  st schema2-2.4 {
0b30: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 66 69 6e  .    sqlite3_fin
0b40: 61 6c 69 7a 65 20 24 3a 3a 53 54 4d 54 0a 20 20  alize $::STMT.  
0b50: 7d 20 7b 53 51 4c 49 54 45 5f 4f 4b 7d 0a 7d 0a  } {SQLITE_OK}.}.
0b60: 0a 69 66 63 61 70 61 62 6c 65 20 74 72 69 67 67  .ifcapable trigg
0b70: 65 72 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20 73  er {.  do_test s
0b80: 63 68 65 6d 61 32 2d 33 2e 31 20 7b 0a 20 20 20  chema2-3.1 {.   
0b90: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 20   execsql {.     
0ba0: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 61 62   CREATE TABLE ab
0bb0: 63 28 61 2c 20 62 2c 20 63 29 3b 0a 20 20 20 20  c(a, b, c);.    
0bc0: 7d 0a 20 20 20 20 73 65 74 20 3a 3a 53 54 4d 54  }.    set ::STMT
0bd0: 20 5b 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72   [sqlite3_prepar
0be0: 65 5f 76 32 20 24 3a 3a 44 42 20 7b 53 45 4c 45  e_v2 $::DB {SELE
0bf0: 43 54 20 2a 20 46 52 4f 4d 20 73 71 6c 69 74 65  CT * FROM sqlite
0c00: 5f 6d 61 73 74 65 72 7d 20 2d 31 20 54 41 49 4c  _master} -1 TAIL
0c10: 5d 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a  ].    execsql {.
0c20: 20 20 20 20 20 20 43 52 45 41 54 45 20 54 52 49        CREATE TRI
0c30: 47 47 45 52 20 61 62 63 5f 74 72 69 67 20 41 46  GGER abc_trig AF
0c40: 54 45 52 20 49 4e 53 45 52 54 20 4f 4e 20 61 62  TER INSERT ON ab
0c50: 63 20 42 45 47 49 4e 0a 20 20 20 20 20 20 20 20  c BEGIN.        
0c60: 53 45 4c 45 43 54 20 31 2c 20 32 2c 20 33 3b 0a  SELECT 1, 2, 3;.
0c70: 20 20 20 20 20 20 45 4e 44 3b 0a 20 20 20 20 7d        END;.    }
0c80: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 73 74 65  .    sqlite3_ste
0c90: 70 20 24 3a 3a 53 54 4d 54 0a 20 20 7d 20 7b 53  p $::STMT.  } {S
0ca0: 51 4c 49 54 45 5f 52 4f 57 7d 0a 20 20 64 6f 5f  QLITE_ROW}.  do_
0cb0: 74 65 73 74 20 73 63 68 65 6d 61 32 2d 33 2e 32  test schema2-3.2
0cc0: 20 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 66   {.    sqlite3_f
0cd0: 69 6e 61 6c 69 7a 65 20 24 3a 3a 53 54 4d 54 0a  inalize $::STMT.
0ce0: 20 20 7d 20 7b 53 51 4c 49 54 45 5f 4f 4b 7d 0a    } {SQLITE_OK}.
0cf0: 20 20 64 6f 5f 74 65 73 74 20 73 63 68 65 6d 61    do_test schema
0d00: 32 2d 33 2e 33 20 7b 0a 20 20 20 20 73 65 74 20  2-3.3 {.    set 
0d10: 3a 3a 53 54 4d 54 20 5b 73 71 6c 69 74 65 33 5f  ::STMT [sqlite3_
0d20: 70 72 65 70 61 72 65 5f 76 32 20 24 3a 3a 44 42  prepare_v2 $::DB
0d30: 20 7b 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20   {SELECT * FROM 
0d40: 73 71 6c 69 74 65 5f 6d 61 73 74 65 72 7d 20 2d  sqlite_master} -
0d50: 31 20 54 41 49 4c 5d 0a 20 20 20 20 65 78 65 63  1 TAIL].    exec
0d60: 73 71 6c 20 7b 0a 20 20 20 20 20 20 44 52 4f 50  sql {.      DROP
0d70: 20 54 52 49 47 47 45 52 20 61 62 63 5f 74 72 69   TRIGGER abc_tri
0d80: 67 3b 0a 20 20 20 20 7d 0a 20 20 20 20 73 71 6c  g;.    }.    sql
0d90: 69 74 65 33 5f 73 74 65 70 20 24 3a 3a 53 54 4d  ite3_step $::STM
0da0: 54 0a 20 20 7d 20 7b 53 51 4c 49 54 45 5f 52 4f  T.  } {SQLITE_RO
0db0: 57 7d 0a 20 20 64 6f 5f 74 65 73 74 20 73 63 68  W}.  do_test sch
0dc0: 65 6d 61 32 2d 33 2e 34 20 7b 0a 20 20 20 20 73  ema2-3.4 {.    s
0dd0: 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 20  qlite3_finalize 
0de0: 24 3a 3a 53 54 4d 54 0a 20 20 7d 20 7b 53 51 4c  $::STMT.  } {SQL
0df0: 49 54 45 5f 4f 4b 7d 0a 7d 0a 0a 64 6f 5f 74 65  ITE_OK}.}..do_te
0e00: 73 74 20 73 63 68 65 6d 61 32 2d 34 2e 31 20 7b  st schema2-4.1 {
0e10: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20  .  catchsql {.  
0e20: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 61    CREATE TABLE a
0e30: 62 63 28 61 2c 20 62 2c 20 63 29 3b 0a 20 20 7d  bc(a, b, c);.  }
0e40: 0a 20 20 73 65 74 20 3a 3a 53 54 4d 54 20 5b 73  .  set ::STMT [s
0e50: 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f 76  qlite3_prepare_v
0e60: 32 20 24 3a 3a 44 42 20 7b 53 45 4c 45 43 54 20  2 $::DB {SELECT 
0e70: 2a 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f 6d 61  * FROM sqlite_ma
0e80: 73 74 65 72 7d 20 2d 31 20 54 41 49 4c 5d 0a 20  ster} -1 TAIL]. 
0e90: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43   execsql {.    C
0ea0: 52 45 41 54 45 20 49 4e 44 45 58 20 61 62 63 5f  REATE INDEX abc_
0eb0: 69 6e 64 65 78 20 4f 4e 20 61 62 63 28 61 29 3b  index ON abc(a);
0ec0: 0a 20 20 7d 0a 20 20 73 71 6c 69 74 65 33 5f 73  .  }.  sqlite3_s
0ed0: 74 65 70 20 24 3a 3a 53 54 4d 54 0a 7d 20 7b 53  tep $::STMT.} {S
0ee0: 51 4c 49 54 45 5f 52 4f 57 7d 0a 64 6f 5f 74 65  QLITE_ROW}.do_te
0ef0: 73 74 20 73 63 68 65 6d 61 32 2d 34 2e 32 20 7b  st schema2-4.2 {
0f00: 0a 20 20 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c  .  sqlite3_final
0f10: 69 7a 65 20 24 3a 3a 53 54 4d 54 0a 7d 20 7b 53  ize $::STMT.} {S
0f20: 51 4c 49 54 45 5f 4f 4b 7d 0a 64 6f 5f 74 65 73  QLITE_OK}.do_tes
0f30: 74 20 73 63 68 65 6d 61 32 2d 34 2e 33 20 7b 0a  t schema2-4.3 {.
0f40: 20 20 73 65 74 20 3a 3a 53 54 4d 54 20 5b 73 71    set ::STMT [sq
0f50: 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f 76 32  lite3_prepare_v2
0f60: 20 24 3a 3a 44 42 20 7b 53 45 4c 45 43 54 20 2a   $::DB {SELECT *
0f70: 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f 6d 61 73   FROM sqlite_mas
0f80: 74 65 72 7d 20 2d 31 20 54 41 49 4c 5d 0a 20 20  ter} -1 TAIL].  
0f90: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 44 52  execsql {.    DR
0fa0: 4f 50 20 49 4e 44 45 58 20 61 62 63 5f 69 6e 64  OP INDEX abc_ind
0fb0: 65 78 3b 0a 20 20 7d 0a 20 20 73 71 6c 69 74 65  ex;.  }.  sqlite
0fc0: 33 5f 73 74 65 70 20 24 3a 3a 53 54 4d 54 0a 7d  3_step $::STMT.}
0fd0: 20 7b 53 51 4c 49 54 45 5f 52 4f 57 7d 0a 64 6f   {SQLITE_ROW}.do
0fe0: 5f 74 65 73 74 20 73 63 68 65 6d 61 32 2d 34 2e  _test schema2-4.
0ff0: 34 20 7b 0a 20 20 73 71 6c 69 74 65 33 5f 66 69  4 {.  sqlite3_fi
1000: 6e 61 6c 69 7a 65 20 24 3a 3a 53 54 4d 54 0a 7d  nalize $::STMT.}
1010: 20 7b 53 51 4c 49 54 45 5f 4f 4b 7d 0a 0a 23 2d   {SQLITE_OK}..#-
1020: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1030: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1040: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1050: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1060: 2d 2d 2d 2d 0a 23 20 54 65 73 74 73 20 35 2e 31  ----.# Tests 5.1
1070: 20 74 6f 20 35 2e 34 20 63 68 65 63 6b 20 74 68   to 5.4 check th
1080: 61 74 20 70 72 65 70 61 72 65 64 20 73 74 61 74  at prepared stat
1090: 65 6d 65 6e 74 73 20 61 72 65 20 69 6e 76 61 6c  ements are inval
10a0: 69 64 61 74 65 64 20 77 68 65 6e 0a 23 20 61 20  idated when.# a 
10b0: 64 61 74 61 62 61 73 65 20 69 73 20 44 45 54 41  database is DETA
10c0: 43 48 65 64 20 28 62 75 74 20 6e 6f 74 20 77 68  CHed (but not wh
10d0: 65 6e 20 6f 6e 65 20 69 73 20 41 54 54 41 43 48  en one is ATTACH
10e0: 65 64 29 2e 0a 23 0a 69 66 63 61 70 61 62 6c 65  ed)..#.ifcapable
10f0: 20 61 74 74 61 63 68 20 7b 0a 20 20 64 6f 5f 74   attach {.  do_t
1100: 65 73 74 20 73 63 68 65 6d 61 32 2d 35 2e 31 20  est schema2-5.1 
1110: 7b 0a 20 20 20 20 73 65 74 20 73 71 6c 20 7b 53  {.    set sql {S
1120: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 61 62 63  ELECT * FROM abc
1130: 3b 7d 0a 20 20 20 20 73 65 74 20 3a 3a 53 54 4d  ;}.    set ::STM
1140: 54 20 5b 73 71 6c 69 74 65 33 5f 70 72 65 70 61  T [sqlite3_prepa
1150: 72 65 5f 76 32 20 24 3a 3a 44 42 20 24 73 71 6c  re_v2 $::DB $sql
1160: 20 2d 31 20 54 41 49 4c 5d 0a 20 20 20 20 65 78   -1 TAIL].    ex
1170: 65 63 73 71 6c 20 7b 0a 20 20 20 20 20 20 41 54  ecsql {.      AT
1180: 54 41 43 48 20 27 74 65 73 74 32 2e 64 62 27 20  TACH 'test2.db' 
1190: 41 53 20 61 75 78 3b 0a 20 20 20 20 7d 0a 20 20  AS aux;.    }.  
11a0: 20 20 73 71 6c 69 74 65 33 5f 73 74 65 70 20 24    sqlite3_step $
11b0: 3a 3a 53 54 4d 54 0a 20 20 7d 20 7b 53 51 4c 49  ::STMT.  } {SQLI
11c0: 54 45 5f 44 4f 4e 45 7d 0a 20 20 64 6f 5f 74 65  TE_DONE}.  do_te
11d0: 73 74 20 73 63 68 65 6d 61 32 2d 35 2e 32 20 7b  st schema2-5.2 {
11e0: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 72 65 73  .    sqlite3_res
11f0: 65 74 20 24 3a 3a 53 54 4d 54 0a 20 20 7d 20 7b  et $::STMT.  } {
1200: 53 51 4c 49 54 45 5f 4f 4b 7d 0a 20 20 64 6f 5f  SQLITE_OK}.  do_
1210: 74 65 73 74 20 73 63 68 65 6d 61 32 2d 35 2e 33  test schema2-5.3
1220: 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b   {.    execsql {
1230: 0a 20 20 20 20 20 20 44 45 54 41 43 48 20 61 75  .      DETACH au
1240: 78 3b 0a 20 20 20 20 7d 0a 20 20 20 20 73 71 6c  x;.    }.    sql
1250: 69 74 65 33 5f 73 74 65 70 20 24 3a 3a 53 54 4d  ite3_step $::STM
1260: 54 0a 20 20 7d 20 7b 53 51 4c 49 54 45 5f 44 4f  T.  } {SQLITE_DO
1270: 4e 45 7d 0a 20 20 64 6f 5f 74 65 73 74 20 73 63  NE}.  do_test sc
1280: 68 65 6d 61 32 2d 35 2e 34 20 7b 0a 20 20 20 20  hema2-5.4 {.    
1290: 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65  sqlite3_finalize
12a0: 20 24 3a 3a 53 54 4d 54 0a 20 20 7d 20 7b 53 51   $::STMT.  } {SQ
12b0: 4c 49 54 45 5f 4f 4b 7d 0a 7d 0a 0a 23 2d 2d 2d  LITE_OK}.}..#---
12c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
12d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
12e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
12f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1300: 2d 2d 0a 23 20 54 65 73 74 73 20 36 2e 2a 20 63  --.# Tests 6.* c
1310: 68 65 63 6b 20 74 68 61 74 20 70 72 65 70 61 72  heck that prepar
1320: 65 64 20 73 74 61 74 65 6d 65 6e 74 73 20 61 72  ed statements ar
1330: 65 20 69 6e 76 61 6c 69 64 61 74 65 64 20 77 68  e invalidated wh
1340: 65 6e 0a 23 20 61 20 75 73 65 72 2d 66 75 6e 63  en.# a user-func
1350: 74 69 6f 6e 20 69 73 20 64 65 6c 65 74 65 64 20  tion is deleted 
1360: 28 62 75 74 20 6e 6f 74 20 77 68 65 6e 20 6f 6e  (but not when on
1370: 65 20 69 73 20 61 64 64 65 64 29 2e 0a 64 6f 5f  e is added)..do_
1380: 74 65 73 74 20 73 63 68 65 6d 61 32 2d 36 2e 31  test schema2-6.1
1390: 20 7b 0a 20 20 73 65 74 20 73 71 6c 20 7b 53 45   {.  set sql {SE
13a0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 61 62 63 3b  LECT * FROM abc;
13b0: 7d 0a 20 20 73 65 74 20 3a 3a 53 54 4d 54 20 5b  }.  set ::STMT [
13c0: 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f  sqlite3_prepare_
13d0: 76 32 20 24 3a 3a 44 42 20 24 73 71 6c 20 2d 31  v2 $::DB $sql -1
13e0: 20 54 41 49 4c 5d 0a 20 20 64 62 20 66 75 6e 63   TAIL].  db func
13f0: 74 69 6f 6e 20 68 65 6c 6c 6f 5f 66 75 6e 63 74  tion hello_funct
1400: 69 6f 6e 20 7b 7d 0a 20 20 73 71 6c 69 74 65 33  ion {}.  sqlite3
1410: 5f 73 74 65 70 20 24 3a 3a 53 54 4d 54 0a 7d 20  _step $::STMT.} 
1420: 7b 53 51 4c 49 54 45 5f 44 4f 4e 45 7d 0a 64 6f  {SQLITE_DONE}.do
1430: 5f 74 65 73 74 20 73 63 68 65 6d 61 32 2d 36 2e  _test schema2-6.
1440: 32 20 7b 0a 20 20 73 71 6c 69 74 65 33 5f 72 65  2 {.  sqlite3_re
1450: 73 65 74 20 24 3a 3a 53 54 4d 54 0a 7d 20 7b 53  set $::STMT.} {S
1460: 51 4c 49 54 45 5f 4f 4b 7d 0a 64 6f 5f 74 65 73  QLITE_OK}.do_tes
1470: 74 20 73 63 68 65 6d 61 32 2d 36 2e 33 20 7b 0a  t schema2-6.3 {.
1480: 20 20 73 71 6c 69 74 65 5f 64 65 6c 65 74 65 5f    sqlite_delete_
1490: 66 75 6e 63 74 69 6f 6e 20 24 3a 3a 44 42 20 68  function $::DB h
14a0: 65 6c 6c 6f 5f 66 75 6e 63 74 69 6f 6e 0a 20 20  ello_function.  
14b0: 73 71 6c 69 74 65 33 5f 73 74 65 70 20 24 3a 3a  sqlite3_step $::
14c0: 53 54 4d 54 0a 7d 20 7b 53 51 4c 49 54 45 5f 44  STMT.} {SQLITE_D
14d0: 4f 4e 45 7d 0a 64 6f 5f 74 65 73 74 20 73 63 68  ONE}.do_test sch
14e0: 65 6d 61 32 2d 36 2e 34 20 7b 0a 20 20 73 71 6c  ema2-6.4 {.  sql
14f0: 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 20 24 3a  ite3_finalize $:
1500: 3a 53 54 4d 54 0a 7d 20 7b 53 51 4c 49 54 45 5f  :STMT.} {SQLITE_
1510: 4f 4b 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  OK}..#----------
1520: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1530: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1540: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1550: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 54 65  -----------.# Te
1560: 73 74 73 20 37 2e 2a 20 63 68 65 63 6b 20 74 68  sts 7.* check th
1570: 61 74 20 70 72 65 70 61 72 65 64 20 73 74 61 74  at prepared stat
1580: 65 6d 65 6e 74 73 20 61 72 65 20 69 6e 76 61 6c  ements are inval
1590: 69 64 61 74 65 64 20 77 68 65 6e 0a 23 20 61 20  idated when.# a 
15a0: 63 6f 6c 6c 61 74 69 6f 6e 20 73 65 71 75 65 6e  collation sequen
15b0: 63 65 20 69 73 20 64 65 6c 65 74 65 64 20 28 62  ce is deleted (b
15c0: 75 74 20 6e 6f 74 20 77 68 65 6e 20 6f 6e 65 20  ut not when one 
15d0: 69 73 20 61 64 64 65 64 29 2e 0a 23 0a 69 66 63  is added)..#.ifc
15e0: 61 70 61 62 6c 65 20 75 74 66 31 36 20 7b 0a 20  apable utf16 {. 
15f0: 20 64 6f 5f 74 65 73 74 20 73 63 68 65 6d 61 32   do_test schema2
1600: 2d 37 2e 31 20 7b 0a 20 20 20 20 73 65 74 20 73  -7.1 {.    set s
1610: 71 6c 20 7b 53 45 4c 45 43 54 20 2a 20 46 52 4f  ql {SELECT * FRO
1620: 4d 20 61 62 63 3b 7d 0a 20 20 20 20 73 65 74 20  M abc;}.    set 
1630: 3a 3a 53 54 4d 54 20 5b 73 71 6c 69 74 65 33 5f  ::STMT [sqlite3_
1640: 70 72 65 70 61 72 65 5f 76 32 20 24 3a 3a 44 42  prepare_v2 $::DB
1650: 20 24 73 71 6c 20 2d 31 20 54 41 49 4c 5d 0a 20   $sql -1 TAIL]. 
1660: 20 20 20 61 64 64 5f 74 65 73 74 5f 63 6f 6c 6c     add_test_coll
1670: 61 74 65 20 24 3a 3a 44 42 20 31 20 31 20 31 0a  ate $::DB 1 1 1.
1680: 20 20 20 20 73 71 6c 69 74 65 33 5f 73 74 65 70      sqlite3_step
1690: 20 24 3a 3a 53 54 4d 54 0a 20 20 7d 20 7b 53 51   $::STMT.  } {SQ
16a0: 4c 49 54 45 5f 44 4f 4e 45 7d 0a 20 20 64 6f 5f  LITE_DONE}.  do_
16b0: 74 65 73 74 20 73 63 68 65 6d 61 32 2d 37 2e 32  test schema2-7.2
16c0: 20 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 72   {.    sqlite3_r
16d0: 65 73 65 74 20 24 3a 3a 53 54 4d 54 0a 20 20 7d  eset $::STMT.  }
16e0: 20 7b 53 51 4c 49 54 45 5f 4f 4b 7d 0a 20 20 64   {SQLITE_OK}.  d
16f0: 6f 5f 74 65 73 74 20 73 63 68 65 6d 61 32 2d 37  o_test schema2-7
1700: 2e 33 20 7b 0a 20 20 20 20 61 64 64 5f 74 65 73  .3 {.    add_tes
1710: 74 5f 63 6f 6c 6c 61 74 65 20 24 3a 3a 44 42 20  t_collate $::DB 
1720: 30 20 30 20 30 20 0a 20 20 20 20 73 71 6c 69 74  0 0 0 .    sqlit
1730: 65 33 5f 73 74 65 70 20 24 3a 3a 53 54 4d 54 0a  e3_step $::STMT.
1740: 20 20 7d 20 7b 53 51 4c 49 54 45 5f 44 4f 4e 45    } {SQLITE_DONE
1750: 7d 0a 20 20 64 6f 5f 74 65 73 74 20 73 63 68 65  }.  do_test sche
1760: 6d 61 32 2d 37 2e 34 20 7b 0a 20 20 20 20 73 71  ma2-7.4 {.    sq
1770: 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 20 24  lite3_finalize $
1780: 3a 3a 53 54 4d 54 0a 20 20 7d 20 7b 53 51 4c 49  ::STMT.  } {SQLI
1790: 54 45 5f 4f 4b 7d 0a 7d 0a 0a 23 2d 2d 2d 2d 2d  TE_OK}.}..#-----
17a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
17b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
17c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
17d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
17e0: 0a 23 20 54 65 73 74 73 20 38 2e 31 20 61 6e 64  .# Tests 8.1 and
17f0: 20 38 2e 32 20 63 68 65 63 6b 20 74 68 61 74 20   8.2 check that 
1800: 70 72 65 70 61 72 65 64 20 73 74 61 74 65 6d 65  prepared stateme
1810: 6e 74 73 20 61 72 65 20 69 6e 76 61 6c 69 64 61  nts are invalida
1820: 74 65 64 20 77 68 65 6e 0a 23 20 74 68 65 20 61  ted when.# the a
1830: 75 74 68 6f 72 69 7a 61 74 69 6f 6e 20 66 75 6e  uthorization fun
1840: 63 74 69 6f 6e 20 69 73 20 73 65 74 2e 0a 23 0a  ction is set..#.
1850: 69 66 63 61 70 61 62 6c 65 20 61 75 74 68 20 7b  ifcapable auth {
1860: 0a 20 20 64 6f 5f 74 65 73 74 20 73 63 68 65 6d  .  do_test schem
1870: 61 32 2d 38 2e 31 20 7b 0a 20 20 20 20 73 65 74  a2-8.1 {.    set
1880: 20 3a 3a 53 54 4d 54 20 5b 73 71 6c 69 74 65 33   ::STMT [sqlite3
1890: 5f 70 72 65 70 61 72 65 5f 76 32 20 24 3a 3a 44  _prepare_v2 $::D
18a0: 42 20 7b 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d  B {SELECT * FROM
18b0: 20 73 71 6c 69 74 65 5f 6d 61 73 74 65 72 7d 20   sqlite_master} 
18c0: 2d 31 20 54 41 49 4c 5d 0a 20 20 20 20 64 62 20  -1 TAIL].    db 
18d0: 61 75 74 68 20 7b 7d 0a 20 20 20 20 73 71 6c 69  auth {}.    sqli
18e0: 74 65 33 5f 73 74 65 70 20 24 3a 3a 53 54 4d 54  te3_step $::STMT
18f0: 0a 20 20 7d 20 7b 53 51 4c 49 54 45 5f 52 4f 57  .  } {SQLITE_ROW
1900: 7d 0a 20 20 64 6f 5f 74 65 73 74 20 73 63 68 65  }.  do_test sche
1910: 6d 61 32 2d 38 2e 33 20 7b 0a 20 20 20 20 73 71  ma2-8.3 {.    sq
1920: 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 20 24  lite3_finalize $
1930: 3a 3a 53 54 4d 54 0a 20 20 7d 20 7b 53 51 4c 49  ::STMT.  } {SQLI
1940: 54 45 5f 4f 4b 7d 0a 7d 0a 0a 23 2d 2d 2d 2d 2d  TE_OK}.}..#-----
1950: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1960: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1970: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1980: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1990: 0a 23 20 73 63 68 65 6d 61 32 2d 39 2e 31 3a 20  .# schema2-9.1: 
19a0: 54 65 73 74 20 74 68 61 74 20 69 66 20 61 20 74  Test that if a t
19b0: 61 62 6c 65 20 69 73 20 64 72 6f 70 70 65 64 20  able is dropped 
19c0: 62 79 20 6f 6e 65 20 64 61 74 61 62 61 73 65 20  by one database 
19d0: 63 6f 6e 6e 65 63 74 69 6f 6e 2c 20 0a 23 20 20  connection, .#  
19e0: 20 20 20 20 20 20 20 20 20 20 20 6f 74 68 65 72             other
19f0: 20 64 61 74 61 62 61 73 65 20 63 6f 6e 6e 65 63   database connec
1a00: 74 69 6f 6e 73 20 61 72 65 20 61 77 61 72 65 20  tions are aware 
1a10: 6f 66 20 74 68 65 20 73 63 68 65 6d 61 20 63 68  of the schema ch
1a20: 61 6e 67 65 2e 0a 23 20 73 63 68 65 6d 61 32 2d  ange..# schema2-
1a30: 39 2e 32 3a 20 54 65 73 74 20 74 68 61 74 20 69  9.2: Test that i
1a40: 66 20 61 20 76 69 65 77 20 69 73 20 64 72 6f 70  f a view is drop
1a50: 70 65 64 20 62 79 20 6f 6e 65 20 64 61 74 61 62  ped by one datab
1a60: 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 2c 0a  ase connection,.
1a70: 23 20 20 20 20 20 20 20 20 20 20 20 20 20 6f 74  #             ot
1a80: 68 65 72 20 64 61 74 61 62 61 73 65 20 63 6f 6e  her database con
1a90: 6e 65 63 74 69 6f 6e 73 20 61 72 65 20 61 77 61  nections are awa
1aa0: 72 65 20 6f 66 20 74 68 65 20 73 63 68 65 6d 61  re of the schema
1ab0: 20 63 68 61 6e 67 65 2e 0a 23 0a 64 6f 5f 74 65   change..#.do_te
1ac0: 73 74 20 73 63 68 65 6d 61 32 2d 39 2e 31 20 7b  st schema2-9.1 {
1ad0: 0a 20 20 73 71 6c 69 74 65 33 20 64 62 32 20 74  .  sqlite3 db2 t
1ae0: 65 73 74 2e 64 62 0a 20 20 65 78 65 63 73 71 6c  est.db.  execsql
1af0: 20 7b 0a 20 20 20 20 44 52 4f 50 20 54 41 42 4c   {.    DROP TABL
1b00: 45 20 61 62 63 3b 0a 20 20 7d 20 64 62 32 0a 20  E abc;.  } db2. 
1b10: 20 64 62 32 20 63 6c 6f 73 65 0a 20 20 63 61 74   db2 close.  cat
1b20: 63 68 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45  chsql {.    SELE
1b30: 43 54 20 2a 20 46 52 4f 4d 20 61 62 63 3b 0a 20  CT * FROM abc;. 
1b40: 20 7d 0a 7d 20 7b 31 20 7b 6e 6f 20 73 75 63 68   }.} {1 {no such
1b50: 20 74 61 62 6c 65 3a 20 61 62 63 7d 7d 0a 65 78   table: abc}}.ex
1b60: 65 63 73 71 6c 20 7b 0a 20 20 43 52 45 41 54 45  ecsql {.  CREATE
1b70: 20 54 41 42 4c 45 20 61 62 63 28 61 2c 20 62 2c   TABLE abc(a, b,
1b80: 20 63 29 3b 0a 7d 0a 69 66 63 61 70 61 62 6c 65   c);.}.ifcapable
1b90: 20 76 69 65 77 20 7b 0a 20 20 64 6f 5f 74 65 73   view {.  do_tes
1ba0: 74 20 73 63 68 65 6d 61 32 2d 39 2e 32 20 7b 0a  t schema2-9.2 {.
1bb0: 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20      execsql {.  
1bc0: 20 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20      CREATE VIEW 
1bd0: 61 62 63 76 69 65 77 20 41 53 20 53 45 4c 45 43  abcview AS SELEC
1be0: 54 20 2a 20 46 52 4f 4d 20 61 62 63 3b 0a 20 20  T * FROM abc;.  
1bf0: 20 20 7d 0a 20 20 20 20 73 71 6c 69 74 65 33 20    }.    sqlite3 
1c00: 64 62 32 20 74 65 73 74 2e 64 62 0a 20 20 20 20  db2 test.db.    
1c10: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 20 20  execsql {.      
1c20: 44 52 4f 50 20 56 49 45 57 20 61 62 63 76 69 65  DROP VIEW abcvie
1c30: 77 3b 0a 20 20 20 20 7d 20 64 62 32 0a 20 20 20  w;.    } db2.   
1c40: 20 64 62 32 20 63 6c 6f 73 65 0a 20 20 20 20 63   db2 close.    c
1c50: 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 20 20  atchsql {.      
1c60: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 61 62  SELECT * FROM ab
1c70: 63 76 69 65 77 3b 0a 20 20 20 20 7d 0a 20 20 7d  cview;.    }.  }
1c80: 20 7b 31 20 7b 6e 6f 20 73 75 63 68 20 74 61 62   {1 {no such tab
1c90: 6c 65 3a 20 61 62 63 76 69 65 77 7d 7d 0a 7d 0a  le: abcview}}.}.
1ca0: 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  .#--------------
1cb0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1cc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1cd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1ce0: 2d 2d 2d 2d 2d 2d 2d 0a 23 20 54 65 73 74 20 74  -------.# Test t
1cf0: 68 61 74 20 69 66 20 61 20 43 52 45 41 54 45 20  hat if a CREATE 
1d00: 54 41 42 4c 45 20 73 74 61 74 65 6d 65 6e 74 20  TABLE statement 
1d10: 66 61 69 6c 73 20 62 65 63 61 75 73 65 20 74 68  fails because th
1d20: 65 72 65 20 61 72 65 20 6f 74 68 65 72 0a 23 20  ere are other.# 
1d30: 62 74 72 65 65 20 63 75 72 73 6f 72 73 20 6f 70  btree cursors op
1d40: 65 6e 20 6f 6e 20 74 68 65 20 73 61 6d 65 20 64  en on the same d
1d50: 61 74 61 62 61 73 65 20 66 69 6c 65 20 69 74 20  atabase file it 
1d60: 64 6f 65 73 20 6e 6f 74 20 63 6f 72 72 75 70 74  does not corrupt
1d70: 0a 23 20 74 68 65 20 73 71 6c 69 74 65 5f 6d 61  .# the sqlite_ma
1d80: 73 74 65 72 20 74 61 62 6c 65 2e 0a 23 0a 23 20  ster table..#.# 
1d90: 32 30 30 37 2d 30 35 2d 30 32 3a 20 54 68 65 73  2007-05-02: Thes
1da0: 65 20 74 65 73 74 73 20 68 61 76 65 20 62 65 65  e tests have bee
1db0: 6e 20 6f 76 65 72 63 6f 6d 65 20 62 79 20 65 76  n overcome by ev
1dc0: 65 6e 74 73 2e 20 20 4f 70 65 6e 20 62 74 72 65  ents.  Open btre
1dd0: 65 0a 23 20 63 75 72 73 6f 72 73 20 6e 6f 20 6c  e.# cursors no l
1de0: 6f 6e 67 65 72 20 62 6c 6f 63 6b 20 43 52 45 41  onger block CREA
1df0: 54 45 20 54 41 42 4c 45 2e 20 20 42 75 74 20 74  TE TABLE.  But t
1e00: 68 65 72 65 20 69 73 20 6e 6f 20 72 65 61 73 6f  here is no reaso
1e10: 6e 20 6e 6f 74 0a 23 20 74 6f 20 6b 65 65 70 20  n not.# to keep 
1e20: 74 68 65 20 74 65 73 74 73 20 69 6e 20 74 68 65  the tests in the
1e30: 20 74 65 73 74 20 73 75 69 74 65 2e 0a 23 0a 64   test suite..#.d
1e40: 6f 5f 74 65 73 74 20 73 63 68 65 6d 61 32 2d 31  o_test schema2-1
1e50: 30 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  0.1 {.  execsql 
1e60: 7b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  {.    INSERT INT
1e70: 4f 20 61 62 63 20 56 41 4c 55 45 53 28 31 2c 20  O abc VALUES(1, 
1e80: 32 2c 20 33 29 3b 0a 20 20 7d 0a 20 20 73 65 74  2, 3);.  }.  set
1e90: 20 73 71 6c 20 7b 53 45 4c 45 43 54 20 2a 20 46   sql {SELECT * F
1ea0: 52 4f 4d 20 61 62 63 7d 0a 20 20 73 65 74 20 3a  ROM abc}.  set :
1eb0: 3a 53 54 4d 54 20 5b 73 71 6c 69 74 65 33 5f 70  :STMT [sqlite3_p
1ec0: 72 65 70 61 72 65 5f 76 32 20 24 3a 3a 44 42 20  repare_v2 $::DB 
1ed0: 24 73 71 6c 20 2d 31 20 54 41 49 4c 5d 0a 20 20  $sql -1 TAIL].  
1ee0: 73 71 6c 69 74 65 33 5f 73 74 65 70 20 24 3a 3a  sqlite3_step $::
1ef0: 53 54 4d 54 0a 7d 20 7b 53 51 4c 49 54 45 5f 52  STMT.} {SQLITE_R
1f00: 4f 57 7d 0a 64 6f 5f 74 65 73 74 20 73 63 68 65  OW}.do_test sche
1f10: 6d 61 32 2d 31 30 2e 32 20 7b 0a 20 20 63 61 74  ma2-10.2 {.  cat
1f20: 63 68 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41  chsql {.    CREA
1f30: 54 45 20 54 41 42 4c 45 20 74 32 28 61 2c 20 62  TE TABLE t2(a, b
1f40: 2c 20 63 29 3b 0a 20 20 7d 0a 7d 20 7b 30 20 7b  , c);.  }.} {0 {
1f50: 7d 7d 0a 64 6f 5f 74 65 73 74 20 73 63 68 65 6d  }}.do_test schem
1f60: 61 32 2d 31 30 2e 33 20 7b 0a 20 20 73 71 6c 69  a2-10.3 {.  sqli
1f70: 74 65 33 5f 66 69 6e 61 6c 69 7a 65 20 24 3a 3a  te3_finalize $::
1f80: 53 54 4d 54 0a 7d 20 7b 53 51 4c 49 54 45 5f 4f  STMT.} {SQLITE_O
1f90: 4b 7d 0a 64 6f 5f 74 65 73 74 20 73 63 68 65 6d  K}.do_test schem
1fa0: 61 32 2d 31 30 2e 34 20 7b 0a 20 20 73 71 6c 69  a2-10.4 {.  sqli
1fb0: 74 65 33 20 64 62 32 20 74 65 73 74 2e 64 62 0a  te3 db2 test.db.
1fc0: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
1fd0: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 61 62  SELECT * FROM ab
1fe0: 63 0a 20 20 7d 20 64 62 32 0a 7d 20 7b 31 20 32  c.  } db2.} {1 2
1ff0: 20 33 7d 0a 64 6f 5f 74 65 73 74 20 73 63 68 65   3}.do_test sche
2000: 6d 61 32 2d 31 30 2e 35 20 7b 0a 20 20 64 62 32  ma2-10.5 {.  db2
2010: 20 63 6c 6f 73 65 0a 7d 20 7b 7d 0a 0a 23 2d 2d   close.} {}..#--
2020: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2030: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2040: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2050: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2060: 2d 2d 2d 0a 23 20 41 74 74 65 6d 70 74 69 6e 67  ---.# Attempting
2070: 20 74 6f 20 64 65 6c 65 74 65 20 6f 72 20 72 65   to delete or re
2080: 70 6c 61 63 65 20 61 20 75 73 65 72 2d 66 75 6e  place a user-fun
2090: 63 74 69 6f 6e 20 6f 72 20 63 6f 6c 6c 61 74 69  ction or collati
20a0: 6f 6e 20 73 65 71 75 65 6e 63 65 20 0a 23 20 77  on sequence .# w
20b0: 68 69 6c 65 20 74 68 65 72 65 20 61 72 65 20 61  hile there are a
20c0: 63 74 69 76 65 20 73 74 61 74 65 6d 65 6e 74 73  ctive statements
20d0: 20 72 65 74 75 72 6e 73 20 61 6e 20 53 51 4c 49   returns an SQLI
20e0: 54 45 5f 42 55 53 59 20 65 72 72 6f 72 2e 0a 23  TE_BUSY error..#
20f0: 0a 23 20 73 63 68 65 6d 61 32 2d 31 31 2e 31 20  .# schema2-11.1 
2100: 2d 20 31 31 2e 34 3a 20 55 73 65 72 20 66 75 6e  - 11.4: User fun
2110: 63 74 69 6f 6e 2e 0a 23 20 73 63 68 65 6d 61 32  ction..# schema2
2120: 2d 31 31 2e 35 20 2d 20 31 31 2e 38 3a 20 43 6f  -11.5 - 11.8: Co
2130: 6c 6c 61 74 69 6f 6e 20 73 65 71 75 65 6e 63 65  llation sequence
2140: 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 73 63 68 65  ..#.do_test sche
2150: 6d 61 32 2d 31 31 2e 31 20 7b 0a 20 20 64 62 20  ma2-11.1 {.  db 
2160: 66 75 6e 63 74 69 6f 6e 20 74 73 74 66 75 6e 63  function tstfunc
2170: 20 7b 7d 0a 20 20 73 65 74 20 73 71 6c 20 7b 53   {}.  set sql {S
2180: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 61 62 63  ELECT * FROM abc
2190: 7d 0a 20 20 73 65 74 20 3a 3a 53 54 4d 54 20 5b  }.  set ::STMT [
21a0: 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f  sqlite3_prepare_
21b0: 76 32 20 24 3a 3a 44 42 20 24 73 71 6c 20 2d 31  v2 $::DB $sql -1
21c0: 20 54 41 49 4c 5d 0a 20 20 73 71 6c 69 74 65 33   TAIL].  sqlite3
21d0: 5f 73 74 65 70 20 24 3a 3a 53 54 4d 54 0a 7d 20  _step $::STMT.} 
21e0: 7b 53 51 4c 49 54 45 5f 52 4f 57 7d 0a 64 6f 5f  {SQLITE_ROW}.do_
21f0: 74 65 73 74 20 73 63 68 65 6d 61 32 2d 31 31 2e  test schema2-11.
2200: 32 20 7b 0a 20 20 73 71 6c 69 74 65 5f 64 65 6c  2 {.  sqlite_del
2210: 65 74 65 5f 66 75 6e 63 74 69 6f 6e 20 24 3a 3a  ete_function $::
2220: 44 42 20 74 73 74 66 75 6e 63 0a 7d 20 7b 53 51  DB tstfunc.} {SQ
2230: 4c 49 54 45 5f 42 55 53 59 7d 0a 64 6f 5f 74 65  LITE_BUSY}.do_te
2240: 73 74 20 73 63 68 65 6d 61 32 2d 31 31 2e 33 20  st schema2-11.3 
2250: 7b 0a 20 20 73 65 74 20 72 63 20 5b 63 61 74 63  {.  set rc [catc
2260: 68 20 7b 0a 20 20 20 20 64 62 20 66 75 6e 63 74  h {.    db funct
2270: 69 6f 6e 20 74 73 74 66 75 6e 63 20 7b 7d 0a 20  ion tstfunc {}. 
2280: 20 7d 20 6d 73 67 5d 0a 20 20 6c 69 73 74 20 24   } msg].  list $
2290: 72 63 20 24 6d 73 67 0a 7d 20 7b 31 20 7b 75 6e  rc $msg.} {1 {un
22a0: 61 62 6c 65 20 74 6f 20 64 65 6c 65 74 65 2f 6d  able to delete/m
22b0: 6f 64 69 66 79 20 75 73 65 72 2d 66 75 6e 63 74  odify user-funct
22c0: 69 6f 6e 20 64 75 65 20 74 6f 20 61 63 74 69 76  ion due to activ
22d0: 65 20 73 74 61 74 65 6d 65 6e 74 73 7d 7d 0a 64  e statements}}.d
22e0: 6f 5f 74 65 73 74 20 73 63 68 65 6d 61 32 2d 31  o_test schema2-1
22f0: 31 2e 34 20 7b 0a 20 20 73 71 6c 69 74 65 33 5f  1.4 {.  sqlite3_
2300: 66 69 6e 61 6c 69 7a 65 20 24 3a 3a 53 54 4d 54  finalize $::STMT
2310: 0a 7d 20 7b 53 51 4c 49 54 45 5f 4f 4b 7d 0a 64  .} {SQLITE_OK}.d
2320: 6f 5f 74 65 73 74 20 73 63 68 65 6d 61 32 2d 31  o_test schema2-1
2330: 31 2e 35 20 7b 0a 20 20 64 62 20 63 6f 6c 6c 61  1.5 {.  db colla
2340: 74 65 20 74 73 74 63 6f 6c 6c 61 74 65 20 7b 7d  te tstcollate {}
2350: 0a 20 20 73 65 74 20 73 71 6c 20 7b 53 45 4c 45  .  set sql {SELE
2360: 43 54 20 2a 20 46 52 4f 4d 20 61 62 63 7d 0a 20  CT * FROM abc}. 
2370: 20 73 65 74 20 3a 3a 53 54 4d 54 20 5b 73 71 6c   set ::STMT [sql
2380: 69 74 65 33 5f 70 72 65 70 61 72 65 5f 76 32 20  ite3_prepare_v2 
2390: 24 3a 3a 44 42 20 24 73 71 6c 20 2d 31 20 54 41  $::DB $sql -1 TA
23a0: 49 4c 5d 0a 20 20 73 71 6c 69 74 65 33 5f 73 74  IL].  sqlite3_st
23b0: 65 70 20 24 3a 3a 53 54 4d 54 0a 7d 20 7b 53 51  ep $::STMT.} {SQ
23c0: 4c 49 54 45 5f 52 4f 57 7d 0a 64 6f 5f 74 65 73  LITE_ROW}.do_tes
23d0: 74 20 73 63 68 65 6d 61 32 2d 31 31 2e 36 20 7b  t schema2-11.6 {
23e0: 0a 20 20 73 71 6c 69 74 65 5f 64 65 6c 65 74 65  .  sqlite_delete
23f0: 5f 63 6f 6c 6c 61 74 69 6f 6e 20 24 3a 3a 44 42  _collation $::DB
2400: 20 74 73 74 63 6f 6c 6c 61 74 65 0a 7d 20 7b 53   tstcollate.} {S
2410: 51 4c 49 54 45 5f 42 55 53 59 7d 0a 64 6f 5f 74  QLITE_BUSY}.do_t
2420: 65 73 74 20 73 63 68 65 6d 61 32 2d 31 31 2e 37  est schema2-11.7
2430: 20 7b 0a 20 20 73 65 74 20 72 63 20 5b 63 61 74   {.  set rc [cat
2440: 63 68 20 7b 0a 20 20 20 20 64 62 20 63 6f 6c 6c  ch {.    db coll
2450: 61 74 65 20 74 73 74 63 6f 6c 6c 61 74 65 20 7b  ate tstcollate {
2460: 7d 0a 20 20 7d 20 6d 73 67 5d 0a 20 20 6c 69 73  }.  } msg].  lis
2470: 74 20 24 72 63 20 24 6d 73 67 0a 7d 20 7b 31 20  t $rc $msg.} {1 
2480: 7b 75 6e 61 62 6c 65 20 74 6f 20 64 65 6c 65 74  {unable to delet
2490: 65 2f 6d 6f 64 69 66 79 20 63 6f 6c 6c 61 74 69  e/modify collati
24a0: 6f 6e 20 73 65 71 75 65 6e 63 65 20 64 75 65 20  on sequence due 
24b0: 74 6f 20 61 63 74 69 76 65 20 73 74 61 74 65 6d  to active statem
24c0: 65 6e 74 73 7d 7d 0a 64 6f 5f 74 65 73 74 20 73  ents}}.do_test s
24d0: 63 68 65 6d 61 32 2d 31 31 2e 38 20 7b 0a 20 20  chema2-11.8 {.  
24e0: 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65  sqlite3_finalize
24f0: 20 24 3a 3a 53 54 4d 54 0a 7d 20 7b 53 51 4c 49   $::STMT.} {SQLI
2500: 54 45 5f 4f 4b 7d 0a 0a 66 69 6e 69 73 68 5f 74  TE_OK}..finish_t
2510: 65 73 74 0a                                      est.