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

Artifact 7a6d6598e6a6a09bf54a02e0aff0f29e407d9f11:


0000: 23 0a 23 20 52 75 6e 20 74 68 69 73 20 73 63 72  #.# Run this scr
0010: 69 70 74 20 74 6f 20 67 65 6e 65 72 61 74 65 64  ipt to generated
0020: 20 61 20 6f 6d 69 74 74 65 64 2e 68 74 6d 6c 20   a omitted.html 
0030: 6f 75 74 70 75 74 20 66 69 6c 65 0a 23 0a 73 65  output file.#.se
0040: 74 20 72 63 73 69 64 20 7b 24 49 64 3a 20 6f 6d  t rcsid {$Id: om
0050: 69 74 74 65 64 2e 74 63 6c 2c 76 20 31 2e 31 20  itted.tcl,v 1.1 
0060: 32 30 30 32 2f 30 38 2f 31 34 20 30 30 3a 30 38  2002/08/14 00:08
0070: 3a 31 34 20 64 72 68 20 45 78 70 20 24 7d 0a 0a  :14 drh Exp $}..
0080: 70 75 74 73 20 7b 3c 68 74 6d 6c 3e 0a 3c 68 65  puts {<html>.<he
0090: 61 64 3e 0a 20 20 3c 74 69 74 6c 65 3e 53 51 4c  ad>.  <title>SQL
00a0: 20 46 65 61 74 75 72 65 73 20 54 68 61 74 20 53   Features That S
00b0: 51 4c 69 74 65 20 44 6f 65 73 20 4e 6f 74 20 49  QLite Does Not I
00c0: 6d 70 6c 65 6d 65 6e 74 3c 2f 74 69 74 6c 65 3e  mplement</title>
00d0: 0a 3c 2f 68 65 61 64 3e 0a 3c 62 6f 64 79 20 62  .</head>.<body b
00e0: 67 63 6f 6c 6f 72 3d 22 77 68 69 74 65 22 3e 0a  gcolor="white">.
00f0: 3c 68 31 20 61 6c 69 67 6e 3d 22 63 65 6e 74 65  <h1 align="cente
0100: 72 22 3e 0a 53 51 4c 20 46 65 61 74 75 72 65 73  r">.SQL Features
0110: 20 54 68 61 74 20 53 51 4c 69 74 65 20 44 6f 65   That SQLite Doe
0120: 73 20 4e 6f 74 20 49 6d 70 6c 65 6d 65 6e 74 0a  s Not Implement.
0130: 3c 2f 68 31 3e 0a 7d 0a 70 75 74 73 20 22 3c 70  </h1>.}.puts "<p
0140: 20 61 6c 69 67 6e 3d 63 65 6e 74 65 72 3e 0a 28   align=center>.(
0150: 54 68 69 73 20 70 61 67 65 20 77 61 73 20 6c 61  This page was la
0160: 73 74 20 6d 6f 64 69 66 69 65 64 20 6f 6e 20 5b  st modified on [
0170: 6c 72 61 6e 67 65 20 24 72 63 73 69 64 20 33 20  lrange $rcsid 3 
0180: 34 5d 20 55 54 43 29 0a 3c 2f 70 3e 22 0a 0a 70  4] UTC).</p>"..p
0190: 75 74 73 20 7b 0a 3c 70 3e 0a 52 61 74 68 65 72  uts {.<p>.Rather
01a0: 20 74 68 61 6e 20 74 72 79 20 74 6f 20 6c 69 73   than try to lis
01b0: 74 20 61 6c 6c 20 74 68 65 20 66 65 61 74 75 72  t all the featur
01c0: 65 73 20 6f 66 20 53 51 4c 39 32 20 74 68 61 74  es of SQL92 that
01d0: 20 53 51 4c 69 74 65 20 64 6f 65 73 0a 73 75 70   SQLite does.sup
01e0: 70 6f 72 74 2c 20 69 74 20 69 73 20 6d 75 63 68  port, it is much
01f0: 20 65 61 73 69 65 72 20 74 6f 20 6c 69 73 74 20   easier to list 
0200: 74 68 6f 73 65 20 74 68 61 74 20 69 74 20 64 6f  those that it do
0210: 65 73 20 6e 6f 74 2e 0a 54 68 65 20 66 6f 6c 6c  es not..The foll
0220: 6f 77 69 6e 67 20 61 72 65 20 66 65 61 74 75 72  owing are featur
0230: 65 73 20 6f 66 20 6f 66 20 53 51 4c 39 32 20 74  es of of SQL92 t
0240: 68 61 74 20 53 51 4c 69 74 65 20 64 6f 65 73 20  hat SQLite does 
0250: 6e 6f 74 20 69 6d 70 6c 65 6d 65 6e 74 2e 0a 3c  not implement..<
0260: 2f 70 3e 0a 0a 3c 74 61 62 6c 65 20 63 65 6c 6c  /p>..<table cell
0270: 70 61 64 64 69 6e 67 3d 22 31 30 22 3e 0a 7d 0a  padding="10">.}.
0280: 0a 70 72 6f 63 20 66 65 61 74 75 72 65 20 7b 6e  .proc feature {n
0290: 61 6d 65 20 64 65 73 63 7d 20 7b 0a 20 20 70 75  ame desc} {.  pu
02a0: 74 73 20 22 3c 74 72 3e 3c 74 64 20 76 61 6c 69  ts "<tr><td vali
02b0: 67 6e 3d 5c 22 74 6f 70 5c 22 3e 3c 62 3e 3c 6e  gn=\"top\"><b><n
02c0: 6f 62 72 3e 24 6e 61 6d 65 3c 2f 6e 6f 62 72 3e  obr>$name</nobr>
02d0: 3c 2f 62 3e 3c 2f 74 64 3e 22 0a 20 20 70 75 74  </b></td>".  put
02e0: 73 20 22 3c 74 64 20 76 61 6c 69 67 6e 3d 5c 22  s "<td valign=\"
02f0: 74 6f 70 5c 22 3e 24 64 65 73 63 3c 2f 74 64 3e  top\">$desc</td>
0300: 3c 2f 74 72 3e 22 0a 7d 0a 0a 66 65 61 74 75 72  </tr>".}..featur
0310: 65 20 7b 52 49 47 48 54 20 61 6e 64 20 46 55 4c  e {RIGHT and FUL
0320: 4c 20 4f 55 54 45 52 20 4a 4f 49 4e 7d 20 7b 0a  L OUTER JOIN} {.
0330: 20 20 4c 45 46 54 20 4f 55 54 45 52 20 4a 4f 49    LEFT OUTER JOI
0340: 4e 20 69 73 20 69 6d 70 6c 65 6d 65 6e 74 65 64  N is implemented
0350: 2c 20 62 75 74 20 6e 6f 74 20 52 49 47 48 54 20  , but not RIGHT 
0360: 4f 55 54 45 52 20 4a 4f 49 4e 20 6f 72 0a 20 20  OUTER JOIN or.  
0370: 46 55 4c 4c 20 4f 55 54 45 52 20 4a 4f 49 4e 2e  FULL OUTER JOIN.
0380: 0a 7d 0a 0a 66 65 61 74 75 72 65 20 7b 43 48 45  .}..feature {CHE
0390: 43 4b 20 63 6f 6e 73 74 72 61 69 6e 74 73 7d 20  CK constraints} 
03a0: 7b 0a 20 20 43 48 45 43 4b 20 63 6f 6e 73 74 72  {.  CHECK constr
03b0: 61 69 6e 74 73 20 61 72 65 20 70 61 72 73 65 64  aints are parsed
03c0: 20 62 75 74 20 74 68 65 79 20 61 72 65 20 6e 6f   but they are no
03d0: 74 20 65 6e 66 6f 72 63 65 64 2e 0a 20 20 4e 4f  t enforced..  NO
03e0: 54 20 4e 55 4c 4c 20 61 6e 64 20 55 4e 49 51 55  T NULL and UNIQU
03f0: 45 20 63 6f 6e 73 74 72 61 69 6e 74 73 20 61 72  E constraints ar
0400: 65 20 65 6e 66 6f 72 63 65 64 2c 20 68 6f 77 65  e enforced, howe
0410: 76 65 72 2e 0a 7d 0a 0a 66 65 61 74 75 72 65 20  ver..}..feature 
0420: 7b 46 4f 52 45 49 47 4e 20 4b 45 59 20 63 6f 6e  {FOREIGN KEY con
0430: 73 74 72 61 69 6e 74 73 7d 20 7b 0a 20 20 46 4f  straints} {.  FO
0440: 52 45 49 47 4e 20 4b 45 59 20 63 6f 6e 73 74 72  REIGN KEY constr
0450: 61 69 6e 74 73 20 61 72 65 20 70 61 72 73 65 64  aints are parsed
0460: 20 62 75 74 20 61 72 65 20 69 67 6e 6f 72 65 64   but are ignored
0470: 2e 0a 7d 0a 0a 66 65 61 74 75 72 65 20 7b 47 52  ..}..feature {GR
0480: 41 4e 54 20 61 6e 64 20 52 45 56 4f 4b 45 7d 20  ANT and REVOKE} 
0490: 7b 0a 20 20 53 69 6e 63 65 20 53 51 4c 69 74 65  {.  Since SQLite
04a0: 20 72 65 61 64 73 20 61 6e 64 20 77 72 69 74 65   reads and write
04b0: 73 20 61 6e 20 6f 72 64 69 6e 61 72 79 20 64 69  s an ordinary di
04c0: 73 6b 20 66 69 6c 65 2c 20 74 68 65 0a 20 20 6f  sk file, the.  o
04d0: 6e 6c 79 20 61 63 63 65 73 73 20 70 65 72 6d 69  nly access permi
04e0: 73 73 69 6f 6e 73 20 74 68 61 74 20 63 61 6e 20  ssions that can 
04f0: 62 65 20 61 70 70 6c 69 65 64 20 61 72 65 20 74  be applied are t
0500: 68 65 20 6e 6f 72 6d 61 6c 0a 20 20 66 69 6c 65  he normal.  file
0510: 20 61 63 63 65 73 73 20 70 65 72 6d 69 73 73 69   access permissi
0520: 6f 6e 73 20 6f 66 20 74 68 65 20 75 6e 64 65 72  ons of the under
0530: 6c 79 69 6e 67 20 6f 70 65 72 61 74 69 6e 67 20  lying operating 
0540: 73 79 73 74 65 6d 2e 0a 20 20 54 68 65 20 47 52  system..  The GR
0550: 41 4e 54 20 61 6e 64 20 52 45 56 4f 4b 45 20 63  ANT and REVOKE c
0560: 6f 6d 6d 61 6e 64 73 20 63 6f 6d 6d 6f 6e 6c 79  ommands commonly
0570: 20 66 6f 75 6e 64 20 6f 6e 20 63 6c 69 65 6e 74   found on client
0580: 2f 73 65 72 76 65 72 0a 20 20 52 44 42 4d 53 65  /server.  RDBMSe
0590: 73 20 61 72 65 20 6e 6f 74 20 69 6d 70 6c 65 6d  s are not implem
05a0: 65 6e 74 65 64 20 62 65 63 61 75 73 65 20 74 68  ented because th
05b0: 65 79 20 77 6f 75 6c 64 20 62 65 20 6d 65 61 6e  ey would be mean
05c0: 69 6e 67 6c 65 73 73 0a 20 20 66 6f 72 20 61 6e  ingless.  for an
05d0: 20 65 6d 62 65 64 64 65 64 20 64 61 74 61 62 61   embedded databa
05e0: 73 65 20 65 6e 67 69 6e 65 2e 0a 7d 0a 0a 66 65  se engine..}..fe
05f0: 61 74 75 72 65 20 7b 44 45 4c 45 54 45 2c 20 49  ature {DELETE, I
0600: 4e 53 45 52 54 2c 20 61 6e 64 20 55 50 44 41 54  NSERT, and UPDAT
0610: 45 20 6f 6e 20 56 49 45 57 73 7d 20 7b 0a 20 20  E on VIEWs} {.  
0620: 56 49 45 57 73 20 69 6e 20 53 51 4c 69 74 65 20  VIEWs in SQLite 
0630: 61 72 65 20 72 65 61 64 2d 6f 6e 6c 79 2e 20 20  are read-only.  
0640: 42 75 74 20 79 6f 75 20 63 61 6e 20 63 72 65 61  But you can crea
0650: 74 65 20 61 20 74 72 69 67 67 65 72 0a 20 20 74  te a trigger.  t
0660: 68 61 74 20 66 69 72 65 73 20 6f 6e 20 61 6e 20  hat fires on an 
0670: 61 74 74 65 6d 70 74 20 74 6f 20 44 45 4c 45 54  attempt to DELET
0680: 45 2c 20 49 4e 53 45 52 54 2c 20 6f 72 20 55 50  E, INSERT, or UP
0690: 44 41 54 45 20 61 20 76 69 65 77 20 61 6e 64 20  DATE a view and 
06a0: 64 6f 0a 20 20 77 68 61 74 20 79 6f 75 20 6e 65  do.  what you ne
06b0: 65 64 20 69 6e 20 74 68 65 20 62 6f 64 79 20 6f  ed in the body o
06c0: 66 20 74 68 65 20 74 72 69 67 67 65 72 2e 0a 7d  f the trigger..}
06d0: 0a 0a 66 65 61 74 75 72 65 20 7b 41 4c 54 45 52  ..feature {ALTER
06e0: 20 54 41 42 4c 45 7d 20 7b 0a 20 20 54 6f 20 63   TABLE} {.  To c
06f0: 68 61 6e 67 65 20 61 20 74 61 62 6c 65 20 79 6f  hange a table yo
0700: 75 20 68 61 76 65 20 74 6f 20 64 65 6c 65 74 65  u have to delete
0710: 20 69 74 20 28 73 61 76 69 6e 67 20 69 74 73 20   it (saving its 
0720: 63 6f 6e 74 65 6e 74 73 20 74 6f 20 61 20 74 65  contents to a te
0730: 6d 70 6f 72 61 72 79 0a 20 20 74 61 62 6c 65 29  mporary.  table)
0740: 20 61 6e 64 20 72 65 63 72 65 61 74 65 20 69 74   and recreate it
0750: 20 66 72 6f 6d 20 73 63 72 61 74 63 68 2e 0a 7d   from scratch..}
0760: 0a 0a 66 65 61 74 75 72 65 20 7b 54 68 65 20 43  ..feature {The C
0770: 4f 55 4e 54 28 44 49 53 54 49 4e 43 54 20 58 29  OUNT(DISTINCT X)
0780: 20 66 75 6e 63 74 69 6f 6e 7d 20 7b 0a 20 20 59   function} {.  Y
0790: 6f 75 20 63 61 6e 20 61 63 63 6f 6d 70 6c 69 73  ou can accomplis
07a0: 68 20 74 68 65 20 73 61 6d 65 20 74 68 69 6e 67  h the same thing
07b0: 20 75 73 69 6e 67 20 61 20 73 75 62 71 75 65 72   using a subquer
07c0: 79 2c 20 6c 69 6b 65 20 74 68 69 73 3a 3c 62 72  y, like this:<br
07d0: 20 2f 3e 0a 20 20 26 6e 62 73 70 3b 26 6e 62 73   />.  &nbsp;&nbs
07e0: 70 3b 53 45 4c 45 43 54 20 63 6f 75 6e 74 28 78  p;SELECT count(x
07f0: 29 20 46 52 4f 4d 20 28 53 45 4c 45 43 54 20 44  ) FROM (SELECT D
0800: 49 53 54 49 4e 43 54 20 78 20 46 52 4f 4d 20 74  ISTINCT x FROM t
0810: 62 6c 29 3b 0a 7d 0a 0a 66 65 61 74 75 72 65 20  bl);.}..feature 
0820: 7b 56 61 72 69 61 62 6c 65 20 73 75 62 71 75 65  {Variable subque
0830: 72 69 65 73 7d 20 7b 0a 20 20 53 75 62 71 75 65  ries} {.  Subque
0840: 72 69 65 73 20 6d 75 73 74 20 62 65 20 73 74 61  ries must be sta
0850: 74 69 63 2e 20 20 54 68 65 79 20 61 72 65 20 65  tic.  They are e
0860: 76 61 6c 75 61 74 65 64 20 6f 6e 6c 79 20 6f 6e  valuated only on
0870: 63 65 2e 20 20 54 68 65 79 20 6d 75 73 74 20 6e  ce.  They must n
0880: 6f 74 2c 0a 20 20 74 68 65 72 65 66 6f 72 65 2c  ot,.  therefore,
0890: 20 72 65 66 65 72 20 74 6f 20 76 61 72 69 61 62   refer to variab
08a0: 6c 65 73 20 69 6e 20 74 68 65 20 63 6f 6e 74 61  les in the conta
08b0: 69 6e 69 6e 67 20 71 75 65 72 79 2e 0a 7d 0a 0a  ining query..}..
08c0: 70 75 74 73 20 7b 0a 3c 2f 74 61 62 6c 65 3e 0a  puts {.</table>.
08d0: 0a 3c 70 3e 0a 49 66 20 79 6f 75 20 66 69 6e 64  .<p>.If you find
08e0: 20 6f 74 68 65 72 20 53 51 4c 39 32 20 66 65 61   other SQL92 fea
08f0: 74 75 72 65 73 20 74 68 61 74 20 53 51 4c 69 74  tures that SQLit
0900: 65 20 64 6f 65 73 20 6e 6f 74 20 73 75 70 70 6f  e does not suppo
0910: 72 74 2c 20 70 6c 65 61 73 65 0a 73 65 6e 64 20  rt, please.send 
0920: 65 2d 6d 61 69 6c 20 74 6f 20 3c 61 20 68 72 65  e-mail to <a hre
0930: 66 3d 22 6d 61 69 6c 74 6f 3a 64 72 68 40 68 77  f="mailto:drh@hw
0940: 61 63 69 2e 63 6f 6d 22 3e 64 72 68 40 68 77 61  aci.com">drh@hwa
0950: 63 69 2e 63 6f 6d 3c 2f 61 3e 20 73 6f 20 74 68  ci.com</a> so th
0960: 65 79 0a 63 61 6e 20 62 65 20 61 64 64 65 64 20  ey.can be added 
0970: 74 6f 20 74 68 69 73 20 6c 69 73 74 2e 0a 3c 2f  to this list..</
0980: 70 3e 0a 3c 70 3e 3c 68 72 20 2f 3e 3c 2f 70 3e  p>.<p><hr /></p>
0990: 0a 3c 70 3e 3c 61 20 68 72 65 66 3d 22 69 6e 64  .<p><a href="ind
09a0: 65 78 2e 68 74 6d 6c 22 3e 3c 69 6d 67 20 73 72  ex.html"><img sr
09b0: 63 3d 22 2f 67 6f 62 61 63 6b 2e 6a 70 67 22 20  c="/goback.jpg" 
09c0: 62 6f 72 64 65 72 3d 30 20 2f 3e 0a 42 61 63 6b  border=0 />.Back
09d0: 20 74 6f 20 74 68 65 20 53 51 4c 69 74 65 20 48   to the SQLite H
09e0: 6f 6d 65 20 50 61 67 65 3c 2f 61 3e 0a 3c 2f 70  ome Page</a>.</p
09f0: 3e 0a 0a 3c 2f 62 6f 64 79 3e 3c 2f 68 74 6d 6c  >..</body></html
0a00: 3e 7d 0a                                         >}.