/ Hex Artifact Content
Login

Artifact a95ccace88291449f5eae7139ec438a42f90654d:


0000: 23 20 54 68 65 20 61 75 74 68 6f 72 20 64 69 73  # The author dis
0010: 63 6c 61 69 6d 73 20 63 6f 70 79 72 69 67 68 74  claims copyright
0020: 20 74 6f 20 74 68 69 73 20 73 6f 75 72 63 65 20   to this source 
0030: 63 6f 64 65 2e 20 20 49 6e 20 70 6c 61 63 65 20  code.  In place 
0040: 6f 66 0a 23 20 61 20 6c 65 67 61 6c 20 6e 6f 74  of.# a legal not
0050: 69 63 65 2c 20 68 65 72 65 20 69 73 20 61 20 62  ice, here is a b
0060: 6c 65 73 73 69 6e 67 3a 0a 23 0a 23 20 20 20 20  lessing:.#.#    
0070: 4d 61 79 20 79 6f 75 20 64 6f 20 67 6f 6f 64 20  May you do good 
0080: 61 6e 64 20 6e 6f 74 20 65 76 69 6c 2e 0a 23 20  and not evil..# 
0090: 20 20 20 4d 61 79 20 79 6f 75 20 66 69 6e 64 20     May you find 
00a0: 66 6f 72 67 69 76 65 6e 65 73 73 20 66 6f 72 20  forgiveness for 
00b0: 79 6f 75 72 73 65 6c 66 20 61 6e 64 20 66 6f 72  yourself and for
00c0: 67 69 76 65 20 6f 74 68 65 72 73 2e 0a 23 20 20  give others..#  
00d0: 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65 20    May you share 
00e0: 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74 61  freely, never ta
00f0: 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20 79  king more than y
0100: 6f 75 20 67 69 76 65 2e 0a 23 0a 23 2a 2a 2a 2a  ou give..#.#****
0110: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0120: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 0a 23 0a 23 20 54 68 69 73 20 66 69 6c  ***.#.# This fil
0160: 65 20 74 65 73 74 73 20 74 68 65 20 52 41 49 53  e tests the RAIS
0170: 45 28 29 20 66 75 6e 63 74 69 6f 6e 2e 0a 23 0a  E() function..#.
0180: 0a 73 65 74 20 74 65 73 74 64 69 72 20 5b 66 69  .set testdir [fi
0190: 6c 65 20 64 69 72 6e 61 6d 65 20 24 61 72 67 76  le dirname $argv
01a0: 30 5d 0a 73 6f 75 72 63 65 20 24 74 65 73 74 64  0].source $testd
01b0: 69 72 2f 74 65 73 74 65 72 2e 74 63 6c 0a 0a 23  ir/tester.tcl..#
01c0: 20 54 65 73 74 20 74 68 61 74 20 77 65 20 63 61   Test that we ca
01d0: 6e 20 63 61 75 73 65 20 52 4f 4c 4c 42 41 43 4b  n cause ROLLBACK
01e0: 2c 20 46 41 49 4c 20 61 6e 64 20 41 42 4f 52 54  , FAIL and ABORT
01f0: 20 63 6f 72 72 65 63 74 6c 79 0a 23 20 63 61 74   correctly.# cat
0200: 63 68 73 71 6c 20 7b 20 44 52 4f 50 20 54 41 42  chsql { DROP TAB
0210: 4c 45 20 74 62 6c 3b 20 7d 0a 63 61 74 63 68 73  LE tbl; }.catchs
0220: 71 6c 20 7b 20 43 52 45 41 54 45 20 54 41 42 4c  ql { CREATE TABL
0230: 45 20 74 62 6c 20 28 61 2c 20 62 2c 20 63 29 20  E tbl (a, b, c) 
0240: 7d 0a 0a 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  }..execsql {.   
0250: 20 43 52 45 41 54 45 20 54 52 49 47 47 45 52 20   CREATE TRIGGER 
0260: 62 65 66 6f 72 65 5f 74 62 6c 5f 69 6e 73 65 72  before_tbl_inser
0270: 74 20 42 45 46 4f 52 45 20 49 4e 53 45 52 54 20  t BEFORE INSERT 
0280: 4f 4e 20 74 62 6c 20 42 45 47 49 4e 20 53 45 4c  ON tbl BEGIN SEL
0290: 45 43 54 20 43 41 53 45 20 0a 09 57 48 45 4e 20  ECT CASE ..WHEN 
02a0: 28 6e 65 77 2e 61 20 3d 20 34 29 20 54 48 45 4e  (new.a = 4) THEN
02b0: 20 52 41 49 53 45 28 49 47 4e 4f 52 45 29 20 45   RAISE(IGNORE) E
02c0: 4e 44 3b 0a 20 20 20 20 45 4e 44 3b 0a 0a 20 20  ND;.    END;..  
02d0: 20 20 43 52 45 41 54 45 20 54 52 49 47 47 45 52    CREATE TRIGGER
02e0: 20 61 66 74 65 72 5f 74 62 6c 5f 69 6e 73 65 72   after_tbl_inser
02f0: 74 20 41 46 54 45 52 20 49 4e 53 45 52 54 20 4f  t AFTER INSERT O
0300: 4e 20 74 62 6c 20 42 45 47 49 4e 20 53 45 4c 45  N tbl BEGIN SELE
0310: 43 54 20 43 41 53 45 20 0a 09 57 48 45 4e 20 28  CT CASE ..WHEN (
0320: 6e 65 77 2e 61 20 3d 20 31 29 20 54 48 45 4e 20  new.a = 1) THEN 
0330: 52 41 49 53 45 28 41 42 4f 52 54 2c 20 20 20 20  RAISE(ABORT,    
0340: 27 54 72 69 67 67 65 72 20 61 62 6f 72 74 27 29  'Trigger abort')
0350: 20 0a 09 57 48 45 4e 20 28 6e 65 77 2e 61 20 3d   ..WHEN (new.a =
0360: 20 32 29 20 54 48 45 4e 20 52 41 49 53 45 28 46   2) THEN RAISE(F
0370: 41 49 4c 2c 20 20 20 20 20 27 54 72 69 67 67 65  AIL,     'Trigge
0380: 72 20 66 61 69 6c 27 29 20 0a 09 57 48 45 4e 20  r fail') ..WHEN 
0390: 28 6e 65 77 2e 61 20 3d 20 33 29 20 54 48 45 4e  (new.a = 3) THEN
03a0: 20 52 41 49 53 45 28 52 4f 4c 4c 42 41 43 4b 2c   RAISE(ROLLBACK,
03b0: 20 27 54 72 69 67 67 65 72 20 72 6f 6c 6c 62 61   'Trigger rollba
03c0: 63 6b 27 29 20 45 4e 44 3b 0a 20 20 20 20 45 4e  ck') END;.    EN
03d0: 44 3b 0a 7d 0a 23 20 41 42 4f 52 54 0a 64 6f 5f  D;.}.# ABORT.do_
03e0: 74 65 73 74 20 74 72 69 67 67 65 72 33 2d 31 2e  test trigger3-1.
03f0: 31 20 7b 0a 20 20 20 20 63 61 74 63 68 73 71 6c  1 {.    catchsql
0400: 20 7b 0a 09 42 45 47 49 4e 3b 0a 20 20 20 20 20   {..BEGIN;.     
0410: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
0420: 62 6c 20 56 41 4c 55 45 53 20 28 35 2c 20 35 2c  bl VALUES (5, 5,
0430: 20 36 29 3b 0a 20 20 20 20 20 20 20 20 49 4e 53   6);.        INS
0440: 45 52 54 20 49 4e 54 4f 20 74 62 6c 20 56 41 4c  ERT INTO tbl VAL
0450: 55 45 53 20 28 31 2c 20 35 2c 20 36 29 3b 0a 20  UES (1, 5, 6);. 
0460: 20 20 20 7d 0a 7d 20 7b 31 20 7b 54 72 69 67 67     }.} {1 {Trigg
0470: 65 72 20 61 62 6f 72 74 7d 7d 0a 64 6f 5f 74 65  er abort}}.do_te
0480: 73 74 20 74 72 69 67 67 65 72 33 2d 31 2e 32 20  st trigger3-1.2 
0490: 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a  {.    execsql {.
04a0: 09 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74  .SELECT * FROM t
04b0: 62 6c 3b 0a 09 52 4f 4c 4c 42 41 43 4b 3b 0a 20  bl;..ROLLBACK;. 
04c0: 20 20 20 7d 0a 7d 20 7b 35 20 35 20 36 7d 0a 64     }.} {5 5 6}.d
04d0: 6f 5f 74 65 73 74 20 74 72 69 67 67 65 72 33 2d  o_test trigger3-
04e0: 31 2e 33 20 7b 0a 20 20 20 20 65 78 65 63 73 71  1.3 {.    execsq
04f0: 6c 20 7b 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d  l {SELECT * FROM
0500: 20 74 62 6c 7d 0a 7d 20 7b 7d 0a 0a 23 20 46 41   tbl}.} {}..# FA
0510: 49 4c 0a 64 6f 5f 74 65 73 74 20 74 72 69 67 67  IL.do_test trigg
0520: 65 72 33 2d 32 2e 31 20 7b 0a 20 20 20 20 63 61  er3-2.1 {.    ca
0530: 74 63 68 73 71 6c 20 7b 0a 09 42 45 47 49 4e 3b  tchsql {..BEGIN;
0540: 0a 20 20 20 20 20 20 20 20 49 4e 53 45 52 54 20  .        INSERT 
0550: 49 4e 54 4f 20 74 62 6c 20 56 41 4c 55 45 53 20  INTO tbl VALUES 
0560: 28 35 2c 20 35 2c 20 36 29 3b 0a 20 20 20 20 20  (5, 5, 6);.     
0570: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
0580: 62 6c 20 56 41 4c 55 45 53 20 28 32 2c 20 35 2c  bl VALUES (2, 5,
0590: 20 36 29 3b 0a 20 20 20 20 7d 0a 7d 20 7b 31 20   6);.    }.} {1 
05a0: 7b 54 72 69 67 67 65 72 20 66 61 69 6c 7d 7d 0a  {Trigger fail}}.
05b0: 64 6f 5f 74 65 73 74 20 74 72 69 67 67 65 72 33  do_test trigger3
05c0: 2d 32 2e 32 20 7b 0a 20 20 20 20 65 78 65 63 73  -2.2 {.    execs
05d0: 71 6c 20 7b 0a 09 53 45 4c 45 43 54 20 2a 20 46  ql {..SELECT * F
05e0: 52 4f 4d 20 74 62 6c 3b 0a 09 52 4f 4c 4c 42 41  ROM tbl;..ROLLBA
05f0: 43 4b 3b 0a 20 20 20 20 7d 0a 7d 20 7b 35 20 35  CK;.    }.} {5 5
0600: 20 36 20 32 20 35 20 36 7d 0a 23 20 52 4f 4c 4c   6 2 5 6}.# ROLL
0610: 42 41 43 4b 0a 64 6f 5f 74 65 73 74 20 74 72 69  BACK.do_test tri
0620: 67 67 65 72 33 2d 33 2e 31 20 7b 0a 20 20 20 20  gger3-3.1 {.    
0630: 63 61 74 63 68 73 71 6c 20 7b 0a 09 42 45 47 49  catchsql {..BEGI
0640: 4e 3b 0a 20 20 20 20 20 20 20 20 49 4e 53 45 52  N;.        INSER
0650: 54 20 49 4e 54 4f 20 74 62 6c 20 56 41 4c 55 45  T INTO tbl VALUE
0660: 53 20 28 35 2c 20 35 2c 20 36 29 3b 0a 20 20 20  S (5, 5, 6);.   
0670: 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f       INSERT INTO
0680: 20 74 62 6c 20 56 41 4c 55 45 53 20 28 33 2c 20   tbl VALUES (3, 
0690: 35 2c 20 36 29 3b 0a 20 20 20 20 7d 0a 7d 20 7b  5, 6);.    }.} {
06a0: 31 20 7b 54 72 69 67 67 65 72 20 72 6f 6c 6c 62  1 {Trigger rollb
06b0: 61 63 6b 7d 7d 0a 64 6f 5f 74 65 73 74 20 74 72  ack}}.do_test tr
06c0: 69 67 67 65 72 33 2d 33 2e 32 20 7b 0a 20 20 20  igger3-3.2 {.   
06d0: 20 65 78 65 63 73 71 6c 20 7b 0a 09 53 45 4c 45   execsql {..SELE
06e0: 43 54 20 2a 20 46 52 4f 4d 20 74 62 6c 3b 0a 20  CT * FROM tbl;. 
06f0: 20 20 20 7d 0a 7d 20 7b 7d 0a 23 20 49 47 4e 4f     }.} {}.# IGNO
0700: 52 45 0a 64 6f 5f 74 65 73 74 20 74 72 69 67 67  RE.do_test trigg
0710: 65 72 33 2d 34 2e 31 20 7b 0a 20 20 20 20 63 61  er3-4.1 {.    ca
0720: 74 63 68 73 71 6c 20 7b 0a 09 42 45 47 49 4e 3b  tchsql {..BEGIN;
0730: 0a 20 20 20 20 20 20 20 20 49 4e 53 45 52 54 20  .        INSERT 
0740: 49 4e 54 4f 20 74 62 6c 20 56 41 4c 55 45 53 20  INTO tbl VALUES 
0750: 28 35 2c 20 35 2c 20 36 29 3b 0a 20 20 20 20 20  (5, 5, 6);.     
0760: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
0770: 62 6c 20 56 41 4c 55 45 53 20 28 34 2c 20 35 2c  bl VALUES (4, 5,
0780: 20 36 29 3b 0a 20 20 20 20 7d 0a 7d 20 7b 30 20   6);.    }.} {0 
0790: 7b 7d 7d 0a 64 6f 5f 74 65 73 74 20 74 72 69 67  {}}.do_test trig
07a0: 67 65 72 33 2d 34 2e 32 20 7b 0a 20 20 20 20 65  ger3-4.2 {.    e
07b0: 78 65 63 73 71 6c 20 7b 0a 09 53 45 4c 45 43 54  xecsql {..SELECT
07c0: 20 2a 20 46 52 4f 4d 20 74 62 6c 3b 0a 09 52 4f   * FROM tbl;..RO
07d0: 4c 4c 42 41 43 4b 3b 0a 20 20 20 20 7d 0a 7d 20  LLBACK;.    }.} 
07e0: 7b 35 20 35 20 36 7d 0a 0a 23 20 43 68 65 63 6b  {5 5 6}..# Check
07f0: 20 74 68 61 74 20 77 65 20 63 61 6e 20 61 6c 73   that we can als
0800: 6f 20 64 6f 20 52 41 49 53 45 28 49 47 4e 4f 52  o do RAISE(IGNOR
0810: 45 29 20 66 6f 72 20 55 50 44 41 54 45 20 61 6e  E) for UPDATE an
0820: 64 20 44 45 4c 45 54 45 0a 65 78 65 63 73 71 6c  d DELETE.execsql
0830: 20 7b 44 52 4f 50 20 54 41 42 4c 45 20 74 62 6c   {DROP TABLE tbl
0840: 3b 7d 0a 65 78 65 63 73 71 6c 20 7b 43 52 45 41  ;}.execsql {CREA
0850: 54 45 20 54 41 42 4c 45 20 74 62 6c 20 28 61 2c  TE TABLE tbl (a,
0860: 20 62 2c 20 63 29 3b 7d 0a 65 78 65 63 73 71 6c   b, c);}.execsql
0870: 20 7b 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 62   {INSERT INTO tb
0880: 6c 20 56 41 4c 55 45 53 28 31 2c 20 32 2c 20 33  l VALUES(1, 2, 3
0890: 29 3b 7d 0a 65 78 65 63 73 71 6c 20 7b 49 4e 53  );}.execsql {INS
08a0: 45 52 54 20 49 4e 54 4f 20 74 62 6c 20 56 41 4c  ERT INTO tbl VAL
08b0: 55 45 53 28 34 2c 20 35 2c 20 36 29 3b 7d 0a 65  UES(4, 5, 6);}.e
08c0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45  xecsql {.    CRE
08d0: 41 54 45 20 54 52 49 47 47 45 52 20 62 65 66 6f  ATE TRIGGER befo
08e0: 72 65 5f 74 62 6c 5f 75 70 64 61 74 65 20 42 45  re_tbl_update BE
08f0: 46 4f 52 45 20 55 50 44 41 54 45 20 4f 4e 20 74  FORE UPDATE ON t
0900: 62 6c 20 42 45 47 49 4e 0a 09 53 45 4c 45 43 54  bl BEGIN..SELECT
0910: 20 43 41 53 45 20 57 48 45 4e 20 28 6f 6c 64 2e   CASE WHEN (old.
0920: 61 20 3d 20 31 29 20 54 48 45 4e 20 52 41 49 53  a = 1) THEN RAIS
0930: 45 28 49 47 4e 4f 52 45 29 20 45 4e 44 3b 0a 20  E(IGNORE) END;. 
0940: 20 20 20 45 4e 44 3b 0a 0a 20 20 20 20 43 52 45     END;..    CRE
0950: 41 54 45 20 54 52 49 47 47 45 52 20 62 65 66 6f  ATE TRIGGER befo
0960: 72 65 5f 74 62 6c 5f 64 65 6c 65 74 65 20 42 45  re_tbl_delete BE
0970: 46 4f 52 45 20 44 45 4c 45 54 45 20 4f 4e 20 74  FORE DELETE ON t
0980: 62 6c 20 42 45 47 49 4e 0a 09 53 45 4c 45 43 54  bl BEGIN..SELECT
0990: 20 43 41 53 45 20 57 48 45 4e 20 28 6f 6c 64 2e   CASE WHEN (old.
09a0: 61 20 3d 20 31 29 20 54 48 45 4e 20 52 41 49 53  a = 1) THEN RAIS
09b0: 45 28 49 47 4e 4f 52 45 29 20 45 4e 44 3b 0a 20  E(IGNORE) END;. 
09c0: 20 20 20 45 4e 44 3b 0a 7d 0a 64 6f 5f 74 65 73     END;.}.do_tes
09d0: 74 20 74 72 69 67 67 65 72 33 2d 35 2e 31 20 7b  t trigger3-5.1 {
09e0: 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 09  .    execsql {..
09f0: 55 50 44 41 54 45 20 74 62 6c 20 53 45 54 20 63  UPDATE tbl SET c
0a00: 20 3d 20 31 30 3b 0a 09 53 45 4c 45 43 54 20 2a   = 10;..SELECT *
0a10: 20 46 52 4f 4d 20 74 62 6c 3b 0a 20 20 20 20 7d   FROM tbl;.    }
0a20: 0a 7d 20 7b 31 20 32 20 33 20 34 20 35 20 31 30  .} {1 2 3 4 5 10
0a30: 7d 0a 64 6f 5f 74 65 73 74 20 74 72 69 67 67 65  }.do_test trigge
0a40: 72 33 2d 35 2e 32 20 7b 0a 20 20 20 20 65 78 65  r3-5.2 {.    exe
0a50: 63 73 71 6c 20 7b 0a 09 44 45 4c 45 54 45 20 46  csql {..DELETE F
0a60: 52 4f 4d 20 74 62 6c 3b 0a 09 53 45 4c 45 43 54  ROM tbl;..SELECT
0a70: 20 2a 20 46 52 4f 4d 20 74 62 6c 3b 0a 20 20 20   * FROM tbl;.   
0a80: 20 7d 0a 7d 20 7b 31 20 32 20 33 7d 0a 0a 23 20   }.} {1 2 3}..# 
0a90: 43 68 65 63 6b 20 74 68 61 74 20 52 41 49 53 45  Check that RAISE
0aa0: 28 49 47 4e 4f 52 45 29 20 77 6f 72 6b 73 20 63  (IGNORE) works c
0ab0: 6f 72 72 65 63 74 6c 79 20 66 6f 72 20 6e 65 73  orrectly for nes
0ac0: 74 65 64 20 74 72 69 67 67 65 72 73 3a 0a 65 78  ted triggers:.ex
0ad0: 65 63 73 71 6c 20 7b 43 52 45 41 54 45 20 54 41  ecsql {CREATE TA
0ae0: 42 4c 45 20 74 62 6c 32 28 61 2c 20 62 2c 20 63  BLE tbl2(a, b, c
0af0: 29 7d 0a 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  )}.execsql {.   
0b00: 20 43 52 45 41 54 45 20 54 52 49 47 47 45 52 20   CREATE TRIGGER 
0b10: 61 66 74 65 72 5f 74 62 6c 32 5f 69 6e 73 65 72  after_tbl2_inser
0b20: 74 20 41 46 54 45 52 20 49 4e 53 45 52 54 20 4f  t AFTER INSERT O
0b30: 4e 20 74 62 6c 32 20 42 45 47 49 4e 0a 09 55 50  N tbl2 BEGIN..UP
0b40: 44 41 54 45 20 74 62 6c 20 53 45 54 20 63 20 3d  DATE tbl SET c =
0b50: 20 31 30 3b 0a 20 20 20 20 20 20 20 20 49 4e 53   10;.        INS
0b60: 45 52 54 20 49 4e 54 4f 20 74 62 6c 32 20 56 41  ERT INTO tbl2 VA
0b70: 4c 55 45 53 20 28 6e 65 77 2e 61 2c 20 6e 65 77  LUES (new.a, new
0b80: 2e 62 2c 20 6e 65 77 2e 63 29 3b 0a 20 20 20 20  .b, new.c);.    
0b90: 45 4e 44 3b 0a 7d 0a 64 6f 5f 74 65 73 74 20 74  END;.}.do_test t
0ba0: 72 69 67 67 65 72 33 2d 36 20 7b 0a 20 20 20 20  rigger3-6 {.    
0bb0: 65 78 65 63 73 71 6c 20 7b 0a 09 49 4e 53 45 52  execsql {..INSER
0bc0: 54 20 49 4e 54 4f 20 74 62 6c 32 20 56 41 4c 55  T INTO tbl2 VALU
0bd0: 45 53 20 28 31 2c 20 32 2c 20 33 29 3b 0a 09 53  ES (1, 2, 3);..S
0be0: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 62 6c  ELECT * FROM tbl
0bf0: 32 3b 0a 09 53 45 4c 45 43 54 20 2a 20 46 52 4f  2;..SELECT * FRO
0c00: 4d 20 74 62 6c 3b 0a 20 20 20 20 7d 0a 7d 20 7b  M tbl;.    }.} {
0c10: 31 20 32 20 33 20 31 20 32 20 33 20 31 20 32 20  1 2 3 1 2 3 1 2 
0c20: 33 7d 0a 0a 23 20 43 68 65 63 6b 20 74 68 61 74  3}..# Check that
0c30: 20 74 68 69 6e 67 73 20 61 6c 73 6f 20 77 6f 72   things also wor
0c40: 6b 20 66 6f 72 20 76 69 65 77 2d 74 72 69 67 67  k for view-trigg
0c50: 65 72 73 0a 65 78 65 63 73 71 6c 20 7b 43 52 45  ers.execsql {CRE
0c60: 41 54 45 20 56 49 45 57 20 74 62 6c 5f 76 69 65  ATE VIEW tbl_vie
0c70: 77 20 41 53 20 53 45 4c 45 43 54 20 2a 20 46 52  w AS SELECT * FR
0c80: 4f 4d 20 74 62 6c 7d 0a 65 78 65 63 73 71 6c 20  OM tbl}.execsql 
0c90: 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 52 49  {.    CREATE TRI
0ca0: 47 47 45 52 20 74 62 6c 5f 76 69 65 77 5f 69 6e  GGER tbl_view_in
0cb0: 73 65 72 74 20 49 4e 53 54 45 41 44 20 4f 46 20  sert INSTEAD OF 
0cc0: 49 4e 53 45 52 54 20 4f 4e 20 74 62 6c 5f 76 69  INSERT ON tbl_vi
0cd0: 65 77 20 42 45 47 49 4e 0a 09 53 45 4c 45 43 54  ew BEGIN..SELECT
0ce0: 20 43 41 53 45 20 57 48 45 4e 20 28 6e 65 77 2e   CASE WHEN (new.
0cf0: 61 20 3d 20 31 29 20 54 48 45 4e 20 52 41 49 53  a = 1) THEN RAIS
0d00: 45 28 52 4f 4c 4c 42 41 43 4b 2c 20 27 56 69 65  E(ROLLBACK, 'Vie
0d10: 77 20 72 6f 6c 6c 62 61 63 6b 27 29 0a 09 20 20  w rollback')..  
0d20: 20 20 20 20 20 20 20 20 20 20 57 48 45 4e 20 28            WHEN (
0d30: 6e 65 77 2e 61 20 3d 20 32 29 20 54 48 45 4e 20  new.a = 2) THEN 
0d40: 52 41 49 53 45 28 49 47 4e 4f 52 45 29 20 0a 09  RAISE(IGNORE) ..
0d50: 20 20 20 20 20 20 20 20 20 20 20 20 57 48 45 4e              WHEN
0d60: 20 28 6e 65 77 2e 61 20 3d 20 33 29 20 54 48 45   (new.a = 3) THE
0d70: 4e 20 52 41 49 53 45 28 41 42 4f 52 54 2c 20 27  N RAISE(ABORT, '
0d80: 56 69 65 77 20 61 62 6f 72 74 27 29 20 45 4e 44  View abort') END
0d90: 3b 0a 20 20 20 20 45 4e 44 3b 0a 7d 0a 0a 64 6f  ;.    END;.}..do
0da0: 5f 74 65 73 74 20 74 72 69 67 67 65 72 33 2d 37  _test trigger3-7
0db0: 2e 31 20 7b 0a 20 20 20 20 63 61 74 63 68 73 71  .1 {.    catchsq
0dc0: 6c 20 7b 0a 09 49 4e 53 45 52 54 20 49 4e 54 4f  l {..INSERT INTO
0dd0: 20 74 62 6c 5f 76 69 65 77 20 56 41 4c 55 45 53   tbl_view VALUES
0de0: 28 31 2c 20 32 2c 20 33 29 3b 0a 20 20 20 20 7d  (1, 2, 3);.    }
0df0: 0a 7d 20 7b 31 20 7b 56 69 65 77 20 72 6f 6c 6c  .} {1 {View roll
0e00: 62 61 63 6b 7d 7d 0a 64 6f 5f 74 65 73 74 20 74  back}}.do_test t
0e10: 72 69 67 67 65 72 33 2d 37 2e 32 20 7b 0a 20 20  rigger3-7.2 {.  
0e20: 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 09 49 4e    catchsql {..IN
0e30: 53 45 52 54 20 49 4e 54 4f 20 74 62 6c 5f 76 69  SERT INTO tbl_vi
0e40: 65 77 20 56 41 4c 55 45 53 28 32 2c 20 32 2c 20  ew VALUES(2, 2, 
0e50: 33 29 3b 0a 20 20 20 20 7d 0a 7d 20 7b 30 20 7b  3);.    }.} {0 {
0e60: 7d 7d 0a 64 6f 5f 74 65 73 74 20 74 72 69 67 67  }}.do_test trigg
0e70: 65 72 33 2d 37 2e 33 20 7b 0a 20 20 20 20 63 61  er3-7.3 {.    ca
0e80: 74 63 68 73 71 6c 20 7b 0a 09 49 4e 53 45 52 54  tchsql {..INSERT
0e90: 20 49 4e 54 4f 20 74 62 6c 5f 76 69 65 77 20 56   INTO tbl_view V
0ea0: 41 4c 55 45 53 28 33 2c 20 32 2c 20 33 29 3b 0a  ALUES(3, 2, 3);.
0eb0: 20 20 20 20 7d 0a 7d 20 7b 31 20 7b 56 69 65 77      }.} {1 {View
0ec0: 20 61 62 6f 72 74 7d 7d 0a 0a 69 6e 74 65 67 72   abort}}..integr
0ed0: 69 74 79 5f 63 68 65 63 6b 20 74 72 69 67 67 65  ity_check trigge
0ee0: 72 33 2d 38 2e 31 0a 0a 63 61 74 63 68 73 71 6c  r3-8.1..catchsql
0ef0: 20 7b 20 44 52 4f 50 20 54 41 42 4c 45 20 74 62   { DROP TABLE tb
0f00: 6c 3b 20 7d 20 0a 63 61 74 63 68 73 71 6c 20 7b  l; } .catchsql {
0f10: 20 44 52 4f 50 20 54 41 42 4c 45 20 74 62 6c 32   DROP TABLE tbl2
0f20: 3b 20 7d 20 0a 63 61 74 63 68 73 71 6c 20 7b 20  ; } .catchsql { 
0f30: 44 52 4f 50 20 56 49 45 57 20 74 62 6c 5f 76 69  DROP VIEW tbl_vi
0f40: 65 77 3b 20 7d 0a 0a 66 69 6e 69 73 68 5f 74 65  ew; }..finish_te
0f50: 73 74 0a                                         st.