/ Hex Artifact Content
Login

Artifact bef47b3c1c1093599905d1d9c79140f265896db0:


0000: 23 20 32 30 30 34 20 4e 6f 76 65 6d 62 65 72 20  # 2004 November 
0010: 31 32 0a 23 0a 23 20 54 68 65 20 61 75 74 68 6f  12.#.# 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 2a 2a 0a 23 20 54 68 69  **********.# Thi
0170: 73 20 66 69 6c 65 20 69 6d 70 6c 65 6d 65 6e 74  s file implement
0180: 73 20 72 65 67 72 65 73 73 69 6f 6e 20 74 65 73  s regression tes
0190: 74 73 20 66 6f 72 20 53 51 4c 69 74 65 20 6c 69  ts for SQLite li
01a0: 62 72 61 72 79 2e 20 20 54 68 65 0a 23 20 66 6f  brary.  The.# fo
01b0: 63 75 73 20 6f 66 20 74 68 69 73 20 73 63 72 69  cus of this scri
01c0: 70 74 20 69 73 20 74 65 73 74 69 6e 67 20 74 68  pt is testing th
01d0: 65 20 41 55 54 4f 49 4e 43 52 45 4d 45 4e 54 20  e AUTOINCREMENT 
01e0: 66 65 61 74 75 72 65 73 2e 0a 23 0a 23 20 24 49  features..#.# $I
01f0: 64 3a 20 61 75 74 6f 69 6e 63 2e 74 65 73 74 2c  d: autoinc.test,
0200: 76 20 31 2e 35 20 32 30 30 35 2f 30 33 2f 32 39  v 1.5 2005/03/29
0210: 20 30 33 3a 31 31 3a 30 30 20 64 61 6e 69 65 6c   03:11:00 daniel
0220: 6b 31 39 37 37 20 45 78 70 20 24 0a 23 0a 0a 73  k1977 Exp $.#..s
0230: 65 74 20 74 65 73 74 64 69 72 20 5b 66 69 6c 65  et testdir [file
0240: 20 64 69 72 6e 61 6d 65 20 24 61 72 67 76 30 5d   dirname $argv0]
0250: 0a 73 6f 75 72 63 65 20 24 74 65 73 74 64 69 72  .source $testdir
0260: 2f 74 65 73 74 65 72 2e 74 63 6c 0a 0a 23 20 49  /tester.tcl..# I
0270: 66 20 74 68 65 20 6c 69 62 72 61 72 79 20 69 73  f the library is
0280: 20 6e 6f 74 20 63 6f 6d 70 69 6c 65 64 20 77 69   not compiled wi
0290: 74 68 20 61 75 74 6f 69 6e 63 72 65 6d 65 6e 74  th autoincrement
02a0: 20 73 75 70 70 6f 72 74 20 74 68 65 6e 0a 23 20   support then.# 
02b0: 73 6b 69 70 20 61 6c 6c 20 74 65 73 74 73 20 69  skip all tests i
02c0: 6e 20 74 68 69 73 20 66 69 6c 65 2e 0a 23 0a 69  n this file..#.i
02d0: 66 63 61 70 61 62 6c 65 20 7b 21 61 75 74 6f 69  fcapable {!autoi
02e0: 6e 63 7d 20 7b 0a 20 20 66 69 6e 69 73 68 5f 74  nc} {.  finish_t
02f0: 65 73 74 0a 20 20 72 65 74 75 72 6e 0a 7d 0a 0a  est.  return.}..
0300: 23 20 54 68 65 20 64 61 74 61 62 61 73 65 20 69  # The database i
0310: 73 20 69 6e 69 74 69 61 6c 6c 79 20 65 6d 70 74  s initially empt
0320: 79 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 61 75 74  y..#.do_test aut
0330: 6f 69 6e 63 2d 31 2e 31 20 7b 0a 20 20 65 78 65  oinc-1.1 {.  exe
0340: 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43  csql {.    SELEC
0350: 54 20 6e 61 6d 65 20 46 52 4f 4d 20 73 71 6c 69  T name FROM sqli
0360: 74 65 5f 6d 61 73 74 65 72 20 57 48 45 52 45 20  te_master WHERE 
0370: 74 79 70 65 3d 27 74 61 62 6c 65 27 3b 0a 20 20  type='table';.  
0380: 7d 0a 7d 20 7b 7d 0a 0a 23 20 41 64 64 20 61 20  }.} {}..# Add a 
0390: 74 61 62 6c 65 20 77 69 74 68 20 74 68 65 20 41  table with the A
03a0: 55 54 4f 49 4e 43 52 45 4d 45 4e 54 20 66 65 61  UTOINCREMENT fea
03b0: 74 75 72 65 2e 20 20 56 65 72 69 66 79 20 74 68  ture.  Verify th
03c0: 61 74 20 74 68 65 0a 23 20 53 51 4c 49 54 45 5f  at the.# SQLITE_
03d0: 53 45 51 55 45 4e 43 45 20 74 61 62 6c 65 20 67  SEQUENCE table g
03e0: 65 74 73 20 63 72 65 61 74 65 64 2e 0a 23 0a 64  ets created..#.d
03f0: 6f 5f 74 65 73 74 20 61 75 74 6f 69 6e 63 2d 31  o_test autoinc-1
0400: 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .2 {.  execsql {
0410: 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  .    CREATE TABL
0420: 45 20 74 31 28 78 20 49 4e 54 45 47 45 52 20 50  E t1(x INTEGER P
0430: 52 49 4d 41 52 59 20 4b 45 59 20 41 55 54 4f 49  RIMARY KEY AUTOI
0440: 4e 43 52 45 4d 45 4e 54 2c 20 79 29 3b 0a 20 20  NCREMENT, y);.  
0450: 20 20 53 45 4c 45 43 54 20 6e 61 6d 65 20 46 52    SELECT name FR
0460: 4f 4d 20 73 71 6c 69 74 65 5f 6d 61 73 74 65 72  OM sqlite_master
0470: 20 57 48 45 52 45 20 74 79 70 65 3d 27 74 61 62   WHERE type='tab
0480: 6c 65 27 3b 0a 20 20 7d 0a 7d 20 7b 74 31 20 73  le';.  }.} {t1 s
0490: 71 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 7d 0a  qlite_sequence}.
04a0: 0a 23 20 54 68 65 20 53 51 4c 49 54 45 5f 53 45  .# The SQLITE_SE
04b0: 51 55 45 4e 43 45 20 74 61 62 6c 65 20 69 73 20  QUENCE table is 
04c0: 69 6e 69 74 69 61 6c 6c 79 20 65 6d 70 74 79 0a  initially empty.
04d0: 23 0a 64 6f 5f 74 65 73 74 20 61 75 74 6f 69 6e  #.do_test autoin
04e0: 63 2d 31 2e 33 20 7b 0a 20 20 65 78 65 63 73 71  c-1.3 {.  execsq
04f0: 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a  l {.    SELECT *
0500: 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f 73 65 71   FROM sqlite_seq
0510: 75 65 6e 63 65 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a  uence;.  }.} {}.
0520: 0a 23 20 43 6c 6f 73 65 20 61 6e 64 20 72 65 6f  .# Close and reo
0530: 70 65 6e 20 74 68 65 20 64 61 74 61 62 61 73 65  pen the database
0540: 2e 20 20 56 65 72 69 66 79 20 74 68 61 74 20 65  .  Verify that e
0550: 76 65 72 79 74 68 69 6e 67 20 69 73 20 73 74 69  verything is sti
0560: 6c 6c 20 74 68 65 72 65 2e 0a 23 0a 64 6f 5f 74  ll there..#.do_t
0570: 65 73 74 20 61 75 74 6f 69 6e 63 2d 31 2e 34 20  est autoinc-1.4 
0580: 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a 20 20 73  {.  db close.  s
0590: 71 6c 69 74 65 33 20 64 62 20 74 65 73 74 2e 64  qlite3 db test.d
05a0: 62 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  b.  execsql {.  
05b0: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
05c0: 73 71 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 3b  sqlite_sequence;
05d0: 0a 20 20 7d 0a 7d 20 7b 7d 0a 0a 23 20 57 65 20  .  }.} {}..# We 
05e0: 61 72 65 20 6e 6f 74 20 61 6c 6c 6f 77 65 64 20  are not allowed 
05f0: 74 6f 20 64 72 6f 70 20 74 68 65 20 73 71 6c 69  to drop the sqli
0600: 74 65 5f 73 65 71 75 65 6e 63 65 20 74 61 62 6c  te_sequence tabl
0610: 65 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 61 75 74  e..#.do_test aut
0620: 6f 69 6e 63 2d 31 2e 35 20 7b 0a 20 20 63 61 74  oinc-1.5 {.  cat
0630: 63 68 73 71 6c 20 7b 44 52 4f 50 20 54 41 42 4c  chsql {DROP TABL
0640: 45 20 73 71 6c 69 74 65 5f 73 65 71 75 65 6e 63  E sqlite_sequenc
0650: 65 7d 0a 7d 20 7b 31 20 7b 74 61 62 6c 65 20 73  e}.} {1 {table s
0660: 71 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 20 6d  qlite_sequence m
0670: 61 79 20 6e 6f 74 20 62 65 20 64 72 6f 70 70 65  ay not be droppe
0680: 64 7d 7d 0a 64 6f 5f 74 65 73 74 20 61 75 74 6f  d}}.do_test auto
0690: 69 6e 63 2d 31 2e 36 20 7b 0a 20 20 65 78 65 63  inc-1.6 {.  exec
06a0: 73 71 6c 20 7b 53 45 4c 45 43 54 20 6e 61 6d 65  sql {SELECT name
06b0: 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f 6d 61 73   FROM sqlite_mas
06c0: 74 65 72 20 57 48 45 52 45 20 74 79 70 65 3d 27  ter WHERE type='
06d0: 74 61 62 6c 65 27 7d 0a 7d 20 7b 74 31 20 73 71  table'}.} {t1 sq
06e0: 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 7d 0a 0a  lite_sequence}..
06f0: 23 20 49 6e 73 65 72 74 20 61 6e 20 65 6e 74 72  # Insert an entr
0700: 69 65 73 20 69 6e 74 6f 20 74 68 65 20 74 31 20  ies into the t1 
0710: 74 61 62 6c 65 20 61 6e 64 20 6d 61 6b 65 20 73  table and make s
0720: 75 72 65 20 74 68 65 20 6c 61 72 67 65 73 74 20  ure the largest 
0730: 6b 65 79 0a 23 20 69 73 20 61 6c 77 61 79 73 20  key.# is always 
0740: 72 65 63 6f 72 64 65 64 20 69 6e 20 74 68 65 20  recorded in the 
0750: 73 71 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 20  sqlite_sequence 
0760: 74 61 62 6c 65 2e 0a 23 0a 64 6f 5f 74 65 73 74  table..#.do_test
0770: 20 61 75 74 6f 69 6e 63 2d 32 2e 31 20 7b 0a 20   autoinc-2.1 {. 
0780: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53   execsql {.    S
0790: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 73 71 6c  ELECT * FROM sql
07a0: 69 74 65 5f 73 65 71 75 65 6e 63 65 0a 20 20 7d  ite_sequence.  }
07b0: 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 61 75  .} {}.do_test au
07c0: 74 6f 69 6e 63 2d 32 2e 32 20 7b 0a 20 20 65 78  toinc-2.2 {.  ex
07d0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45  ecsql {.    INSE
07e0: 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45  RT INTO t1 VALUE
07f0: 53 28 31 32 2c 33 34 29 3b 0a 20 20 20 20 53 45  S(12,34);.    SE
0800: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 73 71 6c 69  LECT * FROM sqli
0810: 74 65 5f 73 65 71 75 65 6e 63 65 3b 0a 20 20 7d  te_sequence;.  }
0820: 0a 7d 20 7b 74 31 20 31 32 7d 0a 64 6f 5f 74 65  .} {t1 12}.do_te
0830: 73 74 20 61 75 74 6f 69 6e 63 2d 32 2e 33 20 7b  st autoinc-2.3 {
0840: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
0850: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
0860: 56 41 4c 55 45 53 28 31 2c 32 33 29 3b 0a 20 20  VALUES(1,23);.  
0870: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
0880: 73 71 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 3b  sqlite_sequence;
0890: 0a 20 20 7d 0a 7d 20 7b 74 31 20 31 32 7d 0a 64  .  }.} {t1 12}.d
08a0: 6f 5f 74 65 73 74 20 61 75 74 6f 69 6e 63 2d 32  o_test autoinc-2
08b0: 2e 34 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .4 {.  execsql {
08c0: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
08d0: 20 74 31 20 56 41 4c 55 45 53 28 31 32 33 2c 34   t1 VALUES(123,4
08e0: 35 36 29 3b 0a 20 20 20 20 53 45 4c 45 43 54 20  56);.    SELECT 
08f0: 2a 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f 73 65  * FROM sqlite_se
0900: 71 75 65 6e 63 65 3b 0a 20 20 7d 0a 7d 20 7b 74  quence;.  }.} {t
0910: 31 20 31 32 33 7d 0a 64 6f 5f 74 65 73 74 20 61  1 123}.do_test a
0920: 75 74 6f 69 6e 63 2d 32 2e 35 20 7b 0a 20 20 65  utoinc-2.5 {.  e
0930: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53  xecsql {.    INS
0940: 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55  ERT INTO t1 VALU
0950: 45 53 28 4e 55 4c 4c 2c 35 36 37 29 3b 0a 20 20  ES(NULL,567);.  
0960: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
0970: 73 71 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 3b  sqlite_sequence;
0980: 0a 20 20 7d 0a 7d 20 7b 74 31 20 31 32 34 7d 0a  .  }.} {t1 124}.
0990: 64 6f 5f 74 65 73 74 20 61 75 74 6f 69 6e 63 2d  do_test autoinc-
09a0: 32 2e 36 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  2.6 {.  execsql 
09b0: 7b 0a 20 20 20 20 44 45 4c 45 54 45 20 46 52 4f  {.    DELETE FRO
09c0: 4d 20 74 31 20 57 48 45 52 45 20 79 3d 35 36 37  M t1 WHERE y=567
09d0: 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  ;.    SELECT * F
09e0: 52 4f 4d 20 73 71 6c 69 74 65 5f 73 65 71 75 65  ROM sqlite_seque
09f0: 6e 63 65 3b 0a 20 20 7d 0a 7d 20 7b 74 31 20 31  nce;.  }.} {t1 1
0a00: 32 34 7d 0a 64 6f 5f 74 65 73 74 20 61 75 74 6f  24}.do_test auto
0a10: 69 6e 63 2d 32 2e 37 20 7b 0a 20 20 65 78 65 63  inc-2.7 {.  exec
0a20: 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52 54  sql {.    INSERT
0a30: 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28   INTO t1 VALUES(
0a40: 4e 55 4c 4c 2c 35 36 37 29 3b 0a 20 20 20 20 53  NULL,567);.    S
0a50: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 73 71 6c  ELECT * FROM sql
0a60: 69 74 65 5f 73 65 71 75 65 6e 63 65 3b 0a 20 20  ite_sequence;.  
0a70: 7d 0a 7d 20 7b 74 31 20 31 32 35 7d 0a 64 6f 5f  }.} {t1 125}.do_
0a80: 74 65 73 74 20 61 75 74 6f 69 6e 63 2d 32 2e 38  test autoinc-2.8
0a90: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   {.  execsql {. 
0aa0: 20 20 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 74     DELETE FROM t
0ab0: 31 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20  1;.    SELECT * 
0ac0: 46 52 4f 4d 20 73 71 6c 69 74 65 5f 73 65 71 75  FROM sqlite_sequ
0ad0: 65 6e 63 65 3b 0a 20 20 7d 0a 7d 20 7b 74 31 20  ence;.  }.} {t1 
0ae0: 31 32 35 7d 0a 64 6f 5f 74 65 73 74 20 61 75 74  125}.do_test aut
0af0: 6f 69 6e 63 2d 32 2e 39 20 7b 0a 20 20 65 78 65  oinc-2.9 {.  exe
0b00: 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52  csql {.    INSER
0b10: 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53  T INTO t1 VALUES
0b20: 28 31 32 2c 33 34 29 3b 0a 20 20 20 20 53 45 4c  (12,34);.    SEL
0b30: 45 43 54 20 2a 20 46 52 4f 4d 20 73 71 6c 69 74  ECT * FROM sqlit
0b40: 65 5f 73 65 71 75 65 6e 63 65 3b 0a 20 20 7d 0a  e_sequence;.  }.
0b50: 7d 20 7b 74 31 20 31 32 35 7d 0a 64 6f 5f 74 65  } {t1 125}.do_te
0b60: 73 74 20 61 75 74 6f 69 6e 63 2d 32 2e 31 30 20  st autoinc-2.10 
0b70: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
0b80: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31    INSERT INTO t1
0b90: 20 56 41 4c 55 45 53 28 31 32 35 2c 34 35 36 29   VALUES(125,456)
0ba0: 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  ;.    SELECT * F
0bb0: 52 4f 4d 20 73 71 6c 69 74 65 5f 73 65 71 75 65  ROM sqlite_seque
0bc0: 6e 63 65 3b 0a 20 20 7d 0a 7d 20 7b 74 31 20 31  nce;.  }.} {t1 1
0bd0: 32 35 7d 0a 64 6f 5f 74 65 73 74 20 61 75 74 6f  25}.do_test auto
0be0: 69 6e 63 2d 32 2e 31 31 20 7b 0a 20 20 65 78 65  inc-2.11 {.  exe
0bf0: 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52  csql {.    INSER
0c00: 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53  T INTO t1 VALUES
0c10: 28 2d 31 32 33 34 35 36 37 2c 2d 31 29 3b 0a 20  (-1234567,-1);. 
0c20: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
0c30: 20 73 71 6c 69 74 65 5f 73 65 71 75 65 6e 63 65   sqlite_sequence
0c40: 3b 0a 20 20 7d 0a 7d 20 7b 74 31 20 31 32 35 7d  ;.  }.} {t1 125}
0c50: 0a 64 6f 5f 74 65 73 74 20 61 75 74 6f 69 6e 63  .do_test autoinc
0c60: 2d 32 2e 31 32 20 7b 0a 20 20 65 78 65 63 73 71  -2.12 {.  execsq
0c70: 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  l {.    INSERT I
0c80: 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 32 33  NTO t1 VALUES(23
0c90: 34 2c 35 36 37 38 29 3b 0a 20 20 20 20 53 45 4c  4,5678);.    SEL
0ca0: 45 43 54 20 2a 20 46 52 4f 4d 20 73 71 6c 69 74  ECT * FROM sqlit
0cb0: 65 5f 73 65 71 75 65 6e 63 65 3b 0a 20 20 7d 0a  e_sequence;.  }.
0cc0: 7d 20 7b 74 31 20 32 33 34 7d 0a 64 6f 5f 74 65  } {t1 234}.do_te
0cd0: 73 74 20 61 75 74 6f 69 6e 63 2d 32 2e 31 33 20  st autoinc-2.13 
0ce0: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
0cf0: 20 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 74 31    DELETE FROM t1
0d00: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
0d10: 4f 20 74 31 20 56 41 4c 55 45 53 28 4e 55 4c 4c  O t1 VALUES(NULL
0d20: 2c 31 29 3b 0a 20 20 20 20 53 45 4c 45 43 54 20  ,1);.    SELECT 
0d30: 2a 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f 73 65  * FROM sqlite_se
0d40: 71 75 65 6e 63 65 3b 0a 20 20 7d 0a 7d 20 7b 74  quence;.  }.} {t
0d50: 31 20 32 33 35 7d 0a 64 6f 5f 74 65 73 74 20 61  1 235}.do_test a
0d60: 75 74 6f 69 6e 63 2d 32 2e 31 34 20 7b 0a 20 20  utoinc-2.14 {.  
0d70: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45  execsql {.    SE
0d80: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 31 3b 0a  LECT * FROM t1;.
0d90: 20 20 7d 0a 7d 20 7b 32 33 35 20 31 7d 0a 0a 23    }.} {235 1}..#
0da0: 20 4d 61 6e 75 61 6c 6c 79 20 63 68 61 6e 67 65   Manually change
0db0: 20 74 68 65 20 61 75 74 6f 69 6e 63 72 65 6d 65   the autoincreme
0dc0: 6e 74 20 76 61 6c 75 65 73 20 69 6e 20 73 71 6c  nt values in sql
0dd0: 69 74 65 5f 73 65 71 75 65 6e 63 65 2e 0a 23 0a  ite_sequence..#.
0de0: 64 6f 5f 74 65 73 74 20 61 75 74 6f 69 6e 63 2d  do_test autoinc-
0df0: 32 2e 32 30 20 7b 0a 20 20 65 78 65 63 73 71 6c  2.20 {.  execsql
0e00: 20 7b 0a 20 20 20 20 55 50 44 41 54 45 20 73 71   {.    UPDATE sq
0e10: 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 20 53 45  lite_sequence SE
0e20: 54 20 73 65 71 3d 31 32 33 34 20 57 48 45 52 45  T seq=1234 WHERE
0e30: 20 6e 61 6d 65 3d 27 74 31 27 3b 0a 20 20 20 20   name='t1';.    
0e40: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56  INSERT INTO t1 V
0e50: 41 4c 55 45 53 28 4e 55 4c 4c 2c 32 29 3b 0a 20  ALUES(NULL,2);. 
0e60: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
0e70: 20 74 31 3b 0a 20 20 7d 0a 7d 20 7b 32 33 35 20   t1;.  }.} {235 
0e80: 31 20 31 32 33 35 20 32 7d 0a 64 6f 5f 74 65 73  1 1235 2}.do_tes
0e90: 74 20 61 75 74 6f 69 6e 63 2d 32 2e 32 31 20 7b  t autoinc-2.21 {
0ea0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
0eb0: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 73   SELECT * FROM s
0ec0: 71 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 3b 0a  qlite_sequence;.
0ed0: 20 20 7d 0a 7d 20 7b 74 31 20 31 32 33 35 7d 0a    }.} {t1 1235}.
0ee0: 64 6f 5f 74 65 73 74 20 61 75 74 6f 69 6e 63 2d  do_test autoinc-
0ef0: 32 2e 32 32 20 7b 0a 20 20 65 78 65 63 73 71 6c  2.22 {.  execsql
0f00: 20 7b 0a 20 20 20 20 55 50 44 41 54 45 20 73 71   {.    UPDATE sq
0f10: 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 20 53 45  lite_sequence SE
0f20: 54 20 73 65 71 3d 4e 55 4c 4c 20 57 48 45 52 45  T seq=NULL WHERE
0f30: 20 6e 61 6d 65 3d 27 74 31 27 3b 0a 20 20 20 20   name='t1';.    
0f40: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56  INSERT INTO t1 V
0f50: 41 4c 55 45 53 28 4e 55 4c 4c 2c 33 29 3b 0a 20  ALUES(NULL,3);. 
0f60: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
0f70: 20 74 31 3b 0a 20 20 7d 0a 7d 20 7b 32 33 35 20   t1;.  }.} {235 
0f80: 31 20 31 32 33 35 20 32 20 31 32 33 36 20 33 7d  1 1235 2 1236 3}
0f90: 0a 64 6f 5f 74 65 73 74 20 61 75 74 6f 69 6e 63  .do_test autoinc
0fa0: 2d 32 2e 32 33 20 7b 0a 20 20 65 78 65 63 73 71  -2.23 {.  execsq
0fb0: 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a  l {.    SELECT *
0fc0: 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f 73 65 71   FROM sqlite_seq
0fd0: 75 65 6e 63 65 3b 0a 20 20 7d 0a 7d 20 7b 74 31  uence;.  }.} {t1
0fe0: 20 31 32 33 36 7d 0a 64 6f 5f 74 65 73 74 20 61   1236}.do_test a
0ff0: 75 74 6f 69 6e 63 2d 32 2e 32 34 20 7b 0a 20 20  utoinc-2.24 {.  
1000: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 55 50  execsql {.    UP
1010: 44 41 54 45 20 73 71 6c 69 74 65 5f 73 65 71 75  DATE sqlite_sequ
1020: 65 6e 63 65 20 53 45 54 20 73 65 71 3d 27 61 2d  ence SET seq='a-
1030: 73 74 72 69 6e 67 27 20 57 48 45 52 45 20 6e 61  string' WHERE na
1040: 6d 65 3d 27 74 31 27 3b 0a 20 20 20 20 49 4e 53  me='t1';.    INS
1050: 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55  ERT INTO t1 VALU
1060: 45 53 28 4e 55 4c 4c 2c 34 29 3b 0a 20 20 20 20  ES(NULL,4);.    
1070: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 31  SELECT * FROM t1
1080: 3b 0a 20 20 7d 0a 7d 20 7b 32 33 35 20 31 20 31  ;.  }.} {235 1 1
1090: 32 33 35 20 32 20 31 32 33 36 20 33 20 31 32 33  235 2 1236 3 123
10a0: 37 20 34 7d 0a 64 6f 5f 74 65 73 74 20 61 75 74  7 4}.do_test aut
10b0: 6f 69 6e 63 2d 32 2e 32 35 20 7b 0a 20 20 65 78  oinc-2.25 {.  ex
10c0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45  ecsql {.    SELE
10d0: 43 54 20 2a 20 46 52 4f 4d 20 73 71 6c 69 74 65  CT * FROM sqlite
10e0: 5f 73 65 71 75 65 6e 63 65 3b 0a 20 20 7d 0a 7d  _sequence;.  }.}
10f0: 20 7b 74 31 20 31 32 33 37 7d 0a 64 6f 5f 74 65   {t1 1237}.do_te
1100: 73 74 20 61 75 74 6f 69 6e 63 2d 32 2e 32 36 20  st autoinc-2.26 
1110: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
1120: 20 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 73 71    DELETE FROM sq
1130: 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 20 57 48  lite_sequence WH
1140: 45 52 45 20 6e 61 6d 65 3d 27 74 31 27 3b 0a 20  ERE name='t1';. 
1150: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
1160: 31 20 56 41 4c 55 45 53 28 4e 55 4c 4c 2c 35 29  1 VALUES(NULL,5)
1170: 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  ;.    SELECT * F
1180: 52 4f 4d 20 74 31 3b 0a 20 20 7d 0a 7d 20 7b 32  ROM t1;.  }.} {2
1190: 33 35 20 31 20 31 32 33 35 20 32 20 31 32 33 36  35 1 1235 2 1236
11a0: 20 33 20 31 32 33 37 20 34 20 31 32 33 38 20 35   3 1237 4 1238 5
11b0: 7d 0a 64 6f 5f 74 65 73 74 20 61 75 74 6f 69 6e  }.do_test autoin
11c0: 63 2d 32 2e 32 37 20 7b 0a 20 20 65 78 65 63 73  c-2.27 {.  execs
11d0: 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20  ql {.    SELECT 
11e0: 2a 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f 73 65  * FROM sqlite_se
11f0: 71 75 65 6e 63 65 3b 0a 20 20 7d 0a 7d 20 7b 74  quence;.  }.} {t
1200: 31 20 31 32 33 38 7d 0a 64 6f 5f 74 65 73 74 20  1 1238}.do_test 
1210: 61 75 74 6f 69 6e 63 2d 32 2e 32 38 20 7b 0a 20  autoinc-2.28 {. 
1220: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 55   execsql {.    U
1230: 50 44 41 54 45 20 73 71 6c 69 74 65 5f 73 65 71  PDATE sqlite_seq
1240: 75 65 6e 63 65 20 53 45 54 20 73 65 71 3d 27 31  uence SET seq='1
1250: 32 33 34 35 36 37 38 39 30 31 32 33 34 35 36 37  2345678901234567
1260: 38 39 30 27 0a 20 20 20 20 20 20 57 48 45 52 45  890'.      WHERE
1270: 20 6e 61 6d 65 3d 27 74 31 27 3b 0a 20 20 20 20   name='t1';.    
1280: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56  INSERT INTO t1 V
1290: 41 4c 55 45 53 28 4e 55 4c 4c 2c 36 29 3b 0a 20  ALUES(NULL,6);. 
12a0: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
12b0: 20 74 31 3b 0a 20 20 7d 0a 7d 20 7b 32 33 35 20   t1;.  }.} {235 
12c0: 31 20 31 32 33 35 20 32 20 31 32 33 36 20 33 20  1 1235 2 1236 3 
12d0: 31 32 33 37 20 34 20 31 32 33 38 20 35 20 31 32  1237 4 1238 5 12
12e0: 33 39 20 36 7d 0a 64 6f 5f 74 65 73 74 20 61 75  39 6}.do_test au
12f0: 74 6f 69 6e 63 2d 32 2e 32 39 20 7b 0a 20 20 65  toinc-2.29 {.  e
1300: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c  xecsql {.    SEL
1310: 45 43 54 20 2a 20 46 52 4f 4d 20 73 71 6c 69 74  ECT * FROM sqlit
1320: 65 5f 73 65 71 75 65 6e 63 65 3b 0a 20 20 7d 0a  e_sequence;.  }.
1330: 7d 20 7b 74 31 20 31 32 33 39 7d 0a 0a 23 20 54  } {t1 1239}..# T
1340: 65 73 74 20 6d 75 6c 74 69 2d 72 6f 77 20 69 6e  est multi-row in
1350: 73 65 72 74 73 0a 23 0a 64 6f 5f 74 65 73 74 20  serts.#.do_test 
1360: 61 75 74 6f 69 6e 63 2d 32 2e 35 30 20 7b 0a 20  autoinc-2.50 {. 
1370: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 44   execsql {.    D
1380: 45 4c 45 54 45 20 46 52 4f 4d 20 74 31 20 57 48  ELETE FROM t1 WH
1390: 45 52 45 20 79 3e 3d 33 3b 0a 20 20 20 20 49 4e  ERE y>=3;.    IN
13a0: 53 45 52 54 20 49 4e 54 4f 20 74 31 20 53 45 4c  SERT INTO t1 SEL
13b0: 45 43 54 20 4e 55 4c 4c 2c 20 79 2b 32 20 46 52  ECT NULL, y+2 FR
13c0: 4f 4d 20 74 31 3b 0a 20 20 20 20 53 45 4c 45 43  OM t1;.    SELEC
13d0: 54 20 2a 20 46 52 4f 4d 20 74 31 3b 0a 20 20 7d  T * FROM t1;.  }
13e0: 0a 7d 20 7b 32 33 35 20 31 20 31 32 33 35 20 32  .} {235 1 1235 2
13f0: 20 31 32 34 30 20 33 20 31 32 34 31 20 34 7d 0a   1240 3 1241 4}.
1400: 64 6f 5f 74 65 73 74 20 61 75 74 6f 69 6e 63 2d  do_test autoinc-
1410: 32 2e 35 31 20 7b 0a 20 20 65 78 65 63 73 71 6c  2.51 {.  execsql
1420: 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20   {.    SELECT * 
1430: 46 52 4f 4d 20 73 71 6c 69 74 65 5f 73 65 71 75  FROM sqlite_sequ
1440: 65 6e 63 65 0a 20 20 7d 0a 7d 20 7b 74 31 20 31  ence.  }.} {t1 1
1450: 32 34 31 7d 0a 0a 69 66 63 61 70 61 62 6c 65 20  241}..ifcapable 
1460: 74 65 6d 70 64 62 20 7b 0a 20 20 64 6f 5f 74 65  tempdb {.  do_te
1470: 73 74 20 61 75 74 6f 69 6e 63 2d 32 2e 35 32 20  st autoinc-2.52 
1480: 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a  {.    execsql {.
1490: 20 20 20 20 20 20 43 52 45 41 54 45 20 54 45 4d        CREATE TEM
14a0: 50 20 54 41 42 4c 45 20 74 32 20 41 53 20 53 45  P TABLE t2 AS SE
14b0: 4c 45 43 54 20 79 20 46 52 4f 4d 20 74 31 3b 0a  LECT y FROM t1;.
14c0: 20 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54        INSERT INT
14d0: 4f 20 74 31 20 53 45 4c 45 43 54 20 4e 55 4c 4c  O t1 SELECT NULL
14e0: 2c 20 79 2b 34 20 46 52 4f 4d 20 74 32 3b 0a 20  , y+4 FROM t2;. 
14f0: 20 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52       SELECT * FR
1500: 4f 4d 20 74 31 3b 0a 20 20 20 20 7d 0a 20 20 7d  OM t1;.    }.  }
1510: 20 7b 32 33 35 20 31 20 31 32 33 35 20 32 20 31   {235 1 1235 2 1
1520: 32 34 30 20 33 20 31 32 34 31 20 34 20 31 32 34  240 3 1241 4 124
1530: 32 20 35 20 31 32 34 33 20 36 20 31 32 34 34 20  2 5 1243 6 1244 
1540: 37 20 31 32 34 35 20 38 7d 0a 20 20 64 6f 5f 74  7 1245 8}.  do_t
1550: 65 73 74 20 61 75 74 6f 69 6e 63 2d 32 2e 35 33  est autoinc-2.53
1560: 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b   {.    execsql {
1570: 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 2a 20  .      SELECT * 
1580: 46 52 4f 4d 20 73 71 6c 69 74 65 5f 73 65 71 75  FROM sqlite_sequ
1590: 65 6e 63 65 0a 20 20 20 20 7d 0a 20 20 7d 20 7b  ence.    }.  } {
15a0: 74 31 20 31 32 34 35 7d 0a 20 20 64 6f 5f 74 65  t1 1245}.  do_te
15b0: 73 74 20 61 75 74 6f 69 6e 63 2d 32 2e 35 34 20  st autoinc-2.54 
15c0: 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a  {.    execsql {.
15d0: 20 20 20 20 20 20 44 45 4c 45 54 45 20 46 52 4f        DELETE FRO
15e0: 4d 20 74 31 3b 0a 20 20 20 20 20 20 49 4e 53 45  M t1;.      INSE
15f0: 52 54 20 49 4e 54 4f 20 74 31 20 53 45 4c 45 43  RT INTO t1 SELEC
1600: 54 20 4e 55 4c 4c 2c 20 79 20 46 52 4f 4d 20 74  T NULL, y FROM t
1610: 32 3b 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20  2;.      SELECT 
1620: 2a 20 46 52 4f 4d 20 74 31 3b 0a 20 20 20 20 7d  * FROM t1;.    }
1630: 0a 20 20 7d 20 7b 31 32 34 36 20 31 20 31 32 34  .  } {1246 1 124
1640: 37 20 32 20 31 32 34 38 20 33 20 31 32 34 39 20  7 2 1248 3 1249 
1650: 34 7d 0a 20 20 64 6f 5f 74 65 73 74 20 61 75 74  4}.  do_test aut
1660: 6f 69 6e 63 2d 32 2e 35 35 20 7b 0a 20 20 20 20  oinc-2.55 {.    
1670: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 20 20  execsql {.      
1680: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 73 71  SELECT * FROM sq
1690: 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 0a 20 20  lite_sequence.  
16a0: 20 20 7d 0a 20 20 7d 20 7b 74 31 20 31 32 34 39    }.  } {t1 1249
16b0: 7d 0a 7d 0a 0a 23 20 43 72 65 61 74 65 20 6d 75  }.}..# Create mu
16c0: 6c 74 69 70 6c 65 20 41 55 54 4f 49 4e 43 52 45  ltiple AUTOINCRE
16d0: 4d 45 4e 54 20 74 61 62 6c 65 73 2e 20 20 4d 61  MENT tables.  Ma
16e0: 6b 65 20 73 75 72 65 20 61 6c 6c 20 73 65 71 75  ke sure all sequ
16f0: 65 6e 63 65 73 20 61 72 65 0a 23 20 74 72 61 63  ences are.# trac
1700: 6b 65 64 20 73 65 70 61 72 61 74 65 6c 79 20 61  ked separately a
1710: 6e 64 20 64 6f 20 6e 6f 74 20 69 6e 74 65 72 66  nd do not interf
1720: 65 72 65 20 77 69 74 68 20 6f 6e 65 20 61 6e 6f  ere with one ano
1730: 74 68 65 72 2e 0a 23 0a 64 6f 5f 74 65 73 74 20  ther..#.do_test 
1740: 61 75 74 6f 69 6e 63 2d 32 2e 37 30 20 7b 0a 20  autoinc-2.70 {. 
1750: 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20   catchsql {.    
1760: 44 52 4f 50 20 54 41 42 4c 45 20 74 32 3b 0a 20  DROP TABLE t2;. 
1770: 20 7d 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   }.  execsql {. 
1780: 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20     CREATE TABLE 
1790: 74 32 28 64 2c 20 65 20 49 4e 54 45 47 45 52 20  t2(d, e INTEGER 
17a0: 50 52 49 4d 41 52 59 20 4b 45 59 20 41 55 54 4f  PRIMARY KEY AUTO
17b0: 49 4e 43 52 45 4d 45 4e 54 2c 20 66 29 3b 0a 20  INCREMENT, f);. 
17c0: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
17d0: 32 28 64 29 20 56 41 4c 55 45 53 28 31 29 3b 0a  2(d) VALUES(1);.
17e0: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
17f0: 4d 20 73 71 6c 69 74 65 5f 73 65 71 75 65 6e 63  M sqlite_sequenc
1800: 65 3b 0a 20 20 7d 0a 7d 20 5b 69 66 63 61 70 61  e;.  }.} [ifcapa
1810: 62 6c 65 20 74 65 6d 70 64 62 20 7b 6c 69 73 74  ble tempdb {list
1820: 20 74 31 20 31 32 34 39 20 74 32 20 31 7d 20 65   t1 1249 t2 1} e
1830: 6c 73 65 20 7b 6c 69 73 74 20 74 31 20 31 32 34  lse {list t1 124
1840: 31 20 74 32 20 31 7d 5d 0a 64 6f 5f 74 65 73 74  1 t2 1}].do_test
1850: 20 61 75 74 6f 69 6e 63 2d 32 2e 37 31 20 7b 0a   autoinc-2.71 {.
1860: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
1870: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 28 64  INSERT INTO t2(d
1880: 29 20 56 41 4c 55 45 53 28 32 29 3b 0a 20 20 20  ) VALUES(2);.   
1890: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 73   SELECT * FROM s
18a0: 71 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 3b 0a  qlite_sequence;.
18b0: 20 20 7d 0a 7d 20 5b 69 66 63 61 70 61 62 6c 65    }.} [ifcapable
18c0: 20 74 65 6d 70 64 62 20 7b 6c 69 73 74 20 74 31   tempdb {list t1
18d0: 20 31 32 34 39 20 74 32 20 32 7d 20 65 6c 73 65   1249 t2 2} else
18e0: 20 7b 6c 69 73 74 20 74 31 20 31 32 34 31 20 74   {list t1 1241 t
18f0: 32 20 32 7d 5d 0a 64 6f 5f 74 65 73 74 20 61 75  2 2}].do_test au
1900: 74 6f 69 6e 63 2d 32 2e 37 32 20 7b 0a 20 20 65  toinc-2.72 {.  e
1910: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53  xecsql {.    INS
1920: 45 52 54 20 49 4e 54 4f 20 74 31 28 78 29 20 56  ERT INTO t1(x) V
1930: 41 4c 55 45 53 28 31 30 30 30 30 29 3b 0a 20 20  ALUES(10000);.  
1940: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
1950: 73 71 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 3b  sqlite_sequence;
1960: 0a 20 20 7d 0a 7d 20 7b 74 31 20 31 30 30 30 30  .  }.} {t1 10000
1970: 20 74 32 20 32 7d 0a 64 6f 5f 74 65 73 74 20 61   t2 2}.do_test a
1980: 75 74 6f 69 6e 63 2d 32 2e 37 33 20 7b 0a 20 20  utoinc-2.73 {.  
1990: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52  execsql {.    CR
19a0: 45 41 54 45 20 54 41 42 4c 45 20 74 33 28 67 20  EATE TABLE t3(g 
19b0: 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59 20  INTEGER PRIMARY 
19c0: 4b 45 59 20 41 55 54 4f 49 4e 43 52 45 4d 45 4e  KEY AUTOINCREMEN
19d0: 54 2c 20 68 29 3b 0a 20 20 20 20 49 4e 53 45 52  T, h);.    INSER
19e0: 54 20 49 4e 54 4f 20 74 33 28 68 29 20 56 41 4c  T INTO t3(h) VAL
19f0: 55 45 53 28 31 29 3b 0a 20 20 20 20 53 45 4c 45  UES(1);.    SELE
1a00: 43 54 20 2a 20 46 52 4f 4d 20 73 71 6c 69 74 65  CT * FROM sqlite
1a10: 5f 73 65 71 75 65 6e 63 65 3b 0a 20 20 7d 0a 7d  _sequence;.  }.}
1a20: 20 7b 74 31 20 31 30 30 30 30 20 74 32 20 32 20   {t1 10000 t2 2 
1a30: 74 33 20 31 7d 0a 64 6f 5f 74 65 73 74 20 61 75  t3 1}.do_test au
1a40: 74 6f 69 6e 63 2d 32 2e 37 34 20 7b 0a 20 20 65  toinc-2.74 {.  e
1a50: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53  xecsql {.    INS
1a60: 45 52 54 20 49 4e 54 4f 20 74 32 28 64 2c 65 29  ERT INTO t2(d,e)
1a70: 20 56 41 4c 55 45 53 28 33 2c 31 30 30 29 3b 0a   VALUES(3,100);.
1a80: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
1a90: 4d 20 73 71 6c 69 74 65 5f 73 65 71 75 65 6e 63  M sqlite_sequenc
1aa0: 65 3b 0a 20 20 7d 0a 7d 20 7b 74 31 20 31 30 30  e;.  }.} {t1 100
1ab0: 30 30 20 74 32 20 31 30 30 20 74 33 20 31 7d 0a  00 t2 100 t3 1}.
1ac0: 0a 0a 23 20 57 68 65 6e 20 61 20 74 61 62 6c 65  ..# When a table
1ad0: 20 77 69 74 68 20 61 6e 20 41 55 54 4f 49 4e 43   with an AUTOINC
1ae0: 52 45 4d 45 4e 54 20 69 73 20 64 65 6c 65 74 65  REMENT is delete
1af0: 64 2c 20 74 68 65 20 63 6f 72 72 65 73 70 6f 6e  d, the correspon
1b00: 64 69 6e 67 20 65 6e 74 72 79 0a 23 20 69 6e 20  ding entry.# in 
1b10: 74 68 65 20 53 51 4c 49 54 45 5f 53 45 51 55 45  the SQLITE_SEQUE
1b20: 4e 43 45 20 74 61 62 6c 65 20 73 68 6f 75 6c 64  NCE table should
1b30: 20 61 6c 73 6f 20 62 65 20 64 65 6c 65 74 65 64   also be deleted
1b40: 2e 20 20 42 75 74 20 74 68 65 20 53 51 4c 49 54  .  But the SQLIT
1b50: 45 5f 53 45 51 55 45 4e 43 45 0a 23 20 74 61 62  E_SEQUENCE.# tab
1b60: 6c 65 20 69 74 73 65 6c 66 20 73 68 6f 75 6c 64  le itself should
1b70: 20 72 65 6d 61 69 6e 20 62 65 68 69 6e 64 2e 0a   remain behind..
1b80: 23 0a 64 6f 5f 74 65 73 74 20 61 75 74 6f 69 6e  #.do_test autoin
1b90: 63 2d 33 2e 31 20 7b 0a 20 20 65 78 65 63 73 71  c-3.1 {.  execsq
1ba0: 6c 20 7b 53 45 4c 45 43 54 20 6e 61 6d 65 20 46  l {SELECT name F
1bb0: 52 4f 4d 20 73 71 6c 69 74 65 5f 73 65 71 75 65  ROM sqlite_seque
1bc0: 6e 63 65 7d 0a 7d 20 7b 74 31 20 74 32 20 74 33  nce}.} {t1 t2 t3
1bd0: 7d 0a 64 6f 5f 74 65 73 74 20 61 75 74 6f 69 6e  }.do_test autoin
1be0: 63 2d 33 2e 32 20 7b 0a 20 20 65 78 65 63 73 71  c-3.2 {.  execsq
1bf0: 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20 54 41 42  l {.    DROP TAB
1c00: 4c 45 20 74 31 3b 0a 20 20 20 20 53 45 4c 45 43  LE t1;.    SELEC
1c10: 54 20 6e 61 6d 65 20 46 52 4f 4d 20 73 71 6c 69  T name FROM sqli
1c20: 74 65 5f 73 65 71 75 65 6e 63 65 3b 0a 20 20 7d  te_sequence;.  }
1c30: 0a 7d 20 7b 74 32 20 74 33 7d 0a 64 6f 5f 74 65  .} {t2 t3}.do_te
1c40: 73 74 20 61 75 74 6f 69 6e 63 2d 33 2e 33 20 7b  st autoinc-3.3 {
1c50: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
1c60: 20 44 52 4f 50 20 54 41 42 4c 45 20 74 33 3b 0a   DROP TABLE t3;.
1c70: 20 20 20 20 53 45 4c 45 43 54 20 6e 61 6d 65 20      SELECT name 
1c80: 46 52 4f 4d 20 73 71 6c 69 74 65 5f 73 65 71 75  FROM sqlite_sequ
1c90: 65 6e 63 65 3b 0a 20 20 7d 0a 7d 20 7b 74 32 7d  ence;.  }.} {t2}
1ca0: 0a 64 6f 5f 74 65 73 74 20 61 75 74 6f 69 6e 63  .do_test autoinc
1cb0: 2d 33 2e 34 20 7b 0a 20 20 65 78 65 63 73 71 6c  -3.4 {.  execsql
1cc0: 20 7b 0a 20 20 20 20 44 52 4f 50 20 54 41 42 4c   {.    DROP TABL
1cd0: 45 20 74 32 3b 0a 20 20 20 20 53 45 4c 45 43 54  E t2;.    SELECT
1ce0: 20 6e 61 6d 65 20 46 52 4f 4d 20 73 71 6c 69 74   name FROM sqlit
1cf0: 65 5f 73 65 71 75 65 6e 63 65 3b 0a 20 20 7d 0a  e_sequence;.  }.
1d00: 7d 20 7b 7d 0a 0a 23 20 41 55 54 4f 49 4e 43 52  } {}..# AUTOINCR
1d10: 45 4d 45 4e 54 20 6f 6e 20 54 45 4d 50 20 74 61  EMENT on TEMP ta
1d20: 62 6c 65 73 2e 0a 23 0a 69 66 63 61 70 61 62 6c  bles..#.ifcapabl
1d30: 65 20 74 65 6d 70 64 62 20 7b 0a 20 20 64 6f 5f  e tempdb {.  do_
1d40: 74 65 73 74 20 61 75 74 6f 69 6e 63 2d 34 2e 31  test autoinc-4.1
1d50: 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b   {.    execsql {
1d60: 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 31 2c  .      SELECT 1,
1d70: 20 6e 61 6d 65 20 46 52 4f 4d 20 73 71 6c 69 74   name FROM sqlit
1d80: 65 5f 6d 61 73 74 65 72 20 57 48 45 52 45 20 74  e_master WHERE t
1d90: 79 70 65 3d 27 74 61 62 6c 65 27 3b 0a 20 20 20  ype='table';.   
1da0: 20 20 20 53 45 4c 45 43 54 20 32 2c 20 6e 61 6d     SELECT 2, nam
1db0: 65 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f 74 65  e FROM sqlite_te
1dc0: 6d 70 5f 6d 61 73 74 65 72 20 57 48 45 52 45 20  mp_master WHERE 
1dd0: 74 79 70 65 3d 27 74 61 62 6c 65 27 3b 0a 20 20  type='table';.  
1de0: 20 20 7d 0a 20 20 7d 20 7b 31 20 73 71 6c 69 74    }.  } {1 sqlit
1df0: 65 5f 73 65 71 75 65 6e 63 65 7d 0a 20 20 64 6f  e_sequence}.  do
1e00: 5f 74 65 73 74 20 61 75 74 6f 69 6e 63 2d 34 2e  _test autoinc-4.
1e10: 32 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20  2 {.    execsql 
1e20: 7b 0a 20 20 20 20 20 20 43 52 45 41 54 45 20 54  {.      CREATE T
1e30: 41 42 4c 45 20 74 31 28 78 20 49 4e 54 45 47 45  ABLE t1(x INTEGE
1e40: 52 20 50 52 49 4d 41 52 59 20 4b 45 59 20 41 55  R PRIMARY KEY AU
1e50: 54 4f 49 4e 43 52 45 4d 45 4e 54 2c 20 79 29 3b  TOINCREMENT, y);
1e60: 0a 20 20 20 20 20 20 43 52 45 41 54 45 20 54 45  .      CREATE TE
1e70: 4d 50 20 54 41 42 4c 45 20 74 33 28 61 20 49 4e  MP TABLE t3(a IN
1e80: 54 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b 45  TEGER PRIMARY KE
1e90: 59 20 41 55 54 4f 49 4e 43 52 45 4d 45 4e 54 2c  Y AUTOINCREMENT,
1ea0: 20 62 29 3b 0a 20 20 20 20 20 20 53 45 4c 45 43   b);.      SELEC
1eb0: 54 20 31 2c 20 6e 61 6d 65 20 46 52 4f 4d 20 73  T 1, name FROM s
1ec0: 71 6c 69 74 65 5f 6d 61 73 74 65 72 20 57 48 45  qlite_master WHE
1ed0: 52 45 20 74 79 70 65 3d 27 74 61 62 6c 65 27 3b  RE type='table';
1ee0: 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 32 2c  .      SELECT 2,
1ef0: 20 6e 61 6d 65 20 46 52 4f 4d 20 73 71 6c 69 74   name FROM sqlit
1f00: 65 5f 74 65 6d 70 5f 6d 61 73 74 65 72 20 57 48  e_temp_master WH
1f10: 45 52 45 20 74 79 70 65 3d 27 74 61 62 6c 65 27  ERE type='table'
1f20: 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 31 20 73  ;.    }.  } {1 s
1f30: 71 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 20 31  qlite_sequence 1
1f40: 20 74 31 20 32 20 74 33 20 32 20 73 71 6c 69 74   t1 2 t3 2 sqlit
1f50: 65 5f 73 65 71 75 65 6e 63 65 7d 0a 20 20 64 6f  e_sequence}.  do
1f60: 5f 74 65 73 74 20 61 75 74 6f 69 6e 63 2d 34 2e  _test autoinc-4.
1f70: 33 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20  3 {.    execsql 
1f80: 7b 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 31  {.      SELECT 1
1f90: 2c 20 2a 20 46 52 4f 4d 20 6d 61 69 6e 2e 73 71  , * FROM main.sq
1fa0: 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 3b 0a 20  lite_sequence;. 
1fb0: 20 20 20 20 20 53 45 4c 45 43 54 20 32 2c 20 2a       SELECT 2, *
1fc0: 20 46 52 4f 4d 20 74 65 6d 70 2e 73 71 6c 69 74   FROM temp.sqlit
1fd0: 65 5f 73 65 71 75 65 6e 63 65 3b 0a 20 20 20 20  e_sequence;.    
1fe0: 7d 0a 20 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74 65  }.  } {}.  do_te
1ff0: 73 74 20 61 75 74 6f 69 6e 63 2d 34 2e 34 20 7b  st autoinc-4.4 {
2000: 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20  .    execsql {. 
2010: 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f       INSERT INTO
2020: 20 74 31 20 56 41 4c 55 45 53 28 31 30 2c 31 29   t1 VALUES(10,1)
2030: 3b 0a 20 20 20 20 20 20 49 4e 53 45 52 54 20 49  ;.      INSERT I
2040: 4e 54 4f 20 74 33 20 56 41 4c 55 45 53 28 32 30  NTO t3 VALUES(20
2050: 2c 32 29 3b 0a 20 20 20 20 20 20 49 4e 53 45 52  ,2);.      INSER
2060: 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53  T INTO t1 VALUES
2070: 28 4e 55 4c 4c 2c 33 29 3b 0a 20 20 20 20 20 20  (NULL,3);.      
2080: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 33 20 56  INSERT INTO t3 V
2090: 41 4c 55 45 53 28 4e 55 4c 4c 2c 34 29 3b 0a 20  ALUES(NULL,4);. 
20a0: 20 20 20 7d 0a 20 20 7d 20 7b 7d 0a 20 20 0a 20     }.  } {}.  . 
20b0: 20 69 66 63 61 70 61 62 6c 65 20 63 6f 6d 70 6f   ifcapable compo
20c0: 75 6e 64 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20  und {.  do_test 
20d0: 61 75 74 6f 69 6e 63 2d 34 2e 34 2e 31 20 7b 0a  autoinc-4.4.1 {.
20e0: 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20      execsql {.  
20f0: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
2100: 4d 20 74 31 20 55 4e 49 4f 4e 20 41 4c 4c 20 53  M t1 UNION ALL S
2110: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 33 3b  ELECT * FROM t3;
2120: 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 31 30 20 31  .    }.  } {10 1
2130: 20 31 31 20 33 20 32 30 20 32 20 32 31 20 34 7d   11 3 20 2 21 4}
2140: 0a 20 20 7d 20 3b 23 20 69 66 63 61 70 61 62 6c  .  } ;# ifcapabl
2150: 65 20 63 6f 6d 70 6f 75 6e 64 0a 20 20 0a 20 20  e compound.  .  
2160: 64 6f 5f 74 65 73 74 20 61 75 74 6f 69 6e 63 2d  do_test autoinc-
2170: 34 2e 35 20 7b 0a 20 20 20 20 65 78 65 63 73 71  4.5 {.    execsq
2180: 6c 20 7b 0a 20 20 20 20 20 20 53 45 4c 45 43 54  l {.      SELECT
2190: 20 31 2c 20 2a 20 46 52 4f 4d 20 6d 61 69 6e 2e   1, * FROM main.
21a0: 73 71 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 3b  sqlite_sequence;
21b0: 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 32 2c  .      SELECT 2,
21c0: 20 2a 20 46 52 4f 4d 20 74 65 6d 70 2e 73 71 6c   * FROM temp.sql
21d0: 69 74 65 5f 73 65 71 75 65 6e 63 65 3b 0a 20 20  ite_sequence;.  
21e0: 20 20 7d 0a 20 20 7d 20 7b 31 20 74 31 20 31 31    }.  } {1 t1 11
21f0: 20 32 20 74 33 20 32 31 7d 0a 20 20 64 6f 5f 74   2 t3 21}.  do_t
2200: 65 73 74 20 61 75 74 6f 69 6e 63 2d 34 2e 36 20  est autoinc-4.6 
2210: 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a  {.    execsql {.
2220: 20 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54        INSERT INT
2230: 4f 20 74 31 20 53 45 4c 45 43 54 20 2a 20 46 52  O t1 SELECT * FR
2240: 4f 4d 20 74 33 3b 0a 20 20 20 20 20 20 53 45 4c  OM t3;.      SEL
2250: 45 43 54 20 31 2c 20 2a 20 46 52 4f 4d 20 6d 61  ECT 1, * FROM ma
2260: 69 6e 2e 73 71 6c 69 74 65 5f 73 65 71 75 65 6e  in.sqlite_sequen
2270: 63 65 3b 0a 20 20 20 20 20 20 53 45 4c 45 43 54  ce;.      SELECT
2280: 20 32 2c 20 2a 20 46 52 4f 4d 20 74 65 6d 70 2e   2, * FROM temp.
2290: 73 71 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 3b  sqlite_sequence;
22a0: 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 31 20 74 31  .    }.  } {1 t1
22b0: 20 32 31 20 32 20 74 33 20 32 31 7d 0a 20 20 64   21 2 t3 21}.  d
22c0: 6f 5f 74 65 73 74 20 61 75 74 6f 69 6e 63 2d 34  o_test autoinc-4
22d0: 2e 37 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c  .7 {.    execsql
22e0: 20 7b 0a 20 20 20 20 20 20 49 4e 53 45 52 54 20   {.      INSERT 
22f0: 49 4e 54 4f 20 74 33 20 53 45 4c 45 43 54 20 78  INTO t3 SELECT x
2300: 2b 31 30 30 2c 20 79 20 20 46 52 4f 4d 20 74 31  +100, y  FROM t1
2310: 3b 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 31  ;.      SELECT 1
2320: 2c 20 2a 20 46 52 4f 4d 20 6d 61 69 6e 2e 73 71  , * FROM main.sq
2330: 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 3b 0a 20  lite_sequence;. 
2340: 20 20 20 20 20 53 45 4c 45 43 54 20 32 2c 20 2a       SELECT 2, *
2350: 20 46 52 4f 4d 20 74 65 6d 70 2e 73 71 6c 69 74   FROM temp.sqlit
2360: 65 5f 73 65 71 75 65 6e 63 65 3b 0a 20 20 20 20  e_sequence;.    
2370: 7d 0a 20 20 7d 20 7b 31 20 74 31 20 32 31 20 32  }.  } {1 t1 21 2
2380: 20 74 33 20 31 32 31 7d 0a 20 20 64 6f 5f 74 65   t3 121}.  do_te
2390: 73 74 20 61 75 74 6f 69 6e 63 2d 34 2e 38 20 7b  st autoinc-4.8 {
23a0: 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20  .    execsql {. 
23b0: 20 20 20 20 20 44 52 4f 50 20 54 41 42 4c 45 20       DROP TABLE 
23c0: 74 33 3b 0a 20 20 20 20 20 20 53 45 4c 45 43 54  t3;.      SELECT
23d0: 20 31 2c 20 2a 20 46 52 4f 4d 20 6d 61 69 6e 2e   1, * FROM main.
23e0: 73 71 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 3b  sqlite_sequence;
23f0: 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 32 2c  .      SELECT 2,
2400: 20 2a 20 46 52 4f 4d 20 74 65 6d 70 2e 73 71 6c   * FROM temp.sql
2410: 69 74 65 5f 73 65 71 75 65 6e 63 65 3b 0a 20 20  ite_sequence;.  
2420: 20 20 7d 0a 20 20 7d 20 7b 31 20 74 31 20 32 31    }.  } {1 t1 21
2430: 7d 0a 20 20 64 6f 5f 74 65 73 74 20 61 75 74 6f  }.  do_test auto
2440: 69 6e 63 2d 34 2e 39 20 7b 0a 20 20 20 20 65 78  inc-4.9 {.    ex
2450: 65 63 73 71 6c 20 7b 0a 20 20 20 20 20 20 43 52  ecsql {.      CR
2460: 45 41 54 45 20 54 45 4d 50 20 54 41 42 4c 45 20  EATE TEMP TABLE 
2470: 74 32 28 70 20 49 4e 54 45 47 45 52 20 50 52 49  t2(p INTEGER PRI
2480: 4d 41 52 59 20 4b 45 59 20 41 55 54 4f 49 4e 43  MARY KEY AUTOINC
2490: 52 45 4d 45 4e 54 2c 20 71 29 3b 0a 20 20 20 20  REMENT, q);.    
24a0: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32    INSERT INTO t2
24b0: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
24c0: 31 3b 0a 20 20 20 20 20 20 44 52 4f 50 20 54 41  1;.      DROP TA
24d0: 42 4c 45 20 74 31 3b 0a 20 20 20 20 20 20 53 45  BLE t1;.      SE
24e0: 4c 45 43 54 20 31 2c 20 2a 20 46 52 4f 4d 20 6d  LECT 1, * FROM m
24f0: 61 69 6e 2e 73 71 6c 69 74 65 5f 73 65 71 75 65  ain.sqlite_seque
2500: 6e 63 65 3b 0a 20 20 20 20 20 20 53 45 4c 45 43  nce;.      SELEC
2510: 54 20 32 2c 20 2a 20 46 52 4f 4d 20 74 65 6d 70  T 2, * FROM temp
2520: 2e 73 71 6c 69 74 65 5f 73 65 71 75 65 6e 63 65  .sqlite_sequence
2530: 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 32 20 74  ;.    }.  } {2 t
2540: 32 20 32 31 7d 0a 20 20 64 6f 5f 74 65 73 74 20  2 21}.  do_test 
2550: 61 75 74 6f 69 6e 63 2d 34 2e 31 30 20 7b 0a 20  autoinc-4.10 {. 
2560: 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20     execsql {.   
2570: 20 20 20 44 52 4f 50 20 54 41 42 4c 45 20 74 32     DROP TABLE t2
2580: 3b 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 31  ;.      SELECT 1
2590: 2c 20 2a 20 46 52 4f 4d 20 6d 61 69 6e 2e 73 71  , * FROM main.sq
25a0: 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 3b 0a 20  lite_sequence;. 
25b0: 20 20 20 20 20 53 45 4c 45 43 54 20 32 2c 20 2a       SELECT 2, *
25c0: 20 46 52 4f 4d 20 74 65 6d 70 2e 73 71 6c 69 74   FROM temp.sqlit
25d0: 65 5f 73 65 71 75 65 6e 63 65 3b 0a 20 20 20 20  e_sequence;.    
25e0: 7d 0a 20 20 7d 20 7b 7d 0a 7d 0a 0a 23 20 4d 61  }.  } {}.}..# Ma
25f0: 6b 65 20 73 75 72 65 20 41 55 54 4f 49 4e 43 52  ke sure AUTOINCR
2600: 45 4d 45 4e 54 20 77 6f 72 6b 73 20 6f 6e 20 41  EMENT works on A
2610: 54 54 41 43 48 2d 65 64 20 74 61 62 6c 65 73 2e  TTACH-ed tables.
2620: 0a 23 0a 69 66 63 61 70 61 62 6c 65 20 74 65 6d  .#.ifcapable tem
2630: 70 64 62 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20  pdb {.  do_test 
2640: 61 75 74 6f 69 6e 63 2d 35 2e 31 20 7b 0a 20 20  autoinc-5.1 {.  
2650: 20 20 66 69 6c 65 20 64 65 6c 65 74 65 20 2d 66    file delete -f
2660: 6f 72 63 65 20 74 65 73 74 32 2e 64 62 0a 20 20  orce test2.db.  
2670: 20 20 66 69 6c 65 20 64 65 6c 65 74 65 20 2d 66    file delete -f
2680: 6f 72 63 65 20 74 65 73 74 32 2e 64 62 2d 6a 6f  orce test2.db-jo
2690: 75 72 6e 61 6c 0a 20 20 20 20 73 71 6c 69 74 65  urnal.    sqlite
26a0: 33 20 64 62 32 20 74 65 73 74 32 2e 64 62 0a 20  3 db2 test2.db. 
26b0: 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20     execsql {.   
26c0: 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20     CREATE TABLE 
26d0: 74 34 28 6d 20 49 4e 54 45 47 45 52 20 50 52 49  t4(m INTEGER PRI
26e0: 4d 41 52 59 20 4b 45 59 20 41 55 54 4f 49 4e 43  MARY KEY AUTOINC
26f0: 52 45 4d 45 4e 54 2c 20 6e 29 3b 0a 20 20 20 20  REMENT, n);.    
2700: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74    CREATE TABLE t
2710: 35 28 6f 2c 20 70 20 49 4e 54 45 47 45 52 20 50  5(o, p INTEGER P
2720: 52 49 4d 41 52 59 20 4b 45 59 20 41 55 54 4f 49  RIMARY KEY AUTOI
2730: 4e 43 52 45 4d 45 4e 54 29 3b 0a 20 20 20 20 7d  NCREMENT);.    }
2740: 20 64 62 32 3b 0a 20 20 20 20 65 78 65 63 73 71   db2;.    execsq
2750: 6c 20 7b 0a 20 20 20 20 20 20 41 54 54 41 43 48  l {.      ATTACH
2760: 20 27 74 65 73 74 32 2e 64 62 27 20 61 73 20 61   'test2.db' as a
2770: 75 78 3b 0a 20 20 20 20 20 20 53 45 4c 45 43 54  ux;.      SELECT
2780: 20 31 2c 20 2a 20 46 52 4f 4d 20 6d 61 69 6e 2e   1, * FROM main.
2790: 73 71 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 3b  sqlite_sequence;
27a0: 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 32 2c  .      SELECT 2,
27b0: 20 2a 20 46 52 4f 4d 20 74 65 6d 70 2e 73 71 6c   * FROM temp.sql
27c0: 69 74 65 5f 73 65 71 75 65 6e 63 65 3b 0a 20 20  ite_sequence;.  
27d0: 20 20 20 20 53 45 4c 45 43 54 20 33 2c 20 2a 20      SELECT 3, * 
27e0: 46 52 4f 4d 20 61 75 78 2e 73 71 6c 69 74 65 5f  FROM aux.sqlite_
27f0: 73 65 71 75 65 6e 63 65 3b 0a 20 20 20 20 7d 0a  sequence;.    }.
2800: 20 20 7d 20 7b 7d 0a 20 20 64 6f 5f 74 65 73 74    } {}.  do_test
2810: 20 61 75 74 6f 69 6e 63 2d 35 2e 32 20 7b 0a 20   autoinc-5.2 {. 
2820: 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20     execsql {.   
2830: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
2840: 34 20 56 41 4c 55 45 53 28 4e 55 4c 4c 2c 31 29  4 VALUES(NULL,1)
2850: 3b 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 31  ;.      SELECT 1
2860: 2c 20 2a 20 46 52 4f 4d 20 6d 61 69 6e 2e 73 71  , * FROM main.sq
2870: 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 3b 0a 20  lite_sequence;. 
2880: 20 20 20 20 20 53 45 4c 45 43 54 20 32 2c 20 2a       SELECT 2, *
2890: 20 46 52 4f 4d 20 74 65 6d 70 2e 73 71 6c 69 74   FROM temp.sqlit
28a0: 65 5f 73 65 71 75 65 6e 63 65 3b 0a 20 20 20 20  e_sequence;.    
28b0: 20 20 53 45 4c 45 43 54 20 33 2c 20 2a 20 46 52    SELECT 3, * FR
28c0: 4f 4d 20 61 75 78 2e 73 71 6c 69 74 65 5f 73 65  OM aux.sqlite_se
28d0: 71 75 65 6e 63 65 3b 0a 20 20 20 20 7d 0a 20 20  quence;.    }.  
28e0: 7d 20 7b 33 20 74 34 20 31 7d 0a 20 20 64 6f 5f  } {3 t4 1}.  do_
28f0: 74 65 73 74 20 61 75 74 6f 69 6e 63 2d 35 2e 33  test autoinc-5.3
2900: 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b   {.    execsql {
2910: 0a 20 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e  .      INSERT IN
2920: 54 4f 20 74 35 20 56 41 4c 55 45 53 28 31 30 30  TO t5 VALUES(100
2930: 2c 32 30 30 29 3b 0a 20 20 20 20 20 20 53 45 4c  ,200);.      SEL
2940: 45 43 54 20 2a 20 46 52 4f 4d 20 73 71 6c 69 74  ECT * FROM sqlit
2950: 65 5f 73 65 71 75 65 6e 63 65 0a 20 20 20 20 7d  e_sequence.    }
2960: 20 64 62 32 0a 20 20 7d 20 7b 74 34 20 31 20 74   db2.  } {t4 1 t
2970: 35 20 32 30 30 7d 0a 20 20 64 6f 5f 74 65 73 74  5 200}.  do_test
2980: 20 61 75 74 6f 69 6e 63 2d 35 2e 34 20 7b 0a 20   autoinc-5.4 {. 
2990: 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20     execsql {.   
29a0: 20 20 20 53 45 4c 45 43 54 20 31 2c 20 2a 20 46     SELECT 1, * F
29b0: 52 4f 4d 20 6d 61 69 6e 2e 73 71 6c 69 74 65 5f  ROM main.sqlite_
29c0: 73 65 71 75 65 6e 63 65 3b 0a 20 20 20 20 20 20  sequence;.      
29d0: 53 45 4c 45 43 54 20 32 2c 20 2a 20 46 52 4f 4d  SELECT 2, * FROM
29e0: 20 74 65 6d 70 2e 73 71 6c 69 74 65 5f 73 65 71   temp.sqlite_seq
29f0: 75 65 6e 63 65 3b 0a 20 20 20 20 20 20 53 45 4c  uence;.      SEL
2a00: 45 43 54 20 33 2c 20 2a 20 46 52 4f 4d 20 61 75  ECT 3, * FROM au
2a10: 78 2e 73 71 6c 69 74 65 5f 73 65 71 75 65 6e 63  x.sqlite_sequenc
2a20: 65 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 33 20  e;.    }.  } {3 
2a30: 74 34 20 31 20 33 20 74 35 20 32 30 30 7d 0a 7d  t4 1 3 t5 200}.}
2a40: 0a 0a 23 20 52 65 71 75 69 72 65 6d 65 6e 74 20  ..# Requirement 
2a50: 52 45 51 30 30 33 31 30 3a 20 20 4d 61 6b 65 20  REQ00310:  Make 
2a60: 73 75 72 65 20 61 6e 20 69 6e 73 65 72 74 20 66  sure an insert f
2a70: 61 69 6c 73 20 69 66 20 74 68 65 20 73 65 71 75  ails if the sequ
2a80: 65 6e 63 65 20 69 73 0a 23 20 61 6c 72 65 61 64  ence is.# alread
2a90: 79 20 61 74 20 69 74 73 20 6d 61 78 69 6d 75 6d  y at its maximum
2aa0: 20 76 61 6c 75 65 2e 0a 23 0a 69 66 63 61 70 61   value..#.ifcapa
2ab0: 62 6c 65 20 7b 72 6f 77 69 64 33 32 7d 20 7b 0a  ble {rowid32} {.
2ac0: 20 20 64 6f 5f 74 65 73 74 20 61 75 74 6f 69 6e    do_test autoin
2ad0: 63 2d 36 2e 31 20 7b 0a 20 20 20 20 65 78 65 63  c-6.1 {.    exec
2ae0: 73 71 6c 20 7b 0a 20 20 20 20 20 20 43 52 45 41  sql {.      CREA
2af0: 54 45 20 54 41 42 4c 45 20 74 36 28 76 20 49 4e  TE TABLE t6(v IN
2b00: 54 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b 45  TEGER PRIMARY KE
2b10: 59 20 41 55 54 4f 49 4e 43 52 45 4d 45 4e 54 2c  Y AUTOINCREMENT,
2b20: 20 77 29 3b 0a 20 20 20 20 20 20 49 4e 53 45 52   w);.      INSER
2b30: 54 20 49 4e 54 4f 20 74 36 20 56 41 4c 55 45 53  T INTO t6 VALUES
2b40: 28 32 31 34 37 34 38 33 36 34 37 2c 31 29 3b 0a  (2147483647,1);.
2b50: 20 20 20 20 20 20 53 45 4c 45 43 54 20 73 65 71        SELECT seq
2b60: 20 46 52 4f 4d 20 6d 61 69 6e 2e 73 71 6c 69 74   FROM main.sqlit
2b70: 65 5f 73 65 71 75 65 6e 63 65 20 57 48 45 52 45  e_sequence WHERE
2b80: 20 6e 61 6d 65 3d 27 74 36 27 3b 0a 20 20 20 20   name='t6';.    
2b90: 7d 0a 20 20 7d 20 32 31 34 37 34 38 33 36 34 37  }.  } 2147483647
2ba0: 0a 7d 0a 69 66 63 61 70 61 62 6c 65 20 7b 21 72  .}.ifcapable {!r
2bb0: 6f 77 69 64 33 32 7d 20 7b 0a 20 20 64 6f 5f 74  owid32} {.  do_t
2bc0: 65 73 74 20 61 75 74 6f 69 6e 63 2d 36 2e 31 20  est autoinc-6.1 
2bd0: 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a  {.    execsql {.
2be0: 20 20 20 20 20 20 43 52 45 41 54 45 20 54 41 42        CREATE TAB
2bf0: 4c 45 20 74 36 28 76 20 49 4e 54 45 47 45 52 20  LE t6(v INTEGER 
2c00: 50 52 49 4d 41 52 59 20 4b 45 59 20 41 55 54 4f  PRIMARY KEY AUTO
2c10: 49 4e 43 52 45 4d 45 4e 54 2c 20 77 29 3b 0a 20  INCREMENT, w);. 
2c20: 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f       INSERT INTO
2c30: 20 74 36 20 56 41 4c 55 45 53 28 39 32 32 33 33   t6 VALUES(92233
2c40: 37 32 30 33 36 38 35 34 37 37 35 38 30 37 2c 31  72036854775807,1
2c50: 29 3b 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20  );.      SELECT 
2c60: 73 65 71 20 46 52 4f 4d 20 6d 61 69 6e 2e 73 71  seq FROM main.sq
2c70: 6c 69 74 65 5f 73 65 71 75 65 6e 63 65 20 57 48  lite_sequence WH
2c80: 45 52 45 20 6e 61 6d 65 3d 27 74 36 27 3b 0a 20  ERE name='t6';. 
2c90: 20 20 20 7d 0a 20 20 7d 20 39 32 32 33 33 37 32     }.  } 9223372
2ca0: 30 33 36 38 35 34 37 37 35 38 30 37 0a 7d 0a 64  036854775807.}.d
2cb0: 6f 5f 74 65 73 74 20 61 75 74 6f 69 6e 63 2d 36  o_test autoinc-6
2cc0: 2e 32 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20  .2 {.  catchsql 
2cd0: 7b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  {.    INSERT INT
2ce0: 4f 20 74 36 20 56 41 4c 55 45 53 28 4e 55 4c 4c  O t6 VALUES(NULL
2cf0: 2c 31 29 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 64  ,1);.  }.} {1 {d
2d00: 61 74 61 62 61 73 65 20 69 73 20 66 75 6c 6c 7d  atabase is full}
2d10: 7d 0a 0a 23 20 41 6c 6c 6f 77 20 74 68 65 20 41  }..# Allow the A
2d20: 55 54 4f 49 4e 43 52 45 4d 45 4e 54 20 6b 65 79  UTOINCREMENT key
2d30: 77 6f 72 64 20 69 6e 73 69 64 65 20 74 68 65 20  word inside the 
2d40: 70 61 72 65 6e 74 68 65 73 65 73 0a 23 20 6f 6e  parentheses.# on
2d50: 20 61 20 73 65 70 61 72 61 74 65 20 50 52 49 4d   a separate PRIM
2d60: 41 52 59 20 4b 45 59 20 64 65 73 69 67 6e 61 74  ARY KEY designat
2d70: 69 6f 6e 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 61  ion..#.do_test a
2d80: 75 74 6f 69 6e 63 2d 37 2e 31 20 7b 0a 20 20 65  utoinc-7.1 {.  e
2d90: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45  xecsql {.    CRE
2da0: 41 54 45 20 54 41 42 4c 45 20 74 37 28 78 20 49  ATE TABLE t7(x I
2db0: 4e 54 45 47 45 52 2c 20 79 20 52 45 41 4c 2c 20  NTEGER, y REAL, 
2dc0: 50 52 49 4d 41 52 59 20 4b 45 59 28 78 20 41 55  PRIMARY KEY(x AU
2dd0: 54 4f 49 4e 43 52 45 4d 45 4e 54 29 29 3b 0a 20  TOINCREMENT));. 
2de0: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
2df0: 37 28 79 29 20 56 41 4c 55 45 53 28 31 32 33 29  7(y) VALUES(123)
2e00: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
2e10: 4f 20 74 37 28 79 29 20 56 41 4c 55 45 53 28 32  O t7(y) VALUES(2
2e20: 33 34 29 3b 0a 20 20 20 20 44 45 4c 45 54 45 20  34);.    DELETE 
2e30: 46 52 4f 4d 20 74 37 3b 0a 20 20 20 20 49 4e 53  FROM t7;.    INS
2e40: 45 52 54 20 49 4e 54 4f 20 74 37 28 79 29 20 56  ERT INTO t7(y) V
2e50: 41 4c 55 45 53 28 33 34 35 29 3b 0a 20 20 20 20  ALUES(345);.    
2e60: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 37  SELECT * FROM t7
2e70: 3b 0a 20 20 7d 0a 7d 20 7b 33 20 33 34 35 7d 0a  ;.  }.} {3 345}.
2e80: 0a 23 20 54 65 73 74 20 74 68 61 74 20 69 66 20  .# Test that if 
2e90: 74 68 65 20 41 55 54 4f 49 4e 43 52 45 4d 45 4e  the AUTOINCREMEN
2ea0: 54 20 69 73 20 61 70 70 6c 69 65 64 20 74 6f 20  T is applied to 
2eb0: 61 20 6e 6f 6e 20 69 6e 74 65 67 65 72 20 70 72  a non integer pr
2ec0: 69 6d 61 72 79 20 6b 65 79 0a 23 20 74 68 65 20  imary key.# the 
2ed0: 65 72 72 6f 72 20 6d 65 73 73 61 67 65 20 69 73  error message is
2ee0: 20 73 65 6e 73 69 62 6c 65 2e 0a 64 6f 5f 74 65   sensible..do_te
2ef0: 73 74 20 61 75 74 6f 69 6e 63 2d 37 2e 32 20 7b  st autoinc-7.2 {
2f00: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20  .  catchsql {.  
2f10: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74    CREATE TABLE t
2f20: 38 28 78 20 54 45 58 54 20 50 52 49 4d 41 52 59  8(x TEXT PRIMARY
2f30: 20 4b 45 59 20 41 55 54 4f 49 4e 43 52 45 4d 45   KEY AUTOINCREME
2f40: 4e 54 29 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 41  NT);.  }.} {1 {A
2f50: 55 54 4f 49 4e 43 52 45 4d 45 4e 54 20 69 73 20  UTOINCREMENT is 
2f60: 6f 6e 6c 79 20 61 6c 6c 6f 77 65 64 20 6f 6e 20  only allowed on 
2f70: 61 6e 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41  an INTEGER PRIMA
2f80: 52 59 20 4b 45 59 7d 7d 0a 0a 63 61 74 63 68 20  RY KEY}}..catch 
2f90: 7b 64 62 32 20 63 6c 6f 73 65 7d 0a 66 69 6e 69  {db2 close}.fini
2fa0: 73 68 5f 74 65 73 74 0a                          sh_test.