System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 9033ca82d80d97b684ee2d78b9d65a800903a653:


0000: 3c 21 44 4f 43 54 59 50 45 20 48 54 4d 4c 20 50  <!DOCTYPE HTML P
0010: 55 42 4c 49 43 20 22 2d 2f 2f 57 33 43 2f 2f 44  UBLIC "-//W3C//D
0020: 54 44 20 48 54 4d 4c 20 34 2e 30 31 2f 2f 45 4e  TD HTML 4.01//EN
0030: 22 20 22 68 74 74 70 3a 2f 2f 77 77 77 2e 77 33  " "http://www.w3
0040: 2e 6f 72 67 2f 54 52 2f 68 74 6d 6c 34 2f 73 74  .org/TR/html4/st
0050: 72 69 63 74 2e 64 74 64 22 3e 0a 3c 68 74 6d 6c  rict.dtd">.<html
0060: 3e 3c 68 65 61 64 3e 0a 3c 6d 65 74 61 20 68 74  ><head>.<meta ht
0070: 74 70 2d 65 71 75 69 76 3d 22 63 6f 6e 74 65 6e  tp-equiv="conten
0080: 74 2d 74 79 70 65 22 20 63 6f 6e 74 65 6e 74 3d  t-type" content=
0090: 22 74 65 78 74 2f 68 74 6d 6c 3b 20 63 68 61 72  "text/html; char
00a0: 73 65 74 3d 55 54 46 2d 38 22 3e 0a 3c 74 69 74  set=UTF-8">.<tit
00b0: 6c 65 3e 53 51 4c 69 74 65 20 51 75 65 72 79 20  le>SQLite Query 
00c0: 4c 61 6e 67 75 61 67 65 3a 20 65 78 70 72 65 73  Language: expres
00d0: 73 69 6f 6e 3c 2f 74 69 74 6c 65 3e 0a 3c 73 74  sion</title>.<st
00e0: 79 6c 65 20 74 79 70 65 3d 22 74 65 78 74 2f 63  yle type="text/c
00f0: 73 73 22 3e 0a 62 6f 64 79 20 7b 0a 20 20 20 20  ss">.body {.    
0100: 6d 61 72 67 69 6e 3a 20 61 75 74 6f 3b 0a 20 20  margin: auto;.  
0110: 20 20 66 6f 6e 74 2d 66 61 6d 69 6c 79 3a 20 56    font-family: V
0120: 65 72 64 61 6e 61 2c 20 73 61 6e 73 2d 73 65 72  erdana, sans-ser
0130: 69 66 3b 0a 20 20 20 20 70 61 64 64 69 6e 67 3a  if;.    padding:
0140: 20 38 70 78 20 31 25 3b 0a 7d 0a 0a 61 20 7b 20   8px 1%;.}..a { 
0150: 63 6f 6c 6f 72 3a 20 23 30 34 34 61 36 34 20 7d  color: #044a64 }
0160: 0a 61 3a 76 69 73 69 74 65 64 20 7b 20 63 6f 6c  .a:visited { col
0170: 6f 72 3a 20 23 37 33 34 35 35 39 20 7d 0a 0a 2e  or: #734559 }...
0180: 6c 6f 67 6f 20 7b 20 70 6f 73 69 74 69 6f 6e 3a  logo { position:
0190: 61 62 73 6f 6c 75 74 65 3b 20 6d 61 72 67 69 6e  absolute; margin
01a0: 3a 33 70 78 3b 20 7d 0a 2e 74 61 67 6c 69 6e 65  :3px; }..tagline
01b0: 20 7b 0a 20 20 66 6c 6f 61 74 3a 72 69 67 68 74   {.  float:right
01c0: 3b 0a 20 20 74 65 78 74 2d 61 6c 69 67 6e 3a 72  ;.  text-align:r
01d0: 69 67 68 74 3b 0a 20 20 66 6f 6e 74 2d 73 74 79  ight;.  font-sty
01e0: 6c 65 3a 69 74 61 6c 69 63 3b 0a 20 20 77 69 64  le:italic;.  wid
01f0: 74 68 3a 33 30 30 70 78 3b 0a 20 20 6d 61 72 67  th:300px;.  marg
0200: 69 6e 3a 31 32 70 78 3b 0a 20 20 6d 61 72 67 69  in:12px;.  margi
0210: 6e 2d 74 6f 70 3a 35 38 70 78 3b 0a 7d 0a 0a 2e  n-top:58px;.}...
0220: 6d 65 6e 75 62 61 72 20 7b 0a 20 20 63 6c 65 61  menubar {.  clea
0230: 72 3a 20 62 6f 74 68 3b 0a 20 20 62 6f 72 64 65  r: both;.  borde
0240: 72 2d 72 61 64 69 75 73 3a 20 38 70 78 3b 0a 20  r-radius: 8px;. 
0250: 20 62 61 63 6b 67 72 6f 75 6e 64 3a 20 23 30 34   background: #04
0260: 34 61 36 34 3b 0a 20 20 70 61 64 64 69 6e 67 3a  4a64;.  padding:
0270: 20 30 70 78 3b 0a 20 20 6d 61 72 67 69 6e 3a 20   0px;.  margin: 
0280: 30 70 78 3b 0a 20 20 63 65 6c 6c 2d 73 70 61 63  0px;.  cell-spac
0290: 69 6e 67 3a 20 30 70 78 3b 0a 7d 20 20 20 20 0a  ing: 0px;.}    .
02a0: 2e 74 6f 6f 6c 62 61 72 20 7b 0a 20 20 74 65 78  .toolbar {.  tex
02b0: 74 2d 61 6c 69 67 6e 3a 20 63 65 6e 74 65 72 3b  t-align: center;
02c0: 0a 20 20 6c 69 6e 65 2d 68 65 69 67 68 74 3a 20  .  line-height: 
02d0: 31 2e 36 65 6d 3b 0a 20 20 6d 61 72 67 69 6e 3a  1.6em;.  margin:
02e0: 20 30 3b 0a 20 20 70 61 64 64 69 6e 67 3a 20 30   0;.  padding: 0
02f0: 70 78 20 38 70 78 3b 0a 7d 0a 2e 74 6f 6f 6c 62  px 8px;.}..toolb
0300: 61 72 20 61 20 7b 20 63 6f 6c 6f 72 3a 20 77 68  ar a { color: wh
0310: 69 74 65 3b 20 74 65 78 74 2d 64 65 63 6f 72 61  ite; text-decora
0320: 74 69 6f 6e 3a 20 6e 6f 6e 65 3b 20 70 61 64 64  tion: none; padd
0330: 69 6e 67 3a 20 36 70 78 20 31 32 70 78 3b 20 7d  ing: 6px 12px; }
0340: 0a 2e 74 6f 6f 6c 62 61 72 20 61 3a 76 69 73 69  ..toolbar a:visi
0350: 74 65 64 20 7b 20 63 6f 6c 6f 72 3a 20 77 68 69  ted { color: whi
0360: 74 65 3b 20 7d 0a 2e 74 6f 6f 6c 62 61 72 20 61  te; }..toolbar a
0370: 3a 68 6f 76 65 72 20 7b 20 63 6f 6c 6f 72 3a 20  :hover { color: 
0380: 23 30 34 34 61 36 34 3b 20 62 61 63 6b 67 72 6f  #044a64; backgro
0390: 75 6e 64 3a 20 77 68 69 74 65 3b 20 7d 0a 0a 2e  und: white; }...
03a0: 63 6f 6e 74 65 6e 74 20 20 20 20 7b 20 6d 61 72  content    { mar
03b0: 67 69 6e 3a 20 35 25 3b 20 7d 0a 2e 63 6f 6e 74  gin: 5%; }..cont
03c0: 65 6e 74 20 64 74 20 7b 20 66 6f 6e 74 2d 77 65  ent dt { font-we
03d0: 69 67 68 74 3a 62 6f 6c 64 3b 20 7d 0a 2e 63 6f  ight:bold; }..co
03e0: 6e 74 65 6e 74 20 64 64 20 7b 20 6d 61 72 67 69  ntent dd { margi
03f0: 6e 2d 62 6f 74 74 6f 6d 3a 20 32 35 70 78 3b 20  n-bottom: 25px; 
0400: 6d 61 72 67 69 6e 2d 6c 65 66 74 3a 32 30 25 3b  margin-left:20%;
0410: 20 7d 0a 2e 63 6f 6e 74 65 6e 74 20 75 6c 20 7b   }..content ul {
0420: 20 70 61 64 64 69 6e 67 3a 30 70 78 3b 20 70 61   padding:0px; pa
0430: 64 64 69 6e 67 2d 6c 65 66 74 3a 20 31 35 70 78  dding-left: 15px
0440: 3b 20 6d 61 72 67 69 6e 3a 30 70 78 3b 20 7d 0a  ; margin:0px; }.
0450: 0a 2f 2a 20 54 68 69 6e 67 73 20 66 6f 72 20 22  ./* Things for "
0460: 66 61 6e 63 79 66 6f 72 6d 61 74 22 20 64 6f 63  fancyformat" doc
0470: 75 6d 65 6e 74 73 20 73 74 61 72 74 20 68 65 72  uments start her
0480: 65 2e 20 2a 2f 0a 2e 66 61 6e 63 79 20 69 6d 67  e. */..fancy img
0490: 2b 70 20 7b 66 6f 6e 74 2d 73 74 79 6c 65 3a 69  +p {font-style:i
04a0: 74 61 6c 69 63 7d 0a 2e 66 61 6e 63 79 20 2e 63  talic}..fancy .c
04b0: 6f 64 65 62 6c 6f 63 6b 20 69 20 7b 20 63 6f 6c  odeblock i { col
04c0: 6f 72 3a 20 64 61 72 6b 62 6c 75 65 3b 20 7d 0a  or: darkblue; }.
04d0: 2e 66 61 6e 63 79 20 68 31 2c 2e 66 61 6e 63 79  .fancy h1,.fancy
04e0: 20 68 32 2c 2e 66 61 6e 63 79 20 68 33 2c 2e 66   h2,.fancy h3,.f
04f0: 61 6e 63 79 20 68 34 20 7b 66 6f 6e 74 2d 77 65  ancy h4 {font-we
0500: 69 67 68 74 3a 6e 6f 72 6d 61 6c 3b 63 6f 6c 6f  ight:normal;colo
0510: 72 3a 23 30 34 34 61 36 34 7d 0a 2e 66 61 6e 63  r:#044a64}..fanc
0520: 79 20 68 32 20 7b 20 6d 61 72 67 69 6e 2d 6c 65  y h2 { margin-le
0530: 66 74 3a 20 31 30 70 78 20 7d 0a 2e 66 61 6e 63  ft: 10px }..fanc
0540: 79 20 68 33 20 7b 20 6d 61 72 67 69 6e 2d 6c 65  y h3 { margin-le
0550: 66 74 3a 20 32 30 70 78 20 7d 0a 2e 66 61 6e 63  ft: 20px }..fanc
0560: 79 20 68 34 20 7b 20 6d 61 72 67 69 6e 2d 6c 65  y h4 { margin-le
0570: 66 74 3a 20 33 30 70 78 20 7d 0a 2e 66 61 6e 63  ft: 30px }..fanc
0580: 79 20 74 68 20 7b 77 68 69 74 65 2d 73 70 61 63  y th {white-spac
0590: 65 3a 6e 6f 77 72 61 70 3b 74 65 78 74 2d 61 6c  e:nowrap;text-al
05a0: 69 67 6e 3a 6c 65 66 74 3b 62 6f 72 64 65 72 2d  ign:left;border-
05b0: 62 6f 74 74 6f 6d 3a 73 6f 6c 69 64 20 31 70 78  bottom:solid 1px
05c0: 20 23 34 34 34 7d 0a 2e 66 61 6e 63 79 20 74 68   #444}..fancy th
05d0: 2c 20 2e 66 61 6e 63 79 20 74 64 20 7b 70 61 64  , .fancy td {pad
05e0: 64 69 6e 67 3a 20 30 2e 32 65 6d 20 31 65 78 3b  ding: 0.2em 1ex;
05f0: 20 76 65 72 74 69 63 61 6c 2d 61 6c 69 67 6e 3a   vertical-align:
0600: 74 6f 70 7d 0a 2e 66 61 6e 63 79 20 23 74 6f 63  top}..fancy #toc
0610: 20 61 20 20 20 20 20 20 20 20 7b 20 63 6f 6c 6f   a        { colo
0620: 72 3a 20 64 61 72 6b 62 6c 75 65 20 3b 20 74 65  r: darkblue ; te
0630: 78 74 2d 64 65 63 6f 72 61 74 69 6f 6e 3a 20 6e  xt-decoration: n
0640: 6f 6e 65 20 7d 0a 2e 66 61 6e 63 79 20 2e 74 6f  one }..fancy .to
0650: 64 6f 20 20 20 20 20 20 20 20 20 7b 20 63 6f 6c  do         { col
0660: 6f 72 3a 20 23 41 41 33 33 33 33 20 3b 20 66 6f  or: #AA3333 ; fo
0670: 6e 74 2d 73 74 79 6c 65 20 3a 20 69 74 61 6c 69  nt-style : itali
0680: 63 20 7d 0a 2e 66 61 6e 63 79 20 2e 74 6f 64 6f  c }..fancy .todo
0690: 3a 62 65 66 6f 72 65 20 20 7b 20 63 6f 6e 74 65  :before  { conte
06a0: 6e 74 3a 20 27 54 4f 44 4f 3a 27 20 7d 0a 2e 66  nt: 'TODO:' }..f
06b0: 61 6e 63 79 20 70 2e 74 6f 64 6f 20 20 20 20 20  ancy p.todo     
06c0: 20 20 20 7b 20 62 6f 72 64 65 72 3a 20 73 6f 6c     { border: sol
06d0: 69 64 20 23 41 41 33 33 33 33 20 31 70 78 3b 20  id #AA3333 1px; 
06e0: 70 61 64 64 69 6e 67 3a 20 31 65 78 20 7d 0a 2e  padding: 1ex }..
06f0: 66 61 6e 63 79 20 69 6d 67 20 7b 20 64 69 73 70  fancy img { disp
0700: 6c 61 79 3a 62 6c 6f 63 6b 3b 20 7d 0a 2e 66 61  lay:block; }..fa
0710: 6e 63 79 20 3a 6c 69 6e 6b 3a 68 6f 76 65 72 2c  ncy :link:hover,
0720: 20 2e 66 61 6e 63 79 20 3a 76 69 73 69 74 65 64   .fancy :visited
0730: 3a 68 6f 76 65 72 20 7b 20 62 61 63 6b 67 72 6f  :hover { backgro
0740: 75 6e 64 3a 20 77 68 65 61 74 20 7d 0a 2e 66 61  und: wheat }..fa
0750: 6e 63 79 20 70 2c 2e 66 61 6e 63 79 20 75 6c 2c  ncy p,.fancy ul,
0760: 2e 66 61 6e 63 79 20 6f 6c 20 7b 20 6d 61 72 67  .fancy ol { marg
0770: 69 6e 3a 20 31 65 6d 20 35 65 78 20 7d 0a 2e 66  in: 1em 5ex }..f
0780: 61 6e 63 79 20 6c 69 20 70 20 7b 20 6d 61 72 67  ancy li p { marg
0790: 69 6e 3a 20 31 65 6d 20 30 20 7d 0a 2f 2a 20 45  in: 1em 0 }./* E
07a0: 6e 64 20 6f 66 20 22 66 61 6e 63 79 66 6f 72 6d  nd of "fancyform
07b0: 61 74 22 20 73 70 65 63 69 66 69 63 20 72 75 6c  at" specific rul
07c0: 65 73 2e 20 2a 2f 0a 0a 3c 2f 73 74 79 6c 65 3e  es. */..</style>
07d0: 0a 20 20 0a 3c 2f 68 65 61 64 3e 0a 3c 62 6f 64  .  .</head>.<bod
07e0: 79 3e 0a 3c 64 69 76 3e 3c 21 2d 2d 20 63 6f 6e  y>.<div><!-- con
07f0: 74 61 69 6e 65 72 20 64 69 76 20 74 6f 20 73 61  tainer div to sa
0800: 74 69 73 66 79 20 76 61 6c 69 64 61 74 6f 72 20  tisfy validator 
0810: 2d 2d 3e 0a 0a 3c 61 20 68 72 65 66 3d 22 69 6e  -->..<a href="in
0820: 64 65 78 2e 68 74 6d 6c 22 3e 0a 3c 69 6d 67 20  dex.html">.<img 
0830: 63 6c 61 73 73 3d 22 6c 6f 67 6f 22 20 73 72 63  class="logo" src
0840: 3d 22 69 6d 61 67 65 73 2f 73 71 6c 69 74 65 33  ="images/sqlite3
0850: 37 30 5f 62 61 6e 6e 65 72 2e 67 69 66 22 20 61  70_banner.gif" a
0860: 6c 74 3d 22 53 51 4c 69 74 65 20 4c 6f 67 6f 22  lt="SQLite Logo"
0870: 0a 20 62 6f 72 64 65 72 3d 22 30 22 3e 3c 2f 61  . border="0"></a
0880: 3e 0a 3c 64 69 76 3e 3c 21 2d 2d 20 49 45 20 68  >.<div><!-- IE h
0890: 61 63 6b 20 74 6f 20 70 72 65 76 65 6e 74 20 64  ack to prevent d
08a0: 69 73 61 70 70 65 61 72 69 6e 67 20 6c 6f 67 6f  isappearing logo
08b0: 2d 2d 3e 3c 2f 64 69 76 3e 0a 3c 64 69 76 20 63  --></div>.<div c
08c0: 6c 61 73 73 3d 22 74 61 67 6c 69 6e 65 22 3e 53  lass="tagline">S
08d0: 6d 61 6c 6c 2e 20 46 61 73 74 2e 20 52 65 6c 69  mall. Fast. Reli
08e0: 61 62 6c 65 2e 3c 62 72 3e 43 68 6f 6f 73 65 20  able.<br>Choose 
08f0: 61 6e 79 20 74 68 72 65 65 2e 3c 2f 64 69 76 3e  any three.</div>
0900: 0a 0a 3c 74 61 62 6c 65 20 77 69 64 74 68 3d 31  ..<table width=1
0910: 30 30 25 20 63 6c 61 73 73 3d 22 6d 65 6e 75 62  00% class="menub
0920: 61 72 22 3e 3c 74 72 3e 0a 20 20 3c 74 64 20 77  ar"><tr>.  <td w
0930: 69 64 74 68 3d 31 30 30 25 3e 0a 20 20 3c 64 69  idth=100%>.  <di
0940: 76 20 63 6c 61 73 73 3d 22 74 6f 6f 6c 62 61 72  v class="toolbar
0950: 22 3e 0a 20 20 20 20 3c 61 20 68 72 65 66 3d 22  ">.    <a href="
0960: 61 62 6f 75 74 2e 68 74 6d 6c 22 3e 41 62 6f 75  about.html">Abou
0970: 74 3c 2f 61 3e 0a 20 20 20 20 3c 61 20 68 72 65  t</a>.    <a hre
0980: 66 3d 22 73 69 74 65 6d 61 70 2e 68 74 6d 6c 22  f="sitemap.html"
0990: 3e 53 69 74 65 6d 61 70 3c 2f 61 3e 0a 20 20 20  >Sitemap</a>.   
09a0: 20 3c 61 20 68 72 65 66 3d 22 64 6f 63 73 2e 68   <a href="docs.h
09b0: 74 6d 6c 22 3e 44 6f 63 75 6d 65 6e 74 61 74 69  tml">Documentati
09c0: 6f 6e 3c 2f 61 3e 0a 20 20 20 20 3c 61 20 68 72  on</a>.    <a hr
09d0: 65 66 3d 22 64 6f 77 6e 6c 6f 61 64 2e 68 74 6d  ef="download.htm
09e0: 6c 22 3e 44 6f 77 6e 6c 6f 61 64 3c 2f 61 3e 0a  l">Download</a>.
09f0: 20 20 20 20 3c 61 20 68 72 65 66 3d 22 63 6f 70      <a href="cop
0a00: 79 72 69 67 68 74 2e 68 74 6d 6c 22 3e 4c 69 63  yright.html">Lic
0a10: 65 6e 73 65 3c 2f 61 3e 0a 20 20 20 20 3c 61 20  ense</a>.    <a 
0a20: 68 72 65 66 3d 22 6e 65 77 73 2e 68 74 6d 6c 22  href="news.html"
0a30: 3e 4e 65 77 73 3c 2f 61 3e 0a 20 20 20 20 3c 61  >News</a>.    <a
0a40: 20 68 72 65 66 3d 22 73 75 70 70 6f 72 74 2e 68   href="support.h
0a50: 74 6d 6c 22 3e 53 75 70 70 6f 72 74 3c 2f 61 3e  tml">Support</a>
0a60: 0a 20 20 3c 2f 64 69 76 3e 0a 3c 73 63 72 69 70  .  </div>.<scrip
0a70: 74 3e 0a 20 20 67 4d 73 67 20 3d 20 22 53 65 61  t>.  gMsg = "Sea
0a80: 72 63 68 20 53 51 4c 69 74 65 20 44 6f 63 73 2e  rch SQLite Docs.
0a90: 2e 2e 22 0a 20 20 66 75 6e 63 74 69 6f 6e 20 65  ..".  function e
0aa0: 6e 74 65 72 73 65 61 72 63 68 28 29 20 7b 0a 20  ntersearch() {. 
0ab0: 20 20 20 76 61 72 20 71 20 3d 20 64 6f 63 75 6d     var q = docum
0ac0: 65 6e 74 2e 67 65 74 45 6c 65 6d 65 6e 74 42 79  ent.getElementBy
0ad0: 49 64 28 22 71 22 29 3b 0a 20 20 20 20 69 66 28  Id("q");.    if(
0ae0: 20 71 2e 76 61 6c 75 65 20 3d 3d 20 67 4d 73 67   q.value == gMsg
0af0: 20 29 20 7b 20 71 2e 76 61 6c 75 65 20 3d 20 22   ) { q.value = "
0b00: 22 20 7d 0a 20 20 20 20 71 2e 73 74 79 6c 65 2e  " }.    q.style.
0b10: 63 6f 6c 6f 72 20 3d 20 22 62 6c 61 63 6b 22 0a  color = "black".
0b20: 20 20 20 20 71 2e 73 74 79 6c 65 2e 66 6f 6e 74      q.style.font
0b30: 53 74 79 6c 65 20 3d 20 22 6e 6f 72 6d 61 6c 22  Style = "normal"
0b40: 0a 20 20 7d 0a 20 20 66 75 6e 63 74 69 6f 6e 20  .  }.  function 
0b50: 6c 65 61 76 65 73 65 61 72 63 68 28 29 20 7b 0a  leavesearch() {.
0b60: 20 20 20 20 76 61 72 20 71 20 3d 20 64 6f 63 75      var q = docu
0b70: 6d 65 6e 74 2e 67 65 74 45 6c 65 6d 65 6e 74 42  ment.getElementB
0b80: 79 49 64 28 22 71 22 29 3b 0a 20 20 20 20 69 66  yId("q");.    if
0b90: 28 20 71 2e 76 61 6c 75 65 20 3d 3d 20 22 22 20  ( q.value == "" 
0ba0: 29 20 7b 20 0a 20 20 20 20 20 20 71 2e 76 61 6c  ) { .      q.val
0bb0: 75 65 20 3d 20 67 4d 73 67 0a 20 20 20 20 20 20  ue = gMsg.      
0bc0: 71 2e 73 74 79 6c 65 2e 63 6f 6c 6f 72 20 3d 20  q.style.color = 
0bd0: 22 23 30 34 34 61 36 34 22 0a 20 20 20 20 20 20  "#044a64".      
0be0: 71 2e 73 74 79 6c 65 2e 66 6f 6e 74 53 74 79 6c  q.style.fontStyl
0bf0: 65 20 3d 20 22 69 74 61 6c 69 63 22 0a 20 20 20  e = "italic".   
0c00: 20 7d 0a 20 20 7d 0a 20 20 66 75 6e 63 74 69 6f   }.  }.  functio
0c10: 6e 20 68 69 64 65 6f 72 73 68 6f 77 28 62 74 6e  n hideorshow(btn
0c20: 2c 6f 62 6a 29 7b 0a 20 20 20 20 76 61 72 20 78  ,obj){.    var x
0c30: 20 3d 20 64 6f 63 75 6d 65 6e 74 2e 67 65 74 45   = document.getE
0c40: 6c 65 6d 65 6e 74 42 79 49 64 28 6f 62 6a 29 3b  lementById(obj);
0c50: 0a 20 20 20 20 76 61 72 20 62 20 3d 20 64 6f 63  .    var b = doc
0c60: 75 6d 65 6e 74 2e 67 65 74 45 6c 65 6d 65 6e 74  ument.getElement
0c70: 42 79 49 64 28 62 74 6e 29 3b 0a 20 20 20 20 69  ById(btn);.    i
0c80: 66 28 20 78 2e 73 74 79 6c 65 2e 64 69 73 70 6c  f( x.style.displ
0c90: 61 79 21 3d 27 6e 6f 6e 65 27 20 29 7b 0a 20 20  ay!='none' ){.  
0ca0: 20 20 20 20 78 2e 73 74 79 6c 65 2e 64 69 73 70      x.style.disp
0cb0: 6c 61 79 20 3d 20 27 6e 6f 6e 65 27 3b 0a 20 20  lay = 'none';.  
0cc0: 20 20 20 20 62 2e 69 6e 6e 65 72 48 54 4d 4c 3d      b.innerHTML=
0cd0: 27 73 68 6f 77 27 3b 0a 20 20 20 20 7d 65 6c 73  'show';.    }els
0ce0: 65 7b 0a 20 20 20 20 20 20 78 2e 73 74 79 6c 65  e{.      x.style
0cf0: 2e 64 69 73 70 6c 61 79 20 3d 20 27 27 3b 0a 20  .display = '';. 
0d00: 20 20 20 20 20 62 2e 69 6e 6e 65 72 48 54 4d 4c       b.innerHTML
0d10: 3d 27 68 69 64 65 27 3b 0a 20 20 20 20 7d 0a 20  ='hide';.    }. 
0d20: 20 20 20 72 65 74 75 72 6e 20 66 61 6c 73 65 3b     return false;
0d30: 0a 20 20 7d 0a 3c 2f 73 63 72 69 70 74 3e 0a 3c  .  }.</script>.<
0d40: 74 64 3e 0a 20 20 20 20 3c 64 69 76 20 73 74 79  td>.    <div sty
0d50: 6c 65 3d 22 70 61 64 64 69 6e 67 3a 30 20 31 65  le="padding:0 1e
0d60: 6d 20 30 70 78 20 30 3b 77 68 69 74 65 2d 73 70  m 0px 0;white-sp
0d70: 61 63 65 3a 6e 6f 77 72 61 70 22 3e 0a 20 20 20  ace:nowrap">.   
0d80: 20 3c 66 6f 72 6d 20 6e 61 6d 65 3d 66 20 6d 65   <form name=f me
0d90: 74 68 6f 64 3d 22 47 45 54 22 20 61 63 74 69 6f  thod="GET" actio
0da0: 6e 3d 22 68 74 74 70 3a 2f 2f 77 77 77 2e 73 71  n="http://www.sq
0db0: 6c 69 74 65 2e 6f 72 67 2f 73 65 61 72 63 68 22  lite.org/search"
0dc0: 3e 0a 20 20 20 20 20 20 3c 69 6e 70 75 74 20 69  >.      <input i
0dd0: 64 3d 71 20 6e 61 6d 65 3d 71 20 74 79 70 65 3d  d=q name=q type=
0de0: 74 65 78 74 0a 20 20 20 20 20 20 20 6f 6e 66 6f  text.       onfo
0df0: 63 75 73 3d 22 65 6e 74 65 72 73 65 61 72 63 68  cus="entersearch
0e00: 28 29 22 20 6f 6e 62 6c 75 72 3d 22 6c 65 61 76  ()" onblur="leav
0e10: 65 73 65 61 72 63 68 28 29 22 20 73 74 79 6c 65  esearch()" style
0e20: 3d 22 77 69 64 74 68 3a 32 34 65 78 3b 70 61 64  ="width:24ex;pad
0e30: 64 69 6e 67 3a 31 70 78 20 31 65 78 3b 20 62 6f  ding:1px 1ex; bo
0e40: 72 64 65 72 3a 73 6f 6c 69 64 20 77 68 69 74 65  rder:solid white
0e50: 20 31 70 78 3b 20 66 6f 6e 74 2d 73 69 7a 65 3a   1px; font-size:
0e60: 30 2e 39 65 6d 20 3b 20 66 6f 6e 74 2d 73 74 79  0.9em ; font-sty
0e70: 6c 65 3a 69 74 61 6c 69 63 3b 63 6f 6c 6f 72 3a  le:italic;color:
0e80: 23 30 34 34 61 36 34 3b 22 20 76 61 6c 75 65 3d  #044a64;" value=
0e90: 22 53 65 61 72 63 68 20 53 51 4c 69 74 65 20 44  "Search SQLite D
0ea0: 6f 63 73 2e 2e 2e 22 3e 0a 20 20 20 20 20 20 3c  ocs...">.      <
0eb0: 69 6e 70 75 74 20 74 79 70 65 3d 73 75 62 6d 69  input type=submi
0ec0: 74 20 76 61 6c 75 65 3d 22 47 6f 22 20 73 74 79  t value="Go" sty
0ed0: 6c 65 3d 22 62 6f 72 64 65 72 3a 73 6f 6c 69 64  le="border:solid
0ee0: 20 77 68 69 74 65 20 31 70 78 3b 62 61 63 6b 67   white 1px;backg
0ef0: 72 6f 75 6e 64 2d 63 6f 6c 6f 72 3a 23 30 34 34  round-color:#044
0f00: 61 36 34 3b 63 6f 6c 6f 72 3a 77 68 69 74 65 3b  a64;color:white;
0f10: 66 6f 6e 74 2d 73 69 7a 65 3a 30 2e 39 65 6d 3b  font-size:0.9em;
0f20: 70 61 64 64 69 6e 67 3a 30 20 31 65 78 22 3e 0a  padding:0 1ex">.
0f30: 20 20 20 20 3c 2f 66 6f 72 6d 3e 0a 20 20 20 20      </form>.    
0f40: 3c 2f 64 69 76 3e 0a 20 20 3c 2f 74 61 62 6c 65  </div>.  </table
0f50: 3e 0a 0a 3c 64 69 76 20 63 6c 61 73 73 3d 73 74  >..<div class=st
0f60: 61 72 74 73 65 61 72 63 68 3e 3c 2f 64 69 76 3e  artsearch></div>
0f70: 0a 20 20 0a 3c 68 31 20 61 6c 69 67 6e 3d 22 63  .  .<h1 align="c
0f80: 65 6e 74 65 72 22 3e 53 51 4c 20 41 73 20 55 6e  enter">SQL As Un
0f90: 64 65 72 73 74 6f 6f 64 20 42 79 20 53 51 4c 69  derstood By SQLi
0fa0: 74 65 3c 2f 68 31 3e 3c 70 3e 3c 61 20 68 72 65  te</h1><p><a hre
0fb0: 66 3d 22 6c 61 6e 67 2e 68 74 6d 6c 22 3e 5b 54  f="lang.html">[T
0fc0: 6f 70 5d 3c 2f 61 3e 3c 2f 70 3e 3c 68 32 3e 65  op]</a></p><h2>e
0fd0: 78 70 72 65 73 73 69 6f 6e 3c 2f 68 32 3e 3c 70  xpression</h2><p
0fe0: 3e 3c 62 3e 3c 61 20 68 72 65 66 3d 22 73 79 6e  ><b><a href="syn
0ff0: 74 61 78 64 69 61 67 72 61 6d 73 2e 68 74 6d 6c  taxdiagrams.html
1000: 23 65 78 70 72 22 3e 65 78 70 72 3a 3c 2f 61 3e  #expr">expr:</a>
1010: 3c 2f 62 3e 0a 3c 62 75 74 74 6f 6e 20 69 64 3d  </b>.<button id=
1020: 27 78 31 30 37 31 27 20 6f 6e 63 6c 69 63 6b 3d  'x1071' onclick=
1030: 27 68 69 64 65 6f 72 73 68 6f 77 28 22 78 31 30  'hideorshow("x10
1040: 37 31 22 2c 22 78 31 30 37 32 22 29 27 3e 68 69  71","x1072")'>hi
1050: 64 65 3c 2f 62 75 74 74 6f 6e 3e 3c 2f 70 3e 0a  de</button></p>.
1060: 20 3c 62 6c 6f 63 6b 71 75 6f 74 65 20 69 64 3d   <blockquote id=
1070: 27 78 31 30 37 32 27 3e 0a 20 3c 69 6d 67 20 61  'x1072'>. <img a
1080: 6c 74 3d 22 73 79 6e 74 61 78 20 64 69 61 67 72  lt="syntax diagr
1090: 61 6d 20 65 78 70 72 22 20 73 72 63 3d 22 69 6d  am expr" src="im
10a0: 61 67 65 73 2f 73 79 6e 74 61 78 2f 65 78 70 72  ages/syntax/expr
10b0: 2e 67 69 66 22 20 2f 3e 0a 3c 70 3e 3c 62 3e 3c  .gif" />.<p><b><
10c0: 61 20 68 72 65 66 3d 22 73 79 6e 74 61 78 64 69  a href="syntaxdi
10d0: 61 67 72 61 6d 73 2e 68 74 6d 6c 23 6c 69 74 65  agrams.html#lite
10e0: 72 61 6c 2d 76 61 6c 75 65 22 3e 6c 69 74 65 72  ral-value">liter
10f0: 61 6c 2d 76 61 6c 75 65 3a 3c 2f 61 3e 3c 2f 62  al-value:</a></b
1100: 3e 0a 3c 62 75 74 74 6f 6e 20 69 64 3d 27 78 31  >.<button id='x1
1110: 30 37 33 27 20 6f 6e 63 6c 69 63 6b 3d 27 68 69  073' onclick='hi
1120: 64 65 6f 72 73 68 6f 77 28 22 78 31 30 37 33 22  deorshow("x1073"
1130: 2c 22 78 31 30 37 34 22 29 27 3e 73 68 6f 77 3c  ,"x1074")'>show<
1140: 2f 62 75 74 74 6f 6e 3e 3c 2f 70 3e 0a 20 3c 62  /button></p>. <b
1150: 6c 6f 63 6b 71 75 6f 74 65 20 69 64 3d 27 78 31  lockquote id='x1
1160: 30 37 34 27 20 73 74 79 6c 65 3d 27 64 69 73 70  074' style='disp
1170: 6c 61 79 3a 6e 6f 6e 65 3b 27 3e 0a 20 3c 69 6d  lay:none;'>. <im
1180: 67 20 61 6c 74 3d 22 73 79 6e 74 61 78 20 64 69  g alt="syntax di
1190: 61 67 72 61 6d 20 6c 69 74 65 72 61 6c 2d 76 61  agram literal-va
11a0: 6c 75 65 22 20 73 72 63 3d 22 69 6d 61 67 65 73  lue" src="images
11b0: 2f 73 79 6e 74 61 78 2f 6c 69 74 65 72 61 6c 2d  /syntax/literal-
11c0: 76 61 6c 75 65 2e 67 69 66 22 20 2f 3e 0a 3c 2f  value.gif" />.</
11d0: 62 6c 6f 63 6b 71 75 6f 74 65 3e 0a 3c 70 3e 3c  blockquote>.<p><
11e0: 62 3e 3c 61 20 68 72 65 66 3d 22 73 79 6e 74 61  b><a href="synta
11f0: 78 64 69 61 67 72 61 6d 73 2e 68 74 6d 6c 23 72  xdiagrams.html#r
1200: 61 69 73 65 2d 66 75 6e 63 74 69 6f 6e 22 3e 72  aise-function">r
1210: 61 69 73 65 2d 66 75 6e 63 74 69 6f 6e 3a 3c 2f  aise-function:</
1220: 61 3e 3c 2f 62 3e 0a 3c 62 75 74 74 6f 6e 20 69  a></b>.<button i
1230: 64 3d 27 78 31 30 37 35 27 20 6f 6e 63 6c 69 63  d='x1075' onclic
1240: 6b 3d 27 68 69 64 65 6f 72 73 68 6f 77 28 22 78  k='hideorshow("x
1250: 31 30 37 35 22 2c 22 78 31 30 37 36 22 29 27 3e  1075","x1076")'>
1260: 73 68 6f 77 3c 2f 62 75 74 74 6f 6e 3e 3c 2f 70  show</button></p
1270: 3e 0a 20 3c 62 6c 6f 63 6b 71 75 6f 74 65 20 69  >. <blockquote i
1280: 64 3d 27 78 31 30 37 36 27 20 73 74 79 6c 65 3d  d='x1076' style=
1290: 27 64 69 73 70 6c 61 79 3a 6e 6f 6e 65 3b 27 3e  'display:none;'>
12a0: 0a 20 3c 69 6d 67 20 61 6c 74 3d 22 73 79 6e 74  . <img alt="synt
12b0: 61 78 20 64 69 61 67 72 61 6d 20 72 61 69 73 65  ax diagram raise
12c0: 2d 66 75 6e 63 74 69 6f 6e 22 20 73 72 63 3d 22  -function" src="
12d0: 69 6d 61 67 65 73 2f 73 79 6e 74 61 78 2f 72 61  images/syntax/ra
12e0: 69 73 65 2d 66 75 6e 63 74 69 6f 6e 2e 67 69 66  ise-function.gif
12f0: 22 20 2f 3e 0a 3c 2f 62 6c 6f 63 6b 71 75 6f 74  " />.</blockquot
1300: 65 3e 0a 3c 70 3e 3c 62 3e 3c 61 20 68 72 65 66  e>.<p><b><a href
1310: 3d 22 73 79 6e 74 61 78 64 69 61 67 72 61 6d 73  ="syntaxdiagrams
1320: 2e 68 74 6d 6c 23 73 65 6c 65 63 74 2d 73 74 6d  .html#select-stm
1330: 74 22 3e 73 65 6c 65 63 74 2d 73 74 6d 74 3a 3c  t">select-stmt:<
1340: 2f 61 3e 3c 2f 62 3e 0a 3c 62 75 74 74 6f 6e 20  /a></b>.<button 
1350: 69 64 3d 27 78 31 30 37 37 27 20 6f 6e 63 6c 69  id='x1077' oncli
1360: 63 6b 3d 27 68 69 64 65 6f 72 73 68 6f 77 28 22  ck='hideorshow("
1370: 78 31 30 37 37 22 2c 22 78 31 30 37 38 22 29 27  x1077","x1078")'
1380: 3e 73 68 6f 77 3c 2f 62 75 74 74 6f 6e 3e 3c 2f  >show</button></
1390: 70 3e 0a 20 3c 62 6c 6f 63 6b 71 75 6f 74 65 20  p>. <blockquote 
13a0: 69 64 3d 27 78 31 30 37 38 27 20 73 74 79 6c 65  id='x1078' style
13b0: 3d 27 64 69 73 70 6c 61 79 3a 6e 6f 6e 65 3b 27  ='display:none;'
13c0: 3e 0a 20 3c 69 6d 67 20 61 6c 74 3d 22 73 79 6e  >. <img alt="syn
13d0: 74 61 78 20 64 69 61 67 72 61 6d 20 73 65 6c 65  tax diagram sele
13e0: 63 74 2d 73 74 6d 74 22 20 73 72 63 3d 22 69 6d  ct-stmt" src="im
13f0: 61 67 65 73 2f 73 79 6e 74 61 78 2f 73 65 6c 65  ages/syntax/sele
1400: 63 74 2d 73 74 6d 74 2e 67 69 66 22 20 2f 3e 0a  ct-stmt.gif" />.
1410: 3c 70 3e 3c 62 3e 3c 61 20 68 72 65 66 3d 22 73  <p><b><a href="s
1420: 79 6e 74 61 78 64 69 61 67 72 61 6d 73 2e 68 74  yntaxdiagrams.ht
1430: 6d 6c 23 63 6f 6d 6d 6f 6e 2d 74 61 62 6c 65 2d  ml#common-table-
1440: 65 78 70 72 65 73 73 69 6f 6e 22 3e 63 6f 6d 6d  expression">comm
1450: 6f 6e 2d 74 61 62 6c 65 2d 65 78 70 72 65 73 73  on-table-express
1460: 69 6f 6e 3a 3c 2f 61 3e 3c 2f 62 3e 0a 3c 62 75  ion:</a></b>.<bu
1470: 74 74 6f 6e 20 69 64 3d 27 78 31 30 37 39 27 20  tton id='x1079' 
1480: 6f 6e 63 6c 69 63 6b 3d 27 68 69 64 65 6f 72 73  onclick='hideors
1490: 68 6f 77 28 22 78 31 30 37 39 22 2c 22 78 31 30  how("x1079","x10
14a0: 38 30 22 29 27 3e 73 68 6f 77 3c 2f 62 75 74 74  80")'>show</butt
14b0: 6f 6e 3e 3c 2f 70 3e 0a 20 3c 62 6c 6f 63 6b 71  on></p>. <blockq
14c0: 75 6f 74 65 20 69 64 3d 27 78 31 30 38 30 27 20  uote id='x1080' 
14d0: 73 74 79 6c 65 3d 27 64 69 73 70 6c 61 79 3a 6e  style='display:n
14e0: 6f 6e 65 3b 27 3e 0a 20 3c 69 6d 67 20 61 6c 74  one;'>. <img alt
14f0: 3d 22 73 79 6e 74 61 78 20 64 69 61 67 72 61 6d  ="syntax diagram
1500: 20 63 6f 6d 6d 6f 6e 2d 74 61 62 6c 65 2d 65 78   common-table-ex
1510: 70 72 65 73 73 69 6f 6e 22 20 73 72 63 3d 22 69  pression" src="i
1520: 6d 61 67 65 73 2f 73 79 6e 74 61 78 2f 63 6f 6d  mages/syntax/com
1530: 6d 6f 6e 2d 74 61 62 6c 65 2d 65 78 70 72 65 73  mon-table-expres
1540: 73 69 6f 6e 2e 67 69 66 22 20 2f 3e 0a 3c 2f 62  sion.gif" />.</b
1550: 6c 6f 63 6b 71 75 6f 74 65 3e 0a 3c 70 3e 3c 62  lockquote>.<p><b
1560: 3e 3c 61 20 68 72 65 66 3d 22 73 79 6e 74 61 78  ><a href="syntax
1570: 64 69 61 67 72 61 6d 73 2e 68 74 6d 6c 23 63 6f  diagrams.html#co
1580: 6d 70 6f 75 6e 64 2d 6f 70 65 72 61 74 6f 72 22  mpound-operator"
1590: 3e 63 6f 6d 70 6f 75 6e 64 2d 6f 70 65 72 61 74  >compound-operat
15a0: 6f 72 3a 3c 2f 61 3e 3c 2f 62 3e 0a 3c 62 75 74  or:</a></b>.<but
15b0: 74 6f 6e 20 69 64 3d 27 78 31 30 38 31 27 20 6f  ton id='x1081' o
15c0: 6e 63 6c 69 63 6b 3d 27 68 69 64 65 6f 72 73 68  nclick='hideorsh
15d0: 6f 77 28 22 78 31 30 38 31 22 2c 22 78 31 30 38  ow("x1081","x108
15e0: 32 22 29 27 3e 73 68 6f 77 3c 2f 62 75 74 74 6f  2")'>show</butto
15f0: 6e 3e 3c 2f 70 3e 0a 20 3c 62 6c 6f 63 6b 71 75  n></p>. <blockqu
1600: 6f 74 65 20 69 64 3d 27 78 31 30 38 32 27 20 73  ote id='x1082' s
1610: 74 79 6c 65 3d 27 64 69 73 70 6c 61 79 3a 6e 6f  tyle='display:no
1620: 6e 65 3b 27 3e 0a 20 3c 69 6d 67 20 61 6c 74 3d  ne;'>. <img alt=
1630: 22 73 79 6e 74 61 78 20 64 69 61 67 72 61 6d 20  "syntax diagram 
1640: 63 6f 6d 70 6f 75 6e 64 2d 6f 70 65 72 61 74 6f  compound-operato
1650: 72 22 20 73 72 63 3d 22 69 6d 61 67 65 73 2f 73  r" src="images/s
1660: 79 6e 74 61 78 2f 63 6f 6d 70 6f 75 6e 64 2d 6f  yntax/compound-o
1670: 70 65 72 61 74 6f 72 2e 67 69 66 22 20 2f 3e 0a  perator.gif" />.
1680: 3c 2f 62 6c 6f 63 6b 71 75 6f 74 65 3e 0a 3c 70  </blockquote>.<p
1690: 3e 3c 62 3e 3c 61 20 68 72 65 66 3d 22 73 79 6e  ><b><a href="syn
16a0: 74 61 78 64 69 61 67 72 61 6d 73 2e 68 74 6d 6c  taxdiagrams.html
16b0: 23 6a 6f 69 6e 2d 63 6c 61 75 73 65 22 3e 6a 6f  #join-clause">jo
16c0: 69 6e 2d 63 6c 61 75 73 65 3a 3c 2f 61 3e 3c 2f  in-clause:</a></
16d0: 62 3e 0a 3c 62 75 74 74 6f 6e 20 69 64 3d 27 78  b>.<button id='x
16e0: 31 30 38 33 27 20 6f 6e 63 6c 69 63 6b 3d 27 68  1083' onclick='h
16f0: 69 64 65 6f 72 73 68 6f 77 28 22 78 31 30 38 33  ideorshow("x1083
1700: 22 2c 22 78 31 30 38 34 22 29 27 3e 73 68 6f 77  ","x1084")'>show
1710: 3c 2f 62 75 74 74 6f 6e 3e 3c 2f 70 3e 0a 20 3c  </button></p>. <
1720: 62 6c 6f 63 6b 71 75 6f 74 65 20 69 64 3d 27 78  blockquote id='x
1730: 31 30 38 34 27 20 73 74 79 6c 65 3d 27 64 69 73  1084' style='dis
1740: 70 6c 61 79 3a 6e 6f 6e 65 3b 27 3e 0a 20 3c 69  play:none;'>. <i
1750: 6d 67 20 61 6c 74 3d 22 73 79 6e 74 61 78 20 64  mg alt="syntax d
1760: 69 61 67 72 61 6d 20 6a 6f 69 6e 2d 63 6c 61 75  iagram join-clau
1770: 73 65 22 20 73 72 63 3d 22 69 6d 61 67 65 73 2f  se" src="images/
1780: 73 79 6e 74 61 78 2f 6a 6f 69 6e 2d 63 6c 61 75  syntax/join-clau
1790: 73 65 2e 67 69 66 22 20 2f 3e 0a 3c 70 3e 3c 62  se.gif" />.<p><b
17a0: 3e 3c 61 20 68 72 65 66 3d 22 73 79 6e 74 61 78  ><a href="syntax
17b0: 64 69 61 67 72 61 6d 73 2e 68 74 6d 6c 23 6a 6f  diagrams.html#jo
17c0: 69 6e 2d 63 6f 6e 73 74 72 61 69 6e 74 22 3e 6a  in-constraint">j
17d0: 6f 69 6e 2d 63 6f 6e 73 74 72 61 69 6e 74 3a 3c  oin-constraint:<
17e0: 2f 61 3e 3c 2f 62 3e 0a 3c 62 75 74 74 6f 6e 20  /a></b>.<button 
17f0: 69 64 3d 27 78 31 30 38 35 27 20 6f 6e 63 6c 69  id='x1085' oncli
1800: 63 6b 3d 27 68 69 64 65 6f 72 73 68 6f 77 28 22  ck='hideorshow("
1810: 78 31 30 38 35 22 2c 22 78 31 30 38 36 22 29 27  x1085","x1086")'
1820: 3e 73 68 6f 77 3c 2f 62 75 74 74 6f 6e 3e 3c 2f  >show</button></
1830: 70 3e 0a 20 3c 62 6c 6f 63 6b 71 75 6f 74 65 20  p>. <blockquote 
1840: 69 64 3d 27 78 31 30 38 36 27 20 73 74 79 6c 65  id='x1086' style
1850: 3d 27 64 69 73 70 6c 61 79 3a 6e 6f 6e 65 3b 27  ='display:none;'
1860: 3e 0a 20 3c 69 6d 67 20 61 6c 74 3d 22 73 79 6e  >. <img alt="syn
1870: 74 61 78 20 64 69 61 67 72 61 6d 20 6a 6f 69 6e  tax diagram join
1880: 2d 63 6f 6e 73 74 72 61 69 6e 74 22 20 73 72 63  -constraint" src
1890: 3d 22 69 6d 61 67 65 73 2f 73 79 6e 74 61 78 2f  ="images/syntax/
18a0: 6a 6f 69 6e 2d 63 6f 6e 73 74 72 61 69 6e 74 2e  join-constraint.
18b0: 67 69 66 22 20 2f 3e 0a 3c 2f 62 6c 6f 63 6b 71  gif" />.</blockq
18c0: 75 6f 74 65 3e 0a 3c 70 3e 3c 62 3e 3c 61 20 68  uote>.<p><b><a h
18d0: 72 65 66 3d 22 73 79 6e 74 61 78 64 69 61 67 72  ref="syntaxdiagr
18e0: 61 6d 73 2e 68 74 6d 6c 23 6a 6f 69 6e 2d 6f 70  ams.html#join-op
18f0: 65 72 61 74 6f 72 22 3e 6a 6f 69 6e 2d 6f 70 65  erator">join-ope
1900: 72 61 74 6f 72 3a 3c 2f 61 3e 3c 2f 62 3e 0a 3c  rator:</a></b>.<
1910: 62 75 74 74 6f 6e 20 69 64 3d 27 78 31 30 38 37  button id='x1087
1920: 27 20 6f 6e 63 6c 69 63 6b 3d 27 68 69 64 65 6f  ' onclick='hideo
1930: 72 73 68 6f 77 28 22 78 31 30 38 37 22 2c 22 78  rshow("x1087","x
1940: 31 30 38 38 22 29 27 3e 73 68 6f 77 3c 2f 62 75  1088")'>show</bu
1950: 74 74 6f 6e 3e 3c 2f 70 3e 0a 20 3c 62 6c 6f 63  tton></p>. <bloc
1960: 6b 71 75 6f 74 65 20 69 64 3d 27 78 31 30 38 38  kquote id='x1088
1970: 27 20 73 74 79 6c 65 3d 27 64 69 73 70 6c 61 79  ' style='display
1980: 3a 6e 6f 6e 65 3b 27 3e 0a 20 3c 69 6d 67 20 61  :none;'>. <img a
1990: 6c 74 3d 22 73 79 6e 74 61 78 20 64 69 61 67 72  lt="syntax diagr
19a0: 61 6d 20 6a 6f 69 6e 2d 6f 70 65 72 61 74 6f 72  am join-operator
19b0: 22 20 73 72 63 3d 22 69 6d 61 67 65 73 2f 73 79  " src="images/sy
19c0: 6e 74 61 78 2f 6a 6f 69 6e 2d 6f 70 65 72 61 74  ntax/join-operat
19d0: 6f 72 2e 67 69 66 22 20 2f 3e 0a 3c 2f 62 6c 6f  or.gif" />.</blo
19e0: 63 6b 71 75 6f 74 65 3e 0a 3c 2f 62 6c 6f 63 6b  ckquote>.</block
19f0: 71 75 6f 74 65 3e 0a 3c 70 3e 3c 62 3e 3c 61 20  quote>.<p><b><a 
1a00: 68 72 65 66 3d 22 73 79 6e 74 61 78 64 69 61 67  href="syntaxdiag
1a10: 72 61 6d 73 2e 68 74 6d 6c 23 6f 72 64 65 72 69  rams.html#orderi
1a20: 6e 67 2d 74 65 72 6d 22 3e 6f 72 64 65 72 69 6e  ng-term">orderin
1a30: 67 2d 74 65 72 6d 3a 3c 2f 61 3e 3c 2f 62 3e 0a  g-term:</a></b>.
1a40: 3c 62 75 74 74 6f 6e 20 69 64 3d 27 78 31 30 38  <button id='x108
1a50: 39 27 20 6f 6e 63 6c 69 63 6b 3d 27 68 69 64 65  9' onclick='hide
1a60: 6f 72 73 68 6f 77 28 22 78 31 30 38 39 22 2c 22  orshow("x1089","
1a70: 78 31 30 39 30 22 29 27 3e 73 68 6f 77 3c 2f 62  x1090")'>show</b
1a80: 75 74 74 6f 6e 3e 3c 2f 70 3e 0a 20 3c 62 6c 6f  utton></p>. <blo
1a90: 63 6b 71 75 6f 74 65 20 69 64 3d 27 78 31 30 39  ckquote id='x109
1aa0: 30 27 20 73 74 79 6c 65 3d 27 64 69 73 70 6c 61  0' style='displa
1ab0: 79 3a 6e 6f 6e 65 3b 27 3e 0a 20 3c 69 6d 67 20  y:none;'>. <img 
1ac0: 61 6c 74 3d 22 73 79 6e 74 61 78 20 64 69 61 67  alt="syntax diag
1ad0: 72 61 6d 20 6f 72 64 65 72 69 6e 67 2d 74 65 72  ram ordering-ter
1ae0: 6d 22 20 73 72 63 3d 22 69 6d 61 67 65 73 2f 73  m" src="images/s
1af0: 79 6e 74 61 78 2f 6f 72 64 65 72 69 6e 67 2d 74  yntax/ordering-t
1b00: 65 72 6d 2e 67 69 66 22 20 2f 3e 0a 3c 2f 62 6c  erm.gif" />.</bl
1b10: 6f 63 6b 71 75 6f 74 65 3e 0a 3c 70 3e 3c 62 3e  ockquote>.<p><b>
1b20: 3c 61 20 68 72 65 66 3d 22 73 79 6e 74 61 78 64  <a href="syntaxd
1b30: 69 61 67 72 61 6d 73 2e 68 74 6d 6c 23 72 65 73  iagrams.html#res
1b40: 75 6c 74 2d 63 6f 6c 75 6d 6e 22 3e 72 65 73 75  ult-column">resu
1b50: 6c 74 2d 63 6f 6c 75 6d 6e 3a 3c 2f 61 3e 3c 2f  lt-column:</a></
1b60: 62 3e 0a 3c 62 75 74 74 6f 6e 20 69 64 3d 27 78  b>.<button id='x
1b70: 31 30 39 31 27 20 6f 6e 63 6c 69 63 6b 3d 27 68  1091' onclick='h
1b80: 69 64 65 6f 72 73 68 6f 77 28 22 78 31 30 39 31  ideorshow("x1091
1b90: 22 2c 22 78 31 30 39 32 22 29 27 3e 73 68 6f 77  ","x1092")'>show
1ba0: 3c 2f 62 75 74 74 6f 6e 3e 3c 2f 70 3e 0a 20 3c  </button></p>. <
1bb0: 62 6c 6f 63 6b 71 75 6f 74 65 20 69 64 3d 27 78  blockquote id='x
1bc0: 31 30 39 32 27 20 73 74 79 6c 65 3d 27 64 69 73  1092' style='dis
1bd0: 70 6c 61 79 3a 6e 6f 6e 65 3b 27 3e 0a 20 3c 69  play:none;'>. <i
1be0: 6d 67 20 61 6c 74 3d 22 73 79 6e 74 61 78 20 64  mg alt="syntax d
1bf0: 69 61 67 72 61 6d 20 72 65 73 75 6c 74 2d 63 6f  iagram result-co
1c00: 6c 75 6d 6e 22 20 73 72 63 3d 22 69 6d 61 67 65  lumn" src="image
1c10: 73 2f 73 79 6e 74 61 78 2f 72 65 73 75 6c 74 2d  s/syntax/result-
1c20: 63 6f 6c 75 6d 6e 2e 67 69 66 22 20 2f 3e 0a 3c  column.gif" />.<
1c30: 2f 62 6c 6f 63 6b 71 75 6f 74 65 3e 0a 3c 70 3e  /blockquote>.<p>
1c40: 3c 62 3e 3c 61 20 68 72 65 66 3d 22 73 79 6e 74  <b><a href="synt
1c50: 61 78 64 69 61 67 72 61 6d 73 2e 68 74 6d 6c 23  axdiagrams.html#
1c60: 74 61 62 6c 65 2d 6f 72 2d 73 75 62 71 75 65 72  table-or-subquer
1c70: 79 22 3e 74 61 62 6c 65 2d 6f 72 2d 73 75 62 71  y">table-or-subq
1c80: 75 65 72 79 3a 3c 2f 61 3e 3c 2f 62 3e 0a 3c 62  uery:</a></b>.<b
1c90: 75 74 74 6f 6e 20 69 64 3d 27 78 31 30 39 33 27  utton id='x1093'
1ca0: 20 6f 6e 63 6c 69 63 6b 3d 27 68 69 64 65 6f 72   onclick='hideor
1cb0: 73 68 6f 77 28 22 78 31 30 39 33 22 2c 22 78 31  show("x1093","x1
1cc0: 30 39 34 22 29 27 3e 73 68 6f 77 3c 2f 62 75 74  094")'>show</but
1cd0: 74 6f 6e 3e 3c 2f 70 3e 0a 20 3c 62 6c 6f 63 6b  ton></p>. <block
1ce0: 71 75 6f 74 65 20 69 64 3d 27 78 31 30 39 34 27  quote id='x1094'
1cf0: 20 73 74 79 6c 65 3d 27 64 69 73 70 6c 61 79 3a   style='display:
1d00: 6e 6f 6e 65 3b 27 3e 0a 20 3c 69 6d 67 20 61 6c  none;'>. <img al
1d10: 74 3d 22 73 79 6e 74 61 78 20 64 69 61 67 72 61  t="syntax diagra
1d20: 6d 20 74 61 62 6c 65 2d 6f 72 2d 73 75 62 71 75  m table-or-subqu
1d30: 65 72 79 22 20 73 72 63 3d 22 69 6d 61 67 65 73  ery" src="images
1d40: 2f 73 79 6e 74 61 78 2f 74 61 62 6c 65 2d 6f 72  /syntax/table-or
1d50: 2d 73 75 62 71 75 65 72 79 2e 67 69 66 22 20 2f  -subquery.gif" /
1d60: 3e 0a 3c 2f 62 6c 6f 63 6b 71 75 6f 74 65 3e 0a  >.</blockquote>.
1d70: 3c 2f 62 6c 6f 63 6b 71 75 6f 74 65 3e 0a 3c 70  </blockquote>.<p
1d80: 3e 3c 62 3e 3c 61 20 68 72 65 66 3d 22 73 79 6e  ><b><a href="syn
1d90: 74 61 78 64 69 61 67 72 61 6d 73 2e 68 74 6d 6c  taxdiagrams.html
1da0: 23 74 79 70 65 2d 6e 61 6d 65 22 3e 74 79 70 65  #type-name">type
1db0: 2d 6e 61 6d 65 3a 3c 2f 61 3e 3c 2f 62 3e 0a 3c  -name:</a></b>.<
1dc0: 62 75 74 74 6f 6e 20 69 64 3d 27 78 31 30 39 35  button id='x1095
1dd0: 27 20 6f 6e 63 6c 69 63 6b 3d 27 68 69 64 65 6f  ' onclick='hideo
1de0: 72 73 68 6f 77 28 22 78 31 30 39 35 22 2c 22 78  rshow("x1095","x
1df0: 31 30 39 36 22 29 27 3e 73 68 6f 77 3c 2f 62 75  1096")'>show</bu
1e00: 74 74 6f 6e 3e 3c 2f 70 3e 0a 20 3c 62 6c 6f 63  tton></p>. <bloc
1e10: 6b 71 75 6f 74 65 20 69 64 3d 27 78 31 30 39 36  kquote id='x1096
1e20: 27 20 73 74 79 6c 65 3d 27 64 69 73 70 6c 61 79  ' style='display
1e30: 3a 6e 6f 6e 65 3b 27 3e 0a 20 3c 69 6d 67 20 61  :none;'>. <img a
1e40: 6c 74 3d 22 73 79 6e 74 61 78 20 64 69 61 67 72  lt="syntax diagr
1e50: 61 6d 20 74 79 70 65 2d 6e 61 6d 65 22 20 73 72  am type-name" sr
1e60: 63 3d 22 69 6d 61 67 65 73 2f 73 79 6e 74 61 78  c="images/syntax
1e70: 2f 74 79 70 65 2d 6e 61 6d 65 2e 67 69 66 22 20  /type-name.gif" 
1e80: 2f 3e 0a 3c 70 3e 3c 62 3e 3c 61 20 68 72 65 66  />.<p><b><a href
1e90: 3d 22 73 79 6e 74 61 78 64 69 61 67 72 61 6d 73  ="syntaxdiagrams
1ea0: 2e 68 74 6d 6c 23 73 69 67 6e 65 64 2d 6e 75 6d  .html#signed-num
1eb0: 62 65 72 22 3e 73 69 67 6e 65 64 2d 6e 75 6d 62  ber">signed-numb
1ec0: 65 72 3a 3c 2f 61 3e 3c 2f 62 3e 0a 3c 62 75 74  er:</a></b>.<but
1ed0: 74 6f 6e 20 69 64 3d 27 78 31 30 39 37 27 20 6f  ton id='x1097' o
1ee0: 6e 63 6c 69 63 6b 3d 27 68 69 64 65 6f 72 73 68  nclick='hideorsh
1ef0: 6f 77 28 22 78 31 30 39 37 22 2c 22 78 31 30 39  ow("x1097","x109
1f00: 38 22 29 27 3e 73 68 6f 77 3c 2f 62 75 74 74 6f  8")'>show</butto
1f10: 6e 3e 3c 2f 70 3e 0a 20 3c 62 6c 6f 63 6b 71 75  n></p>. <blockqu
1f20: 6f 74 65 20 69 64 3d 27 78 31 30 39 38 27 20 73  ote id='x1098' s
1f30: 74 79 6c 65 3d 27 64 69 73 70 6c 61 79 3a 6e 6f  tyle='display:no
1f40: 6e 65 3b 27 3e 0a 20 3c 69 6d 67 20 61 6c 74 3d  ne;'>. <img alt=
1f50: 22 73 79 6e 74 61 78 20 64 69 61 67 72 61 6d 20  "syntax diagram 
1f60: 73 69 67 6e 65 64 2d 6e 75 6d 62 65 72 22 20 73  signed-number" s
1f70: 72 63 3d 22 69 6d 61 67 65 73 2f 73 79 6e 74 61  rc="images/synta
1f80: 78 2f 73 69 67 6e 65 64 2d 6e 75 6d 62 65 72 2e  x/signed-number.
1f90: 67 69 66 22 20 2f 3e 0a 3c 2f 62 6c 6f 63 6b 71  gif" />.</blockq
1fa0: 75 6f 74 65 3e 0a 3c 2f 62 6c 6f 63 6b 71 75 6f  uote>.</blockquo
1fb0: 74 65 3e 0a 3c 2f 62 6c 6f 63 6b 71 75 6f 74 65  te>.</blockquote
1fc0: 3e 0a 0a 0a 3c 70 3e 54 68 69 73 20 73 65 63 74  >...<p>This sect
1fd0: 69 6f 6e 20 69 73 20 64 69 66 66 65 72 65 6e 74  ion is different
1fe0: 20 66 72 6f 6d 20 74 68 65 20 6f 74 68 65 72 73   from the others
1ff0: 2e 20 20 4d 6f 73 74 20 6f 74 68 65 72 20 73 65  .  Most other se
2000: 63 74 69 6f 6e 73 20 6f 66 0a 74 68 69 73 20 64  ctions of.this d
2010: 6f 63 75 6d 65 6e 74 20 74 61 6c 6b 73 20 61 62  ocument talks ab
2020: 6f 75 74 20 61 20 70 61 72 74 69 63 75 6c 61 72  out a particular
2030: 20 53 51 4c 20 63 6f 6d 6d 61 6e 64 2e 20 20 54   SQL command.  T
2040: 68 69 73 20 73 65 63 74 69 6f 6e 20 64 6f 65 73  his section does
2050: 0a 6e 6f 74 20 74 61 6c 6b 20 61 62 6f 75 74 20  .not talk about 
2060: 61 20 73 74 61 6e 64 61 6c 6f 6e 65 20 63 6f 6d  a standalone com
2070: 6d 61 6e 64 20 62 75 74 20 61 62 6f 75 74 20 22  mand but about "
2080: 65 78 70 72 65 73 73 69 6f 6e 73 22 20 77 68 69  expressions" whi
2090: 63 68 20 61 72 65 20 0a 73 75 62 63 6f 6d 70 6f  ch are .subcompo
20a0: 6e 65 6e 74 73 20 6f 66 20 6d 6f 73 74 20 6f 74  nents of most ot
20b0: 68 65 72 20 63 6f 6d 6d 61 6e 64 73 2e 3c 2f 70  her commands.</p
20c0: 3e 0a 0a 3c 61 20 6e 61 6d 65 3d 22 62 69 6e 61  >..<a name="bina
20d0: 72 79 6f 70 73 22 3e 3c 2f 61 3e 0a 0a 3c 68 33  ryops"></a>..<h3
20e0: 3e 4f 70 65 72 61 74 6f 72 73 3c 2f 68 33 3e 0a  >Operators</h3>.
20f0: 3c 70 3e 53 51 4c 69 74 65 20 75 6e 64 65 72 73  <p>SQLite unders
2100: 74 61 6e 64 73 20 74 68 65 20 66 6f 6c 6c 6f 77  tands the follow
2110: 69 6e 67 20 62 69 6e 61 72 79 20 6f 70 65 72 61  ing binary opera
2120: 74 6f 72 73 2c 20 69 6e 20 6f 72 64 65 72 20 66  tors, in order f
2130: 72 6f 6d 0a 68 69 67 68 65 73 74 20 74 6f 20 6c  rom.highest to l
2140: 6f 77 65 73 74 20 70 72 65 63 65 64 65 6e 63 65  owest precedence
2150: 3a 3c 2f 70 3e 0a 0a 3c 62 6c 6f 63 6b 71 75 6f  :</p>..<blockquo
2160: 74 65 3e 3c 70 72 65 3e 0a 3c 66 6f 6e 74 20 63  te><pre>.<font c
2170: 6f 6c 6f 72 3d 22 23 32 63 32 63 66 30 22 3e 3c  olor="#2c2cf0"><
2180: 62 69 67 3e 7c 7c 0a 2a 20 20 20 20 2f 20 20 20  big>||.*    /   
2190: 20 25 0a 2b 20 20 20 20 2d 0a 26 6c 74 3b 26 6c   %.+    -.&lt;&l
21a0: 74 3b 20 20 20 26 67 74 3b 26 67 74 3b 20 20 20  t;   &gt;&gt;   
21b0: 26 61 6d 70 3b 20 20 20 20 7c 0a 26 6c 74 3b 20  &amp;    |.&lt; 
21c0: 20 20 20 26 6c 74 3b 3d 20 20 20 26 67 74 3b 20     &lt;=   &gt; 
21d0: 20 20 20 26 67 74 3b 3d 0a 3d 20 20 20 20 3d 3d     &gt;=.=    ==
21e0: 20 20 20 21 3d 20 20 20 26 6c 74 3b 26 67 74 3b     !=   &lt;&gt;
21f0: 20 20 20 3c 2f 62 69 67 3e 49 53 20 20 20 49 53     </big>IS   IS
2200: 20 4e 4f 54 20 20 20 49 4e 20 20 20 4c 49 4b 45   NOT   IN   LIKE
2210: 20 20 20 47 4c 4f 42 20 20 20 4d 41 54 43 48 20     GLOB   MATCH 
2220: 20 20 52 45 47 45 58 50 0a 41 4e 44 20 20 20 0a    REGEXP.AND   .
2230: 4f 52 3c 2f 66 6f 6e 74 3e 0a 3c 2f 70 72 65 3e  OR</font>.</pre>
2240: 3c 2f 62 6c 6f 63 6b 71 75 6f 74 65 3e 0a 0a 3c  </blockquote>..<
2250: 70 3e 53 75 70 70 6f 72 74 65 64 20 75 6e 61 72  p>Supported unar
2260: 79 20 70 72 65 66 69 78 20 6f 70 65 72 61 74 6f  y prefix operato
2270: 72 73 20 61 72 65 20 74 68 65 73 65 3a 3c 2f 70  rs are these:</p
2280: 3e 0a 0a 3c 62 6c 6f 63 6b 71 75 6f 74 65 3e 3c  >..<blockquote><
2290: 70 72 65 3e 0a 3c 66 6f 6e 74 20 63 6f 6c 6f 72  pre>.<font color
22a0: 3d 22 23 32 63 32 63 66 30 22 3e 3c 62 69 67 3e  ="#2c2cf0"><big>
22b0: 2d 20 20 20 20 2b 20 20 20 20 7e 20 20 20 20 4e  -    +    ~    N
22c0: 4f 54 3c 2f 62 69 67 3e 3c 2f 66 6f 6e 74 3e 0a  OT</big></font>.
22d0: 3c 2f 70 72 65 3e 3c 2f 62 6c 6f 63 6b 71 75 6f  </pre></blockquo
22e0: 74 65 3e 0a 0a 3c 61 20 6e 61 6d 65 3d 22 63 6f  te>..<a name="co
22f0: 6c 6c 61 74 65 6f 70 22 3e 3c 2f 61 3e 0a 0a 3c  llateop"></a>..<
2300: 70 3e 54 68 65 20 43 4f 4c 4c 41 54 45 20 6f 70  p>The COLLATE op
2310: 65 72 61 74 6f 72 20 69 73 20 61 20 75 6e 61 72  erator is a unar
2320: 79 20 70 6f 73 74 66 69 78 0a 6f 70 65 72 61 74  y postfix.operat
2330: 6f 72 20 74 68 61 74 20 61 73 73 69 67 6e 73 20  or that assigns 
2340: 61 20 3c 61 20 68 72 65 66 3d 22 64 61 74 61 74  a <a href="datat
2350: 79 70 65 33 2e 68 74 6d 6c 23 63 6f 6c 6c 61 74  ype3.html#collat
2360: 69 6f 6e 22 3e 63 6f 6c 6c 61 74 69 6e 67 20 73  ion">collating s
2370: 65 71 75 65 6e 63 65 3c 2f 61 3e 20 74 6f 20 61  equence</a> to a
2380: 6e 20 65 78 70 72 65 73 73 69 6f 6e 2e 0a 54 68  n expression..Th
2390: 65 20 43 4f 4c 4c 41 54 45 20 6f 70 65 72 61 74  e COLLATE operat
23a0: 6f 72 20 68 61 73 20 61 20 68 69 67 68 65 72 20  or has a higher 
23b0: 70 72 65 63 65 64 65 6e 63 65 20 28 62 69 6e 64  precedence (bind
23c0: 73 20 6d 6f 72 65 20 74 69 67 68 74 6c 79 29 20  s more tightly) 
23d0: 74 68 61 6e 20 61 6e 79 0a 62 69 6e 61 72 79 20  than any.binary 
23e0: 6f 70 65 72 61 74 6f 72 20 61 6e 64 20 61 6e 79  operator and any
23f0: 20 75 6e 61 72 79 20 70 72 65 66 69 78 20 6f 70   unary prefix op
2400: 65 72 61 74 6f 72 20 65 78 63 65 70 74 20 22 7e  erator except "~
2410: 22 2e 0a 28 43 4f 4c 4c 41 54 45 20 61 6e 64 20  "..(COLLATE and 
2420: 22 7e 22 20 61 72 65 20 61 73 73 6f 63 69 61 74  "~" are associat
2430: 69 76 65 20 73 6f 20 74 68 65 69 72 20 62 69 6e  ive so their bin
2440: 64 69 6e 67 20 6f 72 64 65 72 20 64 6f 65 73 20  ding order does 
2450: 6e 6f 74 20 6d 61 74 74 65 72 2e 29 0a 54 68 65  not matter.).The
2460: 20 63 6f 6c 6c 61 74 69 6e 67 20 73 65 71 75 65   collating seque
2470: 6e 63 65 20 73 65 74 20 62 79 20 74 68 65 20 43  nce set by the C
2480: 4f 4c 4c 41 54 45 20 6f 70 65 72 61 74 6f 72 20  OLLATE operator 
2490: 6f 76 65 72 72 69 64 65 73 20 74 68 65 0a 63 6f  overrides the.co
24a0: 6c 6c 61 74 69 6e 67 20 73 65 71 75 65 6e 63 65  llating sequence
24b0: 20 64 65 74 65 72 6d 69 6e 65 64 20 62 79 20 74   determined by t
24c0: 68 65 20 43 4f 4c 4c 41 54 45 20 63 6c 61 75 73  he COLLATE claus
24d0: 65 20 69 6e 20 61 20 74 61 62 6c 65 0a 3c 61 20  e in a table.<a 
24e0: 68 72 65 66 3d 22 6c 61 6e 67 5f 63 72 65 61 74  href="lang_creat
24f0: 65 74 61 62 6c 65 2e 68 74 6d 6c 23 74 61 62 6c  etable.html#tabl
2500: 65 63 6f 6c 64 65 66 22 3e 63 6f 6c 75 6d 6e 20  ecoldef">column 
2510: 64 65 66 69 6e 69 74 69 6f 6e 3c 2f 61 3e 2e 0a  definition</a>..
2520: 53 65 65 20 74 68 65 20 3c 61 20 68 72 65 66 3d  See the <a href=
2530: 22 64 61 74 61 74 79 70 65 33 2e 68 74 6d 6c 23  "datatype3.html#
2540: 63 6f 6c 6c 61 74 69 6f 6e 22 3e 64 65 74 61 69  collation">detai
2550: 6c 65 64 20 64 69 73 63 75 73 73 69 6f 6e 20 6f  led discussion o
2560: 6e 20 63 6f 6c 6c 61 74 69 6e 67 20 73 65 71 75  n collating sequ
2570: 65 6e 63 65 73 3c 2f 61 3e 0a 69 6e 20 74 68 65  ences</a>.in the
2580: 20 3c 61 20 68 72 65 66 3d 22 64 61 74 61 74 79   <a href="dataty
2590: 70 65 33 2e 68 74 6d 6c 22 3e 44 61 74 61 74 79  pe3.html">Dataty
25a0: 70 65 20 49 6e 20 53 51 4c 69 74 65 33 3c 2f 61  pe In SQLite3</a
25b0: 3e 20 64 6f 63 75 6d 65 6e 74 20 66 6f 72 20 61  > document for a
25c0: 64 64 69 74 69 6f 6e 61 6c 20 69 6e 66 6f 72 6d  dditional inform
25d0: 61 74 69 6f 6e 2e 0a 3c 2f 70 3e 0a 0a 0a 3c 70  ation..</p>...<p
25e0: 3e 54 68 65 20 75 6e 61 72 79 20 6f 70 65 72 61  >The unary opera
25f0: 74 6f 72 20 3c 66 6f 6e 74 20 63 6f 6c 6f 72 3d  tor <font color=
2600: 22 23 32 63 32 63 66 30 22 3e 3c 62 69 67 3e 2b  "#2c2cf0"><big>+
2610: 3c 2f 62 69 67 3e 3c 2f 66 6f 6e 74 3e 20 69 73  </big></font> is
2620: 20 61 20 6e 6f 2d 6f 70 2e 20 20 49 74 20 63 61   a no-op.  It ca
2630: 6e 20 62 65 20 61 70 70 6c 69 65 64 0a 74 6f 20  n be applied.to 
2640: 73 74 72 69 6e 67 73 2c 20 6e 75 6d 62 65 72 73  strings, numbers
2650: 2c 20 62 6c 6f 62 73 20 6f 72 20 4e 55 4c 4c 20  , blobs or NULL 
2660: 61 6e 64 20 69 74 20 61 6c 77 61 79 73 20 72 65  and it always re
2670: 74 75 72 6e 73 20 61 20 72 65 73 75 6c 74 0a 77  turns a result.w
2680: 69 74 68 20 74 68 65 20 73 61 6d 65 20 76 61 6c  ith the same val
2690: 75 65 20 61 73 20 74 68 65 20 6f 70 65 72 61 6e  ue as the operan
26a0: 64 2e 3c 2f 70 3e 0a 0a 3c 70 3e 4e 6f 74 65 20  d.</p>..<p>Note 
26b0: 74 68 61 74 20 74 68 65 72 65 20 61 72 65 20 74  that there are t
26c0: 77 6f 20 76 61 72 69 61 74 69 6f 6e 73 20 6f 66  wo variations of
26d0: 20 74 68 65 20 65 71 75 61 6c 73 20 61 6e 64 20   the equals and 
26e0: 6e 6f 74 20 65 71 75 61 6c 73 0a 6f 70 65 72 61  not equals.opera
26f0: 74 6f 72 73 2e 20 20 45 71 75 61 6c 73 20 63 61  tors.  Equals ca
2700: 6e 20 62 65 20 65 69 74 68 65 72 0a 0a 3c 66 6f  n be either..<fo
2710: 6e 74 20 63 6f 6c 6f 72 3d 22 23 32 63 32 63 66  nt color="#2c2cf
2720: 30 22 3e 3c 62 69 67 3e 3d 3c 2f 62 69 67 3e 3c  0"><big>=</big><
2730: 2f 66 6f 6e 74 3e 20 6f 72 20 3c 66 6f 6e 74 20  /font> or <font 
2740: 63 6f 6c 6f 72 3d 22 23 32 63 32 63 66 30 22 3e  color="#2c2cf0">
2750: 3c 62 69 67 3e 3d 3d 3c 2f 62 69 67 3e 3c 2f 66  <big>==</big></f
2760: 6f 6e 74 3e 2e 0a 54 68 65 20 6e 6f 6e 2d 65 71  ont>..The non-eq
2770: 75 61 6c 73 20 6f 70 65 72 61 74 6f 72 20 63 61  uals operator ca
2780: 6e 20 62 65 20 65 69 74 68 65 72 0a 3c 66 6f 6e  n be either.<fon
2790: 74 20 63 6f 6c 6f 72 3d 22 23 32 63 32 63 66 30  t color="#2c2cf0
27a0: 22 3e 3c 62 69 67 3e 21 3d 3c 2f 62 69 67 3e 3c  "><big>!=</big><
27b0: 2f 66 6f 6e 74 3e 20 6f 72 20 3c 66 6f 6e 74 20  /font> or <font 
27c0: 63 6f 6c 6f 72 3d 22 23 32 63 32 63 66 30 22 3e  color="#2c2cf0">
27d0: 3c 62 69 67 3e 26 6c 74 3b 26 67 74 3b 3c 2f 62  <big>&lt;&gt;</b
27e0: 69 67 3e 3c 2f 66 6f 6e 74 3e 2e 0a 54 68 65 20  ig></font>..The 
27f0: 3c 66 6f 6e 74 20 63 6f 6c 6f 72 3d 22 23 32 63  <font color="#2c
2800: 32 63 66 30 22 3e 3c 62 69 67 3e 7c 7c 3c 2f 62  2cf0"><big>||</b
2810: 69 67 3e 3c 2f 66 6f 6e 74 3e 20 6f 70 65 72 61  ig></font> opera
2820: 74 6f 72 20 69 73 20 22 63 6f 6e 63 61 74 65 6e  tor is "concaten
2830: 61 74 65 22 20 2d 20 69 74 20 6a 6f 69 6e 73 20  ate" - it joins 
2840: 74 6f 67 65 74 68 65 72 0a 74 68 65 20 74 77 6f  together.the two
2850: 20 73 74 72 69 6e 67 73 20 6f 66 20 69 74 73 20   strings of its 
2860: 6f 70 65 72 61 6e 64 73 2e 0a 54 68 65 20 6f 70  operands..The op
2870: 65 72 61 74 6f 72 20 3c 66 6f 6e 74 20 63 6f 6c  erator <font col
2880: 6f 72 3d 22 23 32 63 32 63 66 30 22 3e 3c 62 69  or="#2c2cf0"><bi
2890: 67 3e 25 3c 2f 62 69 67 3e 3c 2f 66 6f 6e 74 3e  g>%</big></font>
28a0: 20 6f 75 74 70 75 74 73 20 74 68 65 20 76 61 6c   outputs the val
28b0: 75 65 20 6f 66 20 69 74 73 20 6c 65 66 74 20 0a  ue of its left .
28c0: 6f 70 65 72 61 6e 64 20 6d 6f 64 75 6c 6f 20 69  operand modulo i
28d0: 74 73 20 72 69 67 68 74 20 6f 70 65 72 61 6e 64  ts right operand
28e0: 2e 3c 2f 70 3e 0a 0a 3c 70 3e 54 68 65 20 72 65  .</p>..<p>The re
28f0: 73 75 6c 74 20 6f 66 20 61 6e 79 20 62 69 6e 61  sult of any bina
2900: 72 79 20 6f 70 65 72 61 74 6f 72 20 69 73 20 65  ry operator is e
2910: 69 74 68 65 72 20 61 20 6e 75 6d 65 72 69 63 20  ither a numeric 
2920: 76 61 6c 75 65 20 6f 72 20 0a 4e 55 4c 4c 2c 20  value or .NULL, 
2930: 65 78 63 65 70 74 20 66 6f 72 20 74 68 65 20 3c  except for the <
2940: 66 6f 6e 74 20 63 6f 6c 6f 72 3d 22 23 32 63 32  font color="#2c2
2950: 63 66 30 22 3e 3c 62 69 67 3e 7c 7c 3c 2f 62 69  cf0"><big>||</bi
2960: 67 3e 3c 2f 66 6f 6e 74 3e 20 63 6f 6e 63 61 74  g></font> concat
2970: 65 6e 61 74 69 6f 6e 20 6f 70 65 72 61 74 6f 72  enation operator
2980: 20 77 68 69 63 68 20 61 6c 77 61 79 73 20 0a 65   which always .e
2990: 76 61 6c 75 61 74 65 73 20 74 6f 20 65 69 74 68  valuates to eith
29a0: 65 72 20 4e 55 4c 4c 20 6f 72 20 61 20 74 65 78  er NULL or a tex
29b0: 74 20 76 61 6c 75 65 2e 3c 2f 70 3e 3c 61 20 6e  t value.</p><a n
29c0: 61 6d 65 3d 22 69 73 69 73 6e 6f 74 22 3e 3c 2f  ame="isisnot"></
29d0: 61 3e 0a 3c 70 3e 54 68 65 20 3c 66 6f 6e 74 20  a>.<p>The <font 
29e0: 63 6f 6c 6f 72 3d 22 23 32 63 32 63 66 30 22 3e  color="#2c2cf0">
29f0: 3c 62 69 67 3e 49 53 3c 2f 62 69 67 3e 3c 2f 66  <big>IS</big></f
2a00: 6f 6e 74 3e 20 61 6e 64 20 3c 66 6f 6e 74 20 63  ont> and <font c
2a10: 6f 6c 6f 72 3d 22 23 32 63 32 63 66 30 22 3e 3c  olor="#2c2cf0"><
2a20: 62 69 67 3e 49 53 20 4e 4f 54 3c 2f 62 69 67 3e  big>IS NOT</big>
2a30: 3c 2f 66 6f 6e 74 3e 20 6f 70 65 72 61 74 6f 72  </font> operator
2a40: 73 20 77 6f 72 6b 0a 6c 69 6b 65 20 3c 66 6f 6e  s work.like <fon
2a50: 74 20 63 6f 6c 6f 72 3d 22 23 32 63 32 63 66 30  t color="#2c2cf0
2a60: 22 3e 3c 62 69 67 3e 3d 3c 2f 62 69 67 3e 3c 2f  "><big>=</big></
2a70: 66 6f 6e 74 3e 20 61 6e 64 20 3c 66 6f 6e 74 20  font> and <font 
2a80: 63 6f 6c 6f 72 3d 22 23 32 63 32 63 66 30 22 3e  color="#2c2cf0">
2a90: 3c 62 69 67 3e 21 3d 3c 2f 62 69 67 3e 3c 2f 66  <big>!=</big></f
2aa0: 6f 6e 74 3e 20 65 78 63 65 70 74 20 77 68 65 6e  ont> except when
2ab0: 20 6f 6e 65 20 6f 72 20 62 6f 74 68 20 6f 66 20   one or both of 
2ac0: 74 68 65 0a 6f 70 65 72 61 6e 64 73 20 61 72 65  the.operands are
2ad0: 20 4e 55 4c 4c 2e 20 49 6e 20 74 68 69 73 20 63   NULL. In this c
2ae0: 61 73 65 2c 20 69 66 20 62 6f 74 68 20 6f 70 65  ase, if both ope
2af0: 72 61 6e 64 73 20 61 72 65 20 4e 55 4c 4c 2c 20  rands are NULL, 
2b00: 74 68 65 6e 20 74 68 65 0a 49 53 20 6f 70 65 72  then the.IS oper
2b10: 61 74 6f 72 20 65 76 61 6c 75 61 74 65 73 20 74  ator evaluates t
2b20: 6f 20 31 20 28 74 72 75 65 29 20 61 6e 64 20 74  o 1 (true) and t
2b30: 68 65 20 49 53 20 4e 4f 54 20 6f 70 65 72 61 74  he IS NOT operat
2b40: 6f 72 20 65 76 61 6c 75 61 74 65 73 0a 74 6f 20  or evaluates.to 
2b50: 30 20 28 66 61 6c 73 65 29 2e 20 49 66 20 6f 6e  0 (false). If on
2b60: 65 20 6f 70 65 72 61 6e 64 20 69 73 20 4e 55 4c  e operand is NUL
2b70: 4c 20 61 6e 64 20 74 68 65 20 6f 74 68 65 72 20  L and the other 
2b80: 69 73 20 6e 6f 74 2c 20 74 68 65 6e 20 74 68 65  is not, then the
2b90: 0a 49 53 20 6f 70 65 72 61 74 6f 72 20 65 76 61  .IS operator eva
2ba0: 6c 75 61 74 65 73 20 74 6f 20 30 20 28 66 61 6c  luates to 0 (fal
2bb0: 73 65 29 20 61 6e 64 20 74 68 65 20 49 53 20 4e  se) and the IS N
2bc0: 4f 54 20 6f 70 65 72 61 74 6f 72 20 69 73 20 31  OT operator is 1
2bd0: 20 28 74 72 75 65 29 2e 0a 49 74 20 69 73 20 6e   (true)..It is n
2be0: 6f 74 20 70 6f 73 73 69 62 6c 65 20 66 6f 72 20  ot possible for 
2bf0: 61 6e 20 49 53 20 6f 72 20 49 53 20 4e 4f 54 20  an IS or IS NOT 
2c00: 65 78 70 72 65 73 73 69 6f 6e 20 74 6f 20 65 76  expression to ev
2c10: 61 6c 75 61 74 65 20 74 6f 20 4e 55 4c 4c 2e 0a  aluate to NULL..
2c20: 4f 70 65 72 61 74 6f 72 73 20 3c 66 6f 6e 74 20  Operators <font 
2c30: 63 6f 6c 6f 72 3d 22 23 32 63 32 63 66 30 22 3e  color="#2c2cf0">
2c40: 3c 62 69 67 3e 49 53 3c 2f 62 69 67 3e 3c 2f 66  <big>IS</big></f
2c50: 6f 6e 74 3e 20 61 6e 64 20 3c 66 6f 6e 74 20 63  ont> and <font c
2c60: 6f 6c 6f 72 3d 22 23 32 63 32 63 66 30 22 3e 3c  olor="#2c2cf0"><
2c70: 62 69 67 3e 49 53 20 4e 4f 54 3c 2f 62 69 67 3e  big>IS NOT</big>
2c80: 3c 2f 66 6f 6e 74 3e 20 68 61 76 65 20 74 68 65  </font> have the
2c90: 20 73 61 6d 65 20 0a 70 72 65 63 65 64 65 6e 63   same .precedenc
2ca0: 65 20 61 73 20 3c 66 6f 6e 74 20 63 6f 6c 6f 72  e as <font color
2cb0: 3d 22 23 32 63 32 63 66 30 22 3e 3c 62 69 67 3e  ="#2c2cf0"><big>
2cc0: 3d 3c 2f 62 69 67 3e 3c 2f 66 6f 6e 74 3e 2e 3c  =</big></font>.<
2cd0: 61 20 6e 61 6d 65 3d 22 6c 69 74 76 61 6c 75 65  a name="litvalue
2ce0: 22 3e 3c 2f 61 3e 0a 0a 3c 68 33 3e 4c 69 74 65  "></a>..<h3>Lite
2cf0: 72 61 6c 20 56 61 6c 75 65 73 20 28 43 6f 6e 73  ral Values (Cons
2d00: 74 61 6e 74 73 29 3c 2f 68 33 3e 0a 3c 70 3e 0a  tants)</h3>.<p>.
2d10: 41 20 6c 69 74 65 72 61 6c 20 76 61 6c 75 65 20  A literal value 
2d20: 72 65 70 72 65 73 65 6e 74 73 20 61 20 63 6f 6e  represents a con
2d30: 73 74 61 6e 74 2e 0a 4c 69 74 65 72 61 6c 20 76  stant..Literal v
2d40: 61 6c 75 65 73 20 6d 61 79 20 62 65 20 69 6e 74  alues may be int
2d50: 65 67 65 72 73 2c 20 66 6c 6f 61 74 69 6e 67 20  egers, floating 
2d60: 70 6f 69 6e 74 20 6e 75 6d 62 65 72 73 2c 20 73  point numbers, s
2d70: 74 72 69 6e 67 73 2c 0a 42 4c 4f 42 73 2c 20 6f  trings,.BLOBs, o
2d80: 72 20 4e 55 4c 4c 73 2e 0a 3c 70 3e 0a 54 68 65  r NULLs..<p>.The
2d90: 20 73 79 6e 74 61 78 20 66 6f 72 20 69 6e 74 65   syntax for inte
2da0: 67 65 72 20 61 6e 64 20 66 6c 6f 61 74 69 6e 67  ger and floating
2db0: 20 70 6f 69 6e 74 20 6c 69 74 65 72 61 6c 73 20   point literals 
2dc0: 28 63 6f 6c 6c 65 63 74 69 76 65 6c 79 0a 22 6e  (collectively."n
2dd0: 75 6d 65 72 69 63 20 6c 69 74 65 72 61 6c 73 22  umeric literals"
2de0: 29 20 69 73 20 73 68 6f 77 6e 20 62 79 20 74 68  ) is shown by th
2df0: 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 64 69 61 67  e following diag
2e00: 72 61 6d 3a 3c 2f 70 3e 0a 0a 3c 70 3e 3c 62 3e  ram:</p>..<p><b>
2e10: 3c 61 20 68 72 65 66 3d 22 73 79 6e 74 61 78 64  <a href="syntaxd
2e20: 69 61 67 72 61 6d 73 2e 68 74 6d 6c 23 6e 75 6d  iagrams.html#num
2e30: 65 72 69 63 2d 6c 69 74 65 72 61 6c 22 3e 6e 75  eric-literal">nu
2e40: 6d 65 72 69 63 2d 6c 69 74 65 72 61 6c 3a 3c 2f  meric-literal:</
2e50: 61 3e 3c 2f 62 3e 3c 2f 70 3e 3c 62 6c 6f 63 6b  a></b></p><block
2e60: 71 75 6f 74 65 3e 0a 20 3c 69 6d 67 20 61 6c 74  quote>. <img alt
2e70: 3d 22 73 79 6e 74 61 78 20 64 69 61 67 72 61 6d  ="syntax diagram
2e80: 20 6e 75 6d 65 72 69 63 2d 6c 69 74 65 72 61 6c   numeric-literal
2e90: 22 20 73 72 63 3d 22 69 6d 61 67 65 73 2f 73 79  " src="images/sy
2ea0: 6e 74 61 78 2f 6e 75 6d 65 72 69 63 2d 6c 69 74  ntax/numeric-lit
2eb0: 65 72 61 6c 2e 67 69 66 22 3e 3c 2f 69 6d 67 3e  eral.gif"></img>
2ec0: 0a 20 3c 2f 62 6c 6f 63 6b 71 75 6f 74 65 3e 0a  . </blockquote>.
2ed0: 0a 0a 3c 70 3e 0a 49 66 20 61 20 6e 75 6d 65 72  ..<p>.If a numer
2ee0: 69 63 20 6c 69 74 65 72 61 6c 20 68 61 73 20 61  ic literal has a
2ef0: 20 64 65 63 69 6d 61 6c 20 70 6f 69 6e 74 20 6f   decimal point o
2f00: 72 20 61 6e 20 65 78 70 6f 6e 65 6e 74 69 61 74  r an exponentiat
2f10: 69 6f 6e 0a 63 6c 61 75 73 65 20 6f 72 20 69 66  ion.clause or if
2f20: 20 69 74 73 20 6d 61 67 6e 69 74 75 64 65 20 69   its magnitude i
2f30: 73 20 6c 65 73 73 20 74 68 61 6e 20 2d 39 32 32  s less than -922
2f40: 33 33 37 32 30 33 36 38 35 34 37 37 35 38 30 38  3372036854775808
2f50: 20 6f 72 0a 67 72 65 61 74 65 72 20 74 68 61 6e   or.greater than
2f60: 20 39 32 32 33 33 37 32 30 33 36 38 35 34 37 37   922337203685477
2f70: 35 38 30 37 2c 20 74 68 65 6e 20 69 74 20 69 73  5807, then it is
2f80: 20 61 20 66 6c 6f 61 74 69 6e 67 20 70 6f 69 6e   a floating poin
2f90: 74 20 6c 69 74 65 72 61 6c 2e 0a 4f 74 68 65 72  t literal..Other
2fa0: 77 69 73 65 20 69 73 20 69 74 20 69 73 20 61 6e  wise is it is an
2fb0: 20 20 69 6e 74 65 67 65 72 20 6c 69 74 65 72 61    integer litera
2fc0: 6c 2e 0a 54 68 65 20 22 45 22 20 63 68 61 72 61  l..The "E" chara
2fd0: 63 74 65 72 20 74 68 61 74 20 62 65 67 69 6e 73  cter that begins
2fe0: 20 74 68 65 20 65 78 70 6f 6e 65 6e 74 69 61 74   the exponentiat
2ff0: 69 6f 6e 0a 63 6c 61 75 73 65 20 6f 66 20 61 20  ion.clause of a 
3000: 66 6c 6f 61 74 69 6e 67 20 70 6f 69 6e 74 20 6c  floating point l
3010: 69 74 65 72 61 6c 20 63 61 6e 20 62 65 20 65 69  iteral can be ei
3020: 74 68 65 72 20 75 70 70 65 72 20 6f 72 20 6c 6f  ther upper or lo
3030: 77 65 72 20 63 61 73 65 2e 0a 54 68 65 20 22 2e  wer case..The ".
3040: 22 20 63 68 61 72 61 63 74 65 72 20 69 73 20 61  " character is a
3050: 6c 77 61 79 73 20 75 73 65 64 20 0a 61 73 20 74  lways used .as t
3060: 68 65 20 64 65 63 69 6d 61 6c 20 70 6f 69 6e 74  he decimal point
3070: 20 65 76 65 6e 20 69 66 20 74 68 65 20 6c 6f 63   even if the loc
3080: 61 6c 65 20 73 65 74 74 69 6e 67 20 73 70 65 63  ale setting spec
3090: 69 66 69 65 73 20 22 2c 22 20 66 6f 72 0a 74 68  ifies "," for.th
30a0: 69 73 20 72 6f 6c 65 20 2d 20 74 68 65 20 75 73  is role - the us
30b0: 65 20 6f 66 20 22 2c 22 20 66 6f 72 20 74 68 65  e of "," for the
30c0: 20 64 65 63 69 6d 61 6c 20 70 6f 69 6e 74 20 77   decimal point w
30d0: 6f 75 6c 64 20 72 65 73 75 6c 74 20 69 6e 0a 73  ould result in.s
30e0: 79 6e 74 61 63 74 69 63 20 61 6d 62 69 67 75 69  yntactic ambigui
30f0: 74 79 2e 0a 0a 3c 61 20 6e 61 6d 65 3d 22 68 65  ty...<a name="he
3100: 78 69 6e 74 22 3e 3c 2f 61 3e 0a 0a 3c 70 3e 48  xint"></a>..<p>H
3110: 65 78 61 64 65 63 69 6d 61 6c 20 69 6e 74 65 67  exadecimal integ
3120: 65 72 20 6c 69 74 65 72 61 6c 73 20 66 6f 6c 6c  er literals foll
3130: 6f 77 20 74 68 65 20 43 2d 6c 61 6e 67 75 61 67  ow the C-languag
3140: 65 20 6e 6f 74 61 74 69 6f 6e 20 6f 66 0a 22 30  e notation of."0
3150: 78 22 20 6f 72 20 22 30 58 22 20 66 6f 6c 6c 6f  x" or "0X" follo
3160: 77 65 64 20 62 79 20 68 65 78 61 64 65 63 69 6d  wed by hexadecim
3170: 61 6c 20 64 69 67 69 74 73 2e 0a 46 6f 72 20 65  al digits..For e
3180: 78 61 6d 70 6c 65 2c 20 30 78 31 32 33 34 20 6d  xample, 0x1234 m
3190: 65 61 6e 73 20 74 68 65 20 73 61 6d 65 20 61 73  eans the same as
31a0: 20 34 36 36 30 0a 61 6e 64 20 30 78 38 30 30 30   4660.and 0x8000
31b0: 30 30 30 30 30 30 30 30 30 30 30 30 20 6d 65 61  000000000000 mea
31c0: 6e 73 20 74 68 65 20 73 61 6d 65 20 61 73 20 2d  ns the same as -
31d0: 39 32 32 33 33 37 32 30 33 36 38 35 34 37 37 35  9223372036854775
31e0: 38 30 38 2e 0a 20 48 65 78 61 64 65 63 69 6d 61  808.. Hexadecima
31f0: 6c 20 69 6e 74 65 67 65 72 20 6c 69 74 65 72 61  l integer litera
3200: 6c 73 20 61 72 65 20 69 6e 74 65 72 70 72 65 74  ls are interpret
3210: 65 64 20 61 73 20 36 34 2d 62 69 74 0a 74 77 6f  ed as 64-bit.two
3220: 27 73 2d 63 6f 6d 70 6c 65 6d 65 6e 74 20 69 6e  's-complement in
3230: 74 65 67 65 72 73 20 61 6e 64 20 61 72 65 20 74  tegers and are t
3240: 68 75 73 20 6c 69 6d 69 74 65 64 0a 74 6f 20 73  hus limited.to s
3250: 69 78 74 65 65 6e 20 73 69 67 6e 69 66 69 63 61  ixteen significa
3260: 6e 74 20 64 69 67 69 74 73 20 6f 66 20 70 72 65  nt digits of pre
3270: 63 69 73 69 6f 6e 2e 0a 53 75 70 70 6f 72 74 20  cision..Support 
3280: 66 6f 72 20 68 65 78 61 64 65 63 69 6d 61 6c 20  for hexadecimal 
3290: 69 6e 74 65 67 65 72 73 20 77 61 73 20 61 64 64  integers was add
32a0: 65 64 20 74 6f 20 53 51 4c 69 74 65 20 76 65 72  ed to SQLite ver
32b0: 73 69 6f 6e 20 33 2e 38 2e 36 2e 0a 46 6f 72 20  sion 3.8.6..For 
32c0: 62 61 63 6b 77 61 72 64 73 20 63 6f 6d 70 61 74  backwards compat
32d0: 69 62 69 6c 69 74 79 2c 20 74 68 65 20 22 30 78  ibility, the "0x
32e0: 22 20 68 65 78 61 64 65 63 69 6d 61 6c 20 69 6e  " hexadecimal in
32f0: 74 65 67 65 72 0a 6e 6f 74 61 74 69 6f 6e 20 69  teger.notation i
3300: 73 20 6f 6e 6c 79 20 75 6e 64 65 72 73 74 6f 6f  s only understoo
3310: 64 20 62 79 20 74 68 65 20 53 51 4c 20 6c 61 6e  d by the SQL lan
3320: 67 75 61 67 65 20 70 61 72 73 65 72 2c 20 6e 6f  guage parser, no
3330: 74 20 62 79 20 74 68 65 0a 74 79 70 65 20 63 6f  t by the.type co
3340: 6e 76 65 72 73 69 6f 6e 73 20 72 6f 75 74 69 6e  nversions routin
3350: 65 73 2e 0a 53 74 72 69 6e 67 20 76 61 72 69 61  es..String varia
3360: 62 6c 65 73 20 74 68 61 74 0a 63 6f 6e 74 61 69  bles that.contai
3370: 6e 20 74 65 78 74 20 66 6f 72 6d 61 74 74 65 64  n text formatted
3380: 20 6c 69 6b 65 20 68 65 78 61 64 65 63 69 6d 61   like hexadecima
3390: 6c 20 69 6e 74 65 67 65 72 73 20 61 72 65 20 6e  l integers are n
33a0: 6f 74 0a 69 6e 74 65 72 70 72 65 74 65 64 20 61  ot.interpreted a
33b0: 73 20 68 65 78 61 64 65 63 69 6d 61 6c 20 69 6e  s hexadecimal in
33c0: 74 65 67 65 72 73 20 77 68 65 6e 20 63 6f 65 72  tegers when coer
33d0: 63 69 6e 67 20 74 68 65 20 73 74 72 69 6e 67 20  cing the string 
33e0: 76 61 6c 75 65 0a 69 6e 74 6f 20 61 6e 20 69 6e  value.into an in
33f0: 74 65 67 65 72 20 64 75 65 20 74 6f 20 61 20 3c  teger due to a <
3400: 61 20 68 72 65 66 3d 22 6c 61 6e 67 5f 65 78 70  a href="lang_exp
3410: 72 2e 68 74 6d 6c 23 63 61 73 74 65 78 70 72 22  r.html#castexpr"
3420: 3e 43 41 53 54 20 65 78 70 72 65 73 73 69 6f 6e  >CAST expression
3430: 3c 2f 61 3e 20 6f 72 20 66 6f 72 20 61 20 3c 61  </a> or for a <a
3440: 20 68 72 65 66 3d 22 64 61 74 61 74 79 70 65 33   href="datatype3
3450: 2e 68 74 6d 6c 23 61 66 66 69 6e 69 74 79 22 3e  .html#affinity">
3460: 63 6f 6c 75 6d 6e 20 61 66 66 69 6e 69 74 79 3c  column affinity<
3470: 2f 61 3e 0a 74 72 61 6e 73 66 6f 72 6d 61 74 69  /a>.transformati
3480: 6f 6e 20 6f 72 20 70 72 69 6f 72 20 74 6f 20 70  on or prior to p
3490: 65 72 66 6f 72 6d 69 6e 67 20 61 20 6e 75 6d 65  erforming a nume
34a0: 72 69 63 20 6f 70 65 72 61 74 69 6f 6e 20 6f 72  ric operation or
34b0: 20 66 6f 72 0a 61 6e 79 20 6f 74 68 65 72 20 72   for.any other r
34c0: 75 6e 2d 74 69 6d 65 20 63 6f 6e 76 65 72 73 69  un-time conversi
34d0: 6f 6e 73 2e 20 20 57 68 65 6e 20 63 6f 65 72 63  ons.  When coerc
34e0: 69 6e 67 20 61 0a 73 74 72 69 6e 67 20 76 61 6c  ing a.string val
34f0: 75 65 20 69 6e 20 74 68 65 20 66 6f 72 6d 61 74  ue in the format
3500: 20 6f 66 20 61 20 68 65 78 61 64 65 63 69 6d 61   of a hexadecima
3510: 6c 20 69 6e 74 65 67 65 72 20 69 6e 74 6f 20 61  l integer into a
3520: 6e 20 69 6e 74 65 67 65 72 0a 76 61 6c 75 65 2c  n integer.value,
3530: 20 74 68 65 20 63 6f 6e 76 65 72 73 69 6f 6e 20   the conversion 
3540: 70 72 6f 63 65 73 73 20 73 74 6f 70 73 20 77 68  process stops wh
3550: 65 6e 20 74 68 65 20 27 78 27 20 63 68 61 72 61  en the 'x' chara
3560: 63 74 65 72 20 69 73 20 73 65 65 6e 0a 73 6f 20  cter is seen.so 
3570: 74 68 65 20 72 65 73 75 6c 74 69 6e 67 20 69 6e  the resulting in
3580: 74 65 67 65 72 20 76 61 6c 75 65 20 69 73 20 61  teger value is a
3590: 6c 77 61 79 73 20 7a 65 72 6f 2e 0a 53 51 4c 69  lways zero..SQLi
35a0: 74 65 20 6f 6e 6c 79 20 75 6e 64 65 72 73 74 61  te only understa
35b0: 6e 64 73 20 74 68 65 20 68 65 78 61 64 65 63 69  nds the hexadeci
35c0: 6d 61 6c 20 69 6e 74 65 67 65 72 20 6e 6f 74 61  mal integer nota
35d0: 74 69 6f 6e 20 77 68 65 6e 20 69 74 0a 61 70 70  tion when it.app
35e0: 65 61 72 73 20 69 6e 20 74 68 65 20 53 51 4c 20  ears in the SQL 
35f0: 73 74 61 74 65 6d 65 6e 74 20 74 65 78 74 2c 20  statement text, 
3600: 6e 6f 74 20 77 68 65 6e 20 69 74 20 61 70 70 65  not when it appe
3610: 61 72 73 20 61 73 0a 70 61 72 74 20 6f 66 20 74  ars as.part of t
3620: 68 65 20 63 6f 6e 74 65 6e 74 20 6f 66 20 74 68  he content of th
3630: 65 20 64 61 74 61 62 61 73 65 2e 0a 0a 3c 70 3e  e database...<p>
3640: 20 41 20 73 74 72 69 6e 67 20 63 6f 6e 73 74 61   A string consta
3650: 6e 74 20 69 73 20 66 6f 72 6d 65 64 20 62 79 20  nt is formed by 
3660: 65 6e 63 6c 6f 73 69 6e 67 20 74 68 65 0a 73 74  enclosing the.st
3670: 72 69 6e 67 20 69 6e 20 73 69 6e 67 6c 65 20 71  ring in single q
3680: 75 6f 74 65 73 20 28 27 29 2e 20 20 41 20 73 69  uotes (').  A si
3690: 6e 67 6c 65 20 71 75 6f 74 65 20 77 69 74 68 69  ngle quote withi
36a0: 6e 20 74 68 65 20 73 74 72 69 6e 67 20 63 61 6e  n the string can
36b0: 0a 62 65 20 65 6e 63 6f 64 65 64 20 62 79 20 70  .be encoded by p
36c0: 75 74 74 69 6e 67 20 74 77 6f 20 73 69 6e 67 6c  utting two singl
36d0: 65 20 71 75 6f 74 65 73 20 69 6e 20 61 20 72 6f  e quotes in a ro
36e0: 77 20 2d 20 61 73 20 69 6e 20 50 61 73 63 61 6c  w - as in Pascal
36f0: 2e 0a 43 2d 73 74 79 6c 65 20 65 73 63 61 70 65  ..C-style escape
3700: 73 20 75 73 69 6e 67 20 74 68 65 20 62 61 63 6b  s using the back
3710: 73 6c 61 73 68 20 63 68 61 72 61 63 74 65 72 20  slash character 
3720: 61 72 65 20 6e 6f 74 20 73 75 70 70 6f 72 74 65  are not supporte
3730: 64 20 62 65 63 61 75 73 65 0a 74 68 65 79 20 61  d because.they a
3740: 72 65 20 6e 6f 74 20 73 74 61 6e 64 61 72 64 20  re not standard 
3750: 53 51 4c 2e 0a 0a 3c 70 3e 20 42 4c 4f 42 20 6c  SQL...<p> BLOB l
3760: 69 74 65 72 61 6c 73 20 61 72 65 20 73 74 72 69  iterals are stri
3770: 6e 67 20 6c 69 74 65 72 61 6c 73 20 63 6f 6e 74  ng literals cont
3780: 61 69 6e 69 6e 67 20 68 65 78 61 64 65 63 69 6d  aining hexadecim
3790: 61 6c 20 64 61 74 61 20 61 6e 64 0a 70 72 65 63  al data and.prec
37a0: 65 64 65 64 20 62 79 20 61 20 73 69 6e 67 6c 65  eded by a single
37b0: 20 22 78 22 20 6f 72 20 22 58 22 20 63 68 61 72   "x" or "X" char
37c0: 61 63 74 65 72 2e 20 20 45 78 61 6d 70 6c 65 3a  acter.  Example:
37d0: 20 58 27 35 33 35 31 34 43 36 39 37 34 36 35 27   X'53514C697465'
37e0: 0a 0a 3c 70 3e 0a 41 20 6c 69 74 65 72 61 6c 20  ..<p>.A literal 
37f0: 76 61 6c 75 65 20 63 61 6e 20 61 6c 73 6f 20 62  value can also b
3800: 65 20 74 68 65 20 74 6f 6b 65 6e 20 22 4e 55 4c  e the token "NUL
3810: 4c 22 2e 0a 3c 2f 70 3e 0a 0a 3c 61 20 6e 61 6d  L"..</p>..<a nam
3820: 65 3d 22 76 61 72 70 61 72 61 6d 22 3e 3c 2f 61  e="varparam"></a
3830: 3e 0a 0a 3c 68 33 3e 50 61 72 61 6d 65 74 65 72  >..<h3>Parameter
3840: 73 3c 2f 68 33 3e 0a 3c 70 3e 0a 41 20 22 76 61  s</h3>.<p>.A "va
3850: 72 69 61 62 6c 65 22 20 6f 72 20 22 70 61 72 61  riable" or "para
3860: 6d 65 74 65 72 22 20 74 6f 6b 65 6e 0a 73 70 65  meter" token.spe
3870: 63 69 66 69 65 73 20 61 20 70 6c 61 63 65 68 6f  cifies a placeho
3880: 6c 64 65 72 20 69 6e 20 74 68 65 20 65 78 70 72  lder in the expr
3890: 65 73 73 69 6f 6e 20 66 6f 72 20 61 20 0a 76 61  ession for a .va
38a0: 6c 75 65 20 74 68 61 74 20 69 73 20 66 69 6c 6c  lue that is fill
38b0: 65 64 20 69 6e 20 61 74 20 72 75 6e 74 69 6d 65  ed in at runtime
38c0: 20 75 73 69 6e 67 20 74 68 65 0a 3c 61 20 68 72   using the.<a hr
38d0: 65 66 3d 22 63 33 72 65 66 2f 62 69 6e 64 5f 62  ef="c3ref/bind_b
38e0: 6c 6f 62 2e 68 74 6d 6c 22 3e 73 71 6c 69 74 65  lob.html">sqlite
38f0: 33 5f 62 69 6e 64 28 29 3c 2f 61 3e 20 66 61 6d  3_bind()</a> fam
3900: 69 6c 79 20 6f 66 20 43 2f 43 2b 2b 20 69 6e 74  ily of C/C++ int
3910: 65 72 66 61 63 65 73 2e 0a 50 61 72 61 6d 65 74  erfaces..Paramet
3920: 65 72 73 20 63 61 6e 20 74 61 6b 65 20 73 65 76  ers can take sev
3930: 65 72 61 6c 20 66 6f 72 6d 73 3a 0a 3c 2f 70 3e  eral forms:.</p>
3940: 0a 0a 3c 62 6c 6f 63 6b 71 75 6f 74 65 3e 0a 3c  ..<blockquote>.<
3950: 74 61 62 6c 65 3e 0a 3c 74 72 3e 0a 3c 74 64 20  table>.<tr>.<td 
3960: 61 6c 69 67 6e 3d 22 72 69 67 68 74 22 20 76 61  align="right" va
3970: 6c 69 67 6e 3d 22 74 6f 70 22 3e 3c 62 3e 3f 3c  lign="top"><b>?<
3980: 2f 62 3e 3c 69 3e 4e 4e 4e 3c 2f 69 3e 3c 2f 74  /b><i>NNN</i></t
3990: 64 3e 3c 74 64 20 77 69 64 74 68 3d 22 32 30 22  d><td width="20"
39a0: 3e 3c 2f 74 64 3e 0a 3c 74 64 3e 41 20 71 75 65  ></td>.<td>A que
39b0: 73 74 69 6f 6e 20 6d 61 72 6b 20 66 6f 6c 6c 6f  stion mark follo
39c0: 77 65 64 20 62 79 20 61 20 6e 75 6d 62 65 72 20  wed by a number 
39d0: 3c 69 3e 4e 4e 4e 3c 2f 69 3e 20 68 6f 6c 64 73  <i>NNN</i> holds
39e0: 20 61 20 73 70 6f 74 20 66 6f 72 20 74 68 65 0a   a spot for the.
39f0: 4e 4e 4e 2d 74 68 20 70 61 72 61 6d 65 74 65 72  NNN-th parameter
3a00: 2e 20 20 4e 4e 4e 20 6d 75 73 74 20 62 65 20 62  .  NNN must be b
3a10: 65 74 77 65 65 6e 20 31 20 61 6e 64 20 3c 61 20  etween 1 and <a 
3a20: 68 72 65 66 3d 22 6c 69 6d 69 74 73 2e 68 74 6d  href="limits.htm
3a30: 6c 23 6d 61 78 5f 76 61 72 69 61 62 6c 65 5f 6e  l#max_variable_n
3a40: 75 6d 62 65 72 22 3e 53 51 4c 49 54 45 5f 4d 41  umber">SQLITE_MA
3a50: 58 5f 56 41 52 49 41 42 4c 45 5f 4e 55 4d 42 45  X_VARIABLE_NUMBE
3a60: 52 3c 2f 61 3e 2e 0a 3c 2f 74 64 3e 0a 3c 2f 74  R</a>..</td>.</t
3a70: 72 3e 0a 3c 74 72 3e 0a 3c 74 64 20 61 6c 69 67  r>.<tr>.<td alig
3a80: 6e 3d 22 72 69 67 68 74 22 20 76 61 6c 69 67 6e  n="right" valign
3a90: 3d 22 74 6f 70 22 3e 3c 62 3e 3f 3c 2f 62 3e 3c  ="top"><b>?</b><
3aa0: 2f 74 64 3e 3c 74 64 20 77 69 64 74 68 3d 22 32  /td><td width="2
3ab0: 30 22 3e 3c 2f 74 64 3e 0a 3c 74 64 3e 41 20 71  0"></td>.<td>A q
3ac0: 75 65 73 74 69 6f 6e 20 6d 61 72 6b 20 74 68 61  uestion mark tha
3ad0: 74 20 69 73 20 6e 6f 74 20 66 6f 6c 6c 6f 77 65  t is not followe
3ae0: 64 20 62 79 20 61 20 6e 75 6d 62 65 72 20 63 72  d by a number cr
3af0: 65 61 74 65 73 20 61 20 70 61 72 61 6d 65 74 65  eates a paramete
3b00: 72 0a 77 69 74 68 20 61 20 6e 75 6d 62 65 72 20  r.with a number 
3b10: 6f 6e 65 20 67 72 65 61 74 65 72 20 74 68 61 6e  one greater than
3b20: 20 74 68 65 20 6c 61 72 67 65 73 74 20 70 61 72   the largest par
3b30: 61 6d 65 74 65 72 20 6e 75 6d 62 65 72 20 61 6c  ameter number al
3b40: 72 65 61 64 79 20 61 73 73 69 67 6e 65 64 2e 0a  ready assigned..
3b50: 49 66 20 74 68 69 73 20 6d 65 61 6e 73 20 74 68  If this means th
3b60: 65 20 70 61 72 61 6d 65 74 65 72 20 6e 75 6d 62  e parameter numb
3b70: 65 72 20 69 73 20 67 72 65 61 74 65 72 20 74 68  er is greater th
3b80: 61 6e 0a 3c 61 20 68 72 65 66 3d 22 6c 69 6d 69  an.<a href="limi
3b90: 74 73 2e 68 74 6d 6c 23 6d 61 78 5f 76 61 72 69  ts.html#max_vari
3ba0: 61 62 6c 65 5f 6e 75 6d 62 65 72 22 3e 53 51 4c  able_number">SQL
3bb0: 49 54 45 5f 4d 41 58 5f 56 41 52 49 41 42 4c 45  ITE_MAX_VARIABLE
3bc0: 5f 4e 55 4d 42 45 52 3c 2f 61 3e 2c 20 69 74 20  _NUMBER</a>, it 
3bd0: 69 73 20 61 6e 20 65 72 72 6f 72 2e 0a 54 68 69  is an error..Thi
3be0: 73 20 70 61 72 61 6d 65 74 65 72 20 66 6f 72 6d  s parameter form
3bf0: 61 74 20 69 73 20 70 72 6f 76 69 64 65 64 20 66  at is provided f
3c00: 6f 72 20 63 6f 6d 70 61 74 69 62 69 6c 69 74 79  or compatibility
3c10: 20 77 69 74 68 20 6f 74 68 65 72 20 64 61 74 61   with other data
3c20: 62 61 73 65 0a 65 6e 67 69 6e 65 73 2e 20 20 42  base.engines.  B
3c30: 75 74 20 62 65 63 61 75 73 65 20 69 74 20 69 73  ut because it is
3c40: 20 65 61 73 79 20 74 6f 20 6d 69 73 63 6f 75 6e   easy to miscoun
3c50: 74 20 74 68 65 20 71 75 65 73 74 69 6f 6e 20 6d  t the question m
3c60: 61 72 6b 73 2c 20 74 68 65 0a 75 73 65 20 6f 66  arks, the.use of
3c70: 20 74 68 69 73 20 70 61 72 61 6d 65 74 65 72 20   this parameter 
3c80: 66 6f 72 6d 61 74 20 69 73 20 64 69 73 63 6f 75  format is discou
3c90: 72 61 67 65 64 2e 20 20 50 72 6f 67 72 61 6d 6d  raged.  Programm
3ca0: 65 72 73 20 61 72 65 20 65 6e 63 6f 75 72 61 67  ers are encourag
3cb0: 65 64 0a 74 6f 20 75 73 65 20 6f 6e 65 20 6f 66  ed.to use one of
3cc0: 20 74 68 65 20 73 79 6d 62 6f 6c 69 63 20 66 6f   the symbolic fo
3cd0: 72 6d 61 74 73 20 62 65 6c 6f 77 20 6f 72 20 74  rmats below or t
3ce0: 68 65 20 3f 4e 4e 4e 20 66 6f 72 6d 61 74 20 61  he ?NNN format a
3cf0: 62 6f 76 65 20 69 6e 73 74 65 61 64 2e 0a 3c 2f  bove instead..</
3d00: 74 64 3e 0a 3c 2f 74 72 3e 0a 3c 74 72 3e 0a 3c  td>.</tr>.<tr>.<
3d10: 74 64 20 61 6c 69 67 6e 3d 22 72 69 67 68 74 22  td align="right"
3d20: 20 76 61 6c 69 67 6e 3d 22 74 6f 70 22 3e 3c 62   valign="top"><b
3d30: 3e 3a 3c 2f 62 3e 3c 69 3e 41 41 41 41 3c 2f 69  >:</b><i>AAAA</i
3d40: 3e 3c 2f 74 64 3e 3c 74 64 20 77 69 64 74 68 3d  ></td><td width=
3d50: 22 32 30 22 3e 3c 2f 74 64 3e 0a 3c 74 64 3e 41  "20"></td>.<td>A
3d60: 20 63 6f 6c 6f 6e 20 66 6f 6c 6c 6f 77 65 64 20   colon followed 
3d70: 62 79 20 61 6e 20 69 64 65 6e 74 69 66 69 65 72  by an identifier
3d80: 20 6e 61 6d 65 20 68 6f 6c 64 73 20 61 20 73 70   name holds a sp
3d90: 6f 74 20 66 6f 72 20 61 20 0a 3c 61 20 68 72 65  ot for a .<a hre
3da0: 66 3d 22 63 33 72 65 66 2f 62 69 6e 64 5f 70 61  f="c3ref/bind_pa
3db0: 72 61 6d 65 74 65 72 5f 6e 61 6d 65 2e 68 74 6d  rameter_name.htm
3dc0: 6c 22 3e 6e 61 6d 65 64 20 70 61 72 61 6d 65 74  l">named paramet
3dd0: 65 72 3c 2f 61 3e 20 77 69 74 68 20 74 68 65 20  er</a> with the 
3de0: 6e 61 6d 65 20 3a 41 41 41 41 2e 20 20 0a 4e 61  name :AAAA.  .Na
3df0: 6d 65 64 20 70 61 72 61 6d 65 74 65 72 73 20 61  med parameters a
3e00: 72 65 20 61 6c 73 6f 20 6e 75 6d 62 65 72 65 64  re also numbered
3e10: 2e 20 54 68 65 20 6e 75 6d 62 65 72 20 61 73 73  . The number ass
3e20: 69 67 6e 65 64 20 69 73 20 6f 6e 65 20 67 72 65  igned is one gre
3e30: 61 74 65 72 20 74 68 61 6e 0a 74 68 65 20 6c 61  ater than.the la
3e40: 72 67 65 73 74 20 70 61 72 61 6d 65 74 65 72 20  rgest parameter 
3e50: 6e 75 6d 62 65 72 20 61 6c 72 65 61 64 79 20 61  number already a
3e60: 73 73 69 67 6e 65 64 2e 20 49 66 20 74 68 69 73  ssigned. If this
3e70: 20 6d 65 61 6e 73 20 74 68 65 20 70 61 72 61 6d   means the param
3e80: 65 74 65 72 0a 77 6f 75 6c 64 20 62 65 20 61 73  eter.would be as
3e90: 73 69 67 6e 65 64 20 61 20 6e 75 6d 62 65 72 20  signed a number 
3ea0: 67 72 65 61 74 65 72 20 74 68 61 6e 20 3c 61 20  greater than <a 
3eb0: 68 72 65 66 3d 22 6c 69 6d 69 74 73 2e 68 74 6d  href="limits.htm
3ec0: 6c 23 6d 61 78 5f 76 61 72 69 61 62 6c 65 5f 6e  l#max_variable_n
3ed0: 75 6d 62 65 72 22 3e 53 51 4c 49 54 45 5f 4d 41  umber">SQLITE_MA
3ee0: 58 5f 56 41 52 49 41 42 4c 45 5f 4e 55 4d 42 45  X_VARIABLE_NUMBE
3ef0: 52 3c 2f 61 3e 2c 20 69 74 20 69 73 0a 61 6e 20  R</a>, it is.an 
3f00: 65 72 72 6f 72 2e 20 54 6f 20 61 76 6f 69 64 20  error. To avoid 
3f10: 63 6f 6e 66 75 73 69 6f 6e 2c 20 69 74 20 69 73  confusion, it is
3f20: 20 62 65 73 74 20 74 6f 20 61 76 6f 69 64 20 6d   best to avoid m
3f30: 69 78 69 6e 67 20 6e 61 6d 65 64 20 61 6e 64 20  ixing named and 
3f40: 6e 75 6d 62 65 72 65 64 0a 70 61 72 61 6d 65 74  numbered.paramet
3f50: 65 72 73 2e 3c 2f 74 64 3e 0a 3c 2f 74 72 3e 0a  ers.</td>.</tr>.
3f60: 3c 74 72 3e 0a 3c 74 64 20 61 6c 69 67 6e 3d 22  <tr>.<td align="
3f70: 72 69 67 68 74 22 20 76 61 6c 69 67 6e 3d 22 74  right" valign="t
3f80: 6f 70 22 3e 3c 62 3e 40 3c 2f 62 3e 3c 69 3e 41  op"><b>@</b><i>A
3f90: 41 41 41 3c 2f 69 3e 3c 2f 74 64 3e 3c 74 64 20  AAA</i></td><td 
3fa0: 77 69 64 74 68 3d 22 32 30 22 3e 3c 2f 74 64 3e  width="20"></td>
3fb0: 0a 3c 74 64 3e 41 6e 20 22 61 74 22 20 73 69 67  .<td>An "at" sig
3fc0: 6e 20 77 6f 72 6b 73 20 65 78 61 63 74 6c 79 20  n works exactly 
3fd0: 6c 69 6b 65 20 61 20 63 6f 6c 6f 6e 2c 20 65 78  like a colon, ex
3fe0: 63 65 70 74 20 74 68 61 74 20 74 68 65 20 6e 61  cept that the na
3ff0: 6d 65 20 6f 66 0a 74 68 65 20 70 61 72 61 6d 65  me of.the parame
4000: 74 65 72 20 63 72 65 61 74 65 64 20 69 73 20 40  ter created is @
4010: 41 41 41 41 2e 3c 2f 74 64 3e 0a 3c 2f 74 72 3e  AAAA.</td>.</tr>
4020: 0a 3c 74 72 3e 0a 3c 74 64 20 61 6c 69 67 6e 3d  .<tr>.<td align=
4030: 22 72 69 67 68 74 22 20 76 61 6c 69 67 6e 3d 22  "right" valign="
4040: 74 6f 70 22 3e 3c 62 3e 24 3c 2f 62 3e 3c 69 3e  top"><b>$</b><i>
4050: 41 41 41 41 3c 2f 69 3e 3c 2f 74 64 3e 3c 74 64  AAAA</i></td><td
4060: 20 77 69 64 74 68 3d 22 32 30 22 3e 3c 2f 74 64   width="20"></td
4070: 3e 0a 3c 74 64 3e 41 20 64 6f 6c 6c 61 72 2d 73  >.<td>A dollar-s
4080: 69 67 6e 20 66 6f 6c 6c 6f 77 65 64 20 62 79 20  ign followed by 
4090: 61 6e 20 69 64 65 6e 74 69 66 69 65 72 20 6e 61  an identifier na
40a0: 6d 65 20 61 6c 73 6f 20 68 6f 6c 64 73 20 61 20  me also holds a 
40b0: 73 70 6f 74 20 66 6f 72 20 61 20 6e 61 6d 65 64  spot for a named
40c0: 0a 70 61 72 61 6d 65 74 65 72 20 77 69 74 68 20  .parameter with 
40d0: 74 68 65 20 6e 61 6d 65 20 24 41 41 41 41 2e 20  the name $AAAA. 
40e0: 20 54 68 65 20 69 64 65 6e 74 69 66 69 65 72 20   The identifier 
40f0: 6e 61 6d 65 20 69 6e 20 74 68 69 73 20 63 61 73  name in this cas
4100: 65 20 63 61 6e 20 69 6e 63 6c 75 64 65 0a 6f 6e  e can include.on
4110: 65 20 6f 72 20 6d 6f 72 65 20 6f 63 63 75 72 72  e or more occurr
4120: 65 6e 63 65 73 20 6f 66 20 22 3a 3a 22 20 61 6e  ences of "::" an
4130: 64 20 61 20 73 75 66 66 69 78 20 65 6e 63 6c 6f  d a suffix enclo
4140: 73 65 64 20 69 6e 20 22 28 2e 2e 2e 29 22 20 63  sed in "(...)" c
4150: 6f 6e 74 61 69 6e 69 6e 67 0a 61 6e 79 20 74 65  ontaining.any te
4160: 78 74 20 61 74 20 61 6c 6c 2e 20 20 54 68 69 73  xt at all.  This
4170: 20 73 79 6e 74 61 78 20 69 73 20 74 68 65 20 66   syntax is the f
4180: 6f 72 6d 20 6f 66 20 61 20 76 61 72 69 61 62 6c  orm of a variabl
4190: 65 20 6e 61 6d 65 20 69 6e 20 74 68 65 0a 3c 61  e name in the.<a
41a0: 20 68 72 65 66 3d 22 68 74 74 70 3a 2f 2f 77 77   href="http://ww
41b0: 77 2e 74 63 6c 2e 74 6b 2f 22 3e 54 63 6c 20 70  w.tcl.tk/">Tcl p
41c0: 72 6f 67 72 61 6d 6d 69 6e 67 20 6c 61 6e 67 75  rogramming langu
41d0: 61 67 65 3c 2f 61 3e 2e 20 20 54 68 65 20 70 72  age</a>.  The pr
41e0: 65 73 65 6e 63 65 0a 6f 66 20 74 68 69 73 20 73  esence.of this s
41f0: 79 6e 74 61 78 20 72 65 73 75 6c 74 73 20 66 72  yntax results fr
4200: 6f 6d 20 74 68 65 20 66 61 63 74 20 74 68 61 74  om the fact that
4210: 20 53 51 4c 69 74 65 20 69 73 20 72 65 61 6c 6c   SQLite is reall
4220: 79 20 61 20 0a 3c 61 20 68 72 65 66 3d 22 74 63  y a .<a href="tc
4230: 6c 73 71 6c 69 74 65 2e 68 74 6d 6c 22 3e 54 63  lsqlite.html">Tc
4240: 6c 20 65 78 74 65 6e 73 69 6f 6e 3c 2f 61 3e 20  l extension</a> 
4250: 74 68 61 74 20 68 61 73 20 65 73 63 61 70 65 64  that has escaped
4260: 20 69 6e 74 6f 20 74 68 65 20 77 69 6c 64 2e 3c   into the wild.<
4270: 2f 74 64 3e 0a 3c 2f 74 72 3e 0a 3c 2f 74 61 62  /td>.</tr>.</tab
4280: 6c 65 3e 0a 3c 2f 62 6c 6f 63 6b 71 75 6f 74 65  le>.</blockquote
4290: 3e 0a 0a 3c 70 3e 50 61 72 61 6d 65 74 65 72 73  >..<p>Parameters
42a0: 20 74 68 61 74 20 61 72 65 20 6e 6f 74 20 61 73   that are not as
42b0: 73 69 67 6e 65 64 20 76 61 6c 75 65 73 20 75 73  signed values us
42c0: 69 6e 67 0a 3c 61 20 68 72 65 66 3d 22 63 33 72  ing.<a href="c3r
42d0: 65 66 2f 62 69 6e 64 5f 62 6c 6f 62 2e 68 74 6d  ef/bind_blob.htm
42e0: 6c 22 3e 73 71 6c 69 74 65 33 5f 62 69 6e 64 28  l">sqlite3_bind(
42f0: 29 3c 2f 61 3e 20 61 72 65 20 74 72 65 61 74 65  )</a> are treate
4300: 64 0a 61 73 20 4e 55 4c 4c 2e 20 20 54 68 65 20  d.as NULL.  The 
4310: 3c 61 20 68 72 65 66 3d 22 63 33 72 65 66 2f 62  <a href="c3ref/b
4320: 69 6e 64 5f 70 61 72 61 6d 65 74 65 72 5f 69 6e  ind_parameter_in
4330: 64 65 78 2e 68 74 6d 6c 22 3e 73 71 6c 69 74 65  dex.html">sqlite
4340: 33 5f 62 69 6e 64 5f 70 61 72 61 6d 65 74 65 72  3_bind_parameter
4350: 5f 69 6e 64 65 78 28 29 3c 2f 61 3e 20 69 6e 74  _index()</a> int
4360: 65 72 66 61 63 65 20 63 61 6e 20 62 65 20 75 73  erface can be us
4370: 65 64 0a 74 6f 20 74 72 61 6e 73 6c 61 74 65 20  ed.to translate 
4380: 61 20 73 79 6d 62 6f 6c 69 63 20 70 61 72 61 6d  a symbolic param
4390: 65 74 65 72 20 6e 61 6d 65 20 69 6e 74 6f 20 69  eter name into i
43a0: 74 73 20 65 71 75 69 76 61 6c 65 6e 74 20 6e 75  ts equivalent nu
43b0: 6d 65 72 69 63 20 69 6e 64 65 78 2e 3c 2f 70 3e  meric index.</p>
43c0: 0a 0a 3c 70 3e 54 68 65 20 6d 61 78 69 6d 75 6d  ..<p>The maximum
43d0: 20 70 61 72 61 6d 65 74 65 72 20 6e 75 6d 62 65   parameter numbe
43e0: 72 20 69 73 20 73 65 74 20 61 74 20 63 6f 6d 70  r is set at comp
43f0: 69 6c 65 2d 74 69 6d 65 20 62 79 0a 74 68 65 20  ile-time by.the 
4400: 3c 61 20 68 72 65 66 3d 22 6c 69 6d 69 74 73 2e  <a href="limits.
4410: 68 74 6d 6c 23 6d 61 78 5f 76 61 72 69 61 62 6c  html#max_variabl
4420: 65 5f 6e 75 6d 62 65 72 22 3e 53 51 4c 49 54 45  e_number">SQLITE
4430: 5f 4d 41 58 5f 56 41 52 49 41 42 4c 45 5f 4e 55  _MAX_VARIABLE_NU
4440: 4d 42 45 52 3c 2f 61 3e 20 6d 61 63 72 6f 2e 20  MBER</a> macro. 
4450: 20 41 6e 20 69 6e 64 69 76 69 64 75 61 6c 20 3c   An individual <
4460: 61 20 68 72 65 66 3d 22 63 33 72 65 66 2f 73 71  a href="c3ref/sq
4470: 6c 69 74 65 33 2e 68 74 6d 6c 22 3e 64 61 74 61  lite3.html">data
4480: 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 3c  base connection<
4490: 2f 61 3e 0a 44 20 63 61 6e 20 72 65 64 75 63 65  /a>.D can reduce
44a0: 20 69 74 73 20 6d 61 78 69 6d 75 6d 20 70 61 72   its maximum par
44b0: 61 6d 65 74 65 72 20 6e 75 6d 62 65 72 20 62 65  ameter number be
44c0: 6c 6f 77 20 74 68 65 20 63 6f 6d 70 69 6c 65 2d  low the compile-
44d0: 74 69 6d 65 20 6d 61 78 69 6d 75 6d 0a 75 73 69  time maximum.usi
44e0: 6e 67 20 74 68 65 20 3c 61 20 68 72 65 66 3d 22  ng the <a href="
44f0: 63 33 72 65 66 2f 6c 69 6d 69 74 2e 68 74 6d 6c  c3ref/limit.html
4500: 22 3e 73 71 6c 69 74 65 33 5f 6c 69 6d 69 74 3c  ">sqlite3_limit<
4510: 2f 61 3e 28 44 2c 20 3c 61 20 68 72 65 66 3d 22  /a>(D, <a href="
4520: 63 33 72 65 66 2f 63 5f 6c 69 6d 69 74 5f 61 74  c3ref/c_limit_at
4530: 74 61 63 68 65 64 2e 68 74 6d 6c 23 73 71 6c 69  tached.html#sqli
4540: 74 65 6c 69 6d 69 74 76 61 72 69 61 62 6c 65 6e  telimitvariablen
4550: 75 6d 62 65 72 22 3e 53 51 4c 49 54 45 5f 4c 49  umber">SQLITE_LI
4560: 4d 49 54 5f 56 41 52 49 41 42 4c 45 5f 4e 55 4d  MIT_VARIABLE_NUM
4570: 42 45 52 3c 2f 61 3e 2c 2e 2e 2e 29 20 69 6e 74  BER</a>,...) int
4580: 65 72 66 61 63 65 2e 0a 3c 2f 70 3e 0a 0a 3c 61  erface..</p>..<a
4590: 20 6e 61 6d 65 3d 22 6c 69 6b 65 22 3e 3c 2f 61   name="like"></a
45a0: 3e 0a 0a 3c 68 33 3e 54 68 65 20 4c 49 4b 45 20  >..<h3>The LIKE 
45b0: 61 6e 64 20 47 4c 4f 42 20 6f 70 65 72 61 74 6f  and GLOB operato
45c0: 72 73 3c 2f 68 33 3e 0a 3c 70 3e 54 68 65 20 4c  rs</h3>.<p>The L
45d0: 49 4b 45 20 6f 70 65 72 61 74 6f 72 20 64 6f 65  IKE operator doe
45e0: 73 20 61 20 70 61 74 74 65 72 6e 20 6d 61 74 63  s a pattern matc
45f0: 68 69 6e 67 20 63 6f 6d 70 61 72 69 73 6f 6e 2e  hing comparison.
4600: 20 54 68 65 20 6f 70 65 72 61 6e 64 0a 74 6f 20   The operand.to 
4610: 74 68 65 20 72 69 67 68 74 20 6f 66 20 74 68 65  the right of the
4620: 20 4c 49 4b 45 20 6f 70 65 72 61 74 6f 72 20 63   LIKE operator c
4630: 6f 6e 74 61 69 6e 73 20 74 68 65 20 70 61 74 74  ontains the patt
4640: 65 72 6e 20 61 6e 64 20 74 68 65 20 6c 65 66 74  ern and the left
4650: 20 68 61 6e 64 0a 6f 70 65 72 61 6e 64 20 63 6f   hand.operand co
4660: 6e 74 61 69 6e 73 20 74 68 65 20 73 74 72 69 6e  ntains the strin
4670: 67 20 74 6f 20 6d 61 74 63 68 20 61 67 61 69 6e  g to match again
4680: 73 74 20 74 68 65 20 70 61 74 74 65 72 6e 2e 0a  st the pattern..
4690: 0a 41 20 70 65 72 63 65 6e 74 20 73 79 6d 62 6f  .A percent symbo
46a0: 6c 20 28 22 25 22 29 20 69 6e 20 74 68 65 20 4c  l ("%") in the L
46b0: 49 4b 45 20 70 61 74 74 65 72 6e 20 6d 61 74 63  IKE pattern matc
46c0: 68 65 73 20 61 6e 79 0a 73 65 71 75 65 6e 63 65  hes any.sequence
46d0: 20 6f 66 20 7a 65 72 6f 20 6f 72 20 6d 6f 72 65   of zero or more
46e0: 20 63 68 61 72 61 63 74 65 72 73 20 69 6e 20 74   characters in t
46f0: 68 65 20 73 74 72 69 6e 67 2e 20 20 41 6e 20 75  he string.  An u
4700: 6e 64 65 72 73 63 6f 72 65 0a 28 22 5f 22 29 20  nderscore.("_") 
4710: 69 6e 20 74 68 65 20 4c 49 4b 45 20 70 61 74 74  in the LIKE patt
4720: 65 72 6e 20 6d 61 74 63 68 65 73 20 61 6e 79 20  ern matches any 
4730: 73 69 6e 67 6c 65 20 63 68 61 72 61 63 74 65 72  single character
4740: 20 69 6e 20 74 68 65 0a 73 74 72 69 6e 67 2e 20   in the.string. 
4750: 20 41 6e 79 20 6f 74 68 65 72 20 63 68 61 72 61   Any other chara
4760: 63 74 65 72 20 6d 61 74 63 68 65 73 20 69 74 73  cter matches its
4770: 65 6c 66 20 6f 72 20 69 74 73 20 6c 6f 77 65 72  elf or its lower
4780: 2f 75 70 70 65 72 20 63 61 73 65 0a 65 71 75 69  /upper case.equi
4790: 76 61 6c 65 6e 74 20 28 69 2e 65 2e 20 63 61 73  valent (i.e. cas
47a0: 65 2d 69 6e 73 65 6e 73 69 74 69 76 65 20 6d 61  e-insensitive ma
47b0: 74 63 68 69 6e 67 29 2e 20 20 28 41 20 62 75 67  tching).  (A bug
47c0: 3a 20 53 51 4c 69 74 65 20 6f 6e 6c 79 0a 75 6e  : SQLite only.un
47d0: 64 65 72 73 74 61 6e 64 73 20 75 70 70 65 72 2f  derstands upper/
47e0: 6c 6f 77 65 72 20 63 61 73 65 20 66 6f 72 20 41  lower case for A
47f0: 53 43 49 49 20 63 68 61 72 61 63 74 65 72 73 20  SCII characters 
4800: 62 79 20 64 65 66 61 75 6c 74 2e 20 20 54 68 65  by default.  The
4810: 0a 4c 49 4b 45 20 6f 70 65 72 61 74 6f 72 20 69  .LIKE operator i
4820: 73 20 63 61 73 65 20 73 65 6e 73 69 74 69 76 65  s case sensitive
4830: 20 62 79 20 64 65 66 61 75 6c 74 20 66 6f 72 20   by default for 
4840: 75 6e 69 63 6f 64 65 20 63 68 61 72 61 63 74 65  unicode characte
4850: 72 73 20 74 68 61 74 20 61 72 65 0a 62 65 79 6f  rs that are.beyo
4860: 6e 64 20 74 68 65 20 41 53 43 49 49 20 72 61 6e  nd the ASCII ran
4870: 67 65 2e 20 20 46 6f 72 20 65 78 61 6d 70 6c 65  ge.  For example
4880: 2c 0a 74 68 65 20 65 78 70 72 65 73 73 69 6f 6e  ,.the expression
4890: 20 3c 62 3e 27 61 27 26 6e 62 73 70 3b 4c 49 4b   <b>'a'&nbsp;LIK
48a0: 45 26 6e 62 73 70 3b 27 41 27 3c 2f 62 3e 0a 69  E&nbsp;'A'</b>.i
48b0: 73 20 54 52 55 45 20 62 75 74 20 3c 62 3e 27 26  s TRUE but <b>'&
48c0: 61 65 6c 69 67 3b 27 26 6e 62 73 70 3b 4c 49 4b  aelig;'&nbsp;LIK
48d0: 45 26 6e 62 73 70 3b 27 26 41 45 6c 69 67 3b 27  E&nbsp;'&AElig;'
48e0: 3c 2f 62 3e 20 69 73 20 46 41 4c 53 45 2e 29 3c  </b> is FALSE.)<
48f0: 70 3e 0a 0a 3c 70 3e 49 66 20 74 68 65 20 6f 70  p>..<p>If the op
4900: 74 69 6f 6e 61 6c 20 45 53 43 41 50 45 20 63 6c  tional ESCAPE cl
4910: 61 75 73 65 20 69 73 20 70 72 65 73 65 6e 74 2c  ause is present,
4920: 20 74 68 65 6e 20 74 68 65 20 65 78 70 72 65 73   then the expres
4930: 73 69 6f 6e 0a 66 6f 6c 6c 6f 77 69 6e 67 20 74  sion.following t
4940: 68 65 20 45 53 43 41 50 45 20 6b 65 79 77 6f 72  he ESCAPE keywor
4950: 64 20 6d 75 73 74 20 65 76 61 6c 75 61 74 65 20  d must evaluate 
4960: 74 6f 20 61 20 73 74 72 69 6e 67 20 63 6f 6e 73  to a string cons
4970: 69 73 74 69 6e 67 20 6f 66 0a 61 20 73 69 6e 67  isting of.a sing
4980: 6c 65 20 63 68 61 72 61 63 74 65 72 2e 20 54 68  le character. Th
4990: 69 73 20 63 68 61 72 61 63 74 65 72 20 6d 61 79  is character may
49a0: 20 62 65 20 75 73 65 64 20 69 6e 20 74 68 65 20   be used in the 
49b0: 4c 49 4b 45 20 70 61 74 74 65 72 6e 0a 74 6f 20  LIKE pattern.to 
49c0: 69 6e 63 6c 75 64 65 20 6c 69 74 65 72 61 6c 20  include literal 
49d0: 70 65 72 63 65 6e 74 20 6f 72 20 75 6e 64 65 72  percent or under
49e0: 73 63 6f 72 65 20 63 68 61 72 61 63 74 65 72 73  score characters
49f0: 2e 20 54 68 65 20 65 73 63 61 70 65 0a 63 68 61  . The escape.cha
4a00: 72 61 63 74 65 72 20 66 6f 6c 6c 6f 77 65 64 20  racter followed 
4a10: 62 79 20 61 20 70 65 72 63 65 6e 74 20 73 79 6d  by a percent sym
4a20: 62 6f 6c 20 28 25 29 2c 20 75 6e 64 65 72 73 63  bol (%), undersc
4a30: 6f 72 65 20 28 5f 29 2c 20 6f 72 20 61 20 73 65  ore (_), or a se
4a40: 63 6f 6e 64 0a 69 6e 73 74 61 6e 63 65 20 6f 66  cond.instance of
4a50: 20 74 68 65 20 65 73 63 61 70 65 20 63 68 61 72   the escape char
4a60: 61 63 74 65 72 20 69 74 73 65 6c 66 20 6d 61 74  acter itself mat
4a70: 63 68 65 73 20 61 0a 6c 69 74 65 72 61 6c 20 70  ches a.literal p
4a80: 65 72 63 65 6e 74 20 73 79 6d 62 6f 6c 2c 20 75  ercent symbol, u
4a90: 6e 64 65 72 73 63 6f 72 65 2c 20 6f 72 20 61 20  nderscore, or a 
4aa0: 73 69 6e 67 6c 65 20 65 73 63 61 70 65 20 63 68  single escape ch
4ab0: 61 72 61 63 74 65 72 2c 0a 72 65 73 70 65 63 74  aracter,.respect
4ac0: 69 76 65 6c 79 2e 0a 0a 3c 70 3e 54 68 65 20 69  ively...<p>The i
4ad0: 6e 66 69 78 20 4c 49 4b 45 20 6f 70 65 72 61 74  nfix LIKE operat
4ae0: 6f 72 20 69 73 20 69 6d 70 6c 65 6d 65 6e 74 65  or is implemente
4af0: 64 20 62 79 20 63 61 6c 6c 69 6e 67 20 74 68 65  d by calling the
4b00: 0a 61 70 70 6c 69 63 61 74 69 6f 6e 2d 64 65 66  .application-def
4b10: 69 6e 65 64 20 53 51 4c 20 66 75 6e 63 74 69 6f  ined SQL functio
4b20: 6e 73 20 3c 61 20 68 72 65 66 3d 22 6c 61 6e 67  ns <a href="lang
4b30: 5f 63 6f 72 65 66 75 6e 63 2e 68 74 6d 6c 23 6c  _corefunc.html#l
4b40: 69 6b 65 22 3e 6c 69 6b 65 28 3c 69 3e 59 3c 2f  ike">like(<i>Y</
4b50: 69 3e 2c 3c 69 3e 58 3c 2f 69 3e 29 3c 2f 61 3e  i>,<i>X</i>)</a>
4b60: 20 6f 72 0a 3c 61 20 68 72 65 66 3d 22 6c 61 6e   or.<a href="lan
4b70: 67 5f 63 6f 72 65 66 75 6e 63 2e 68 74 6d 6c 23  g_corefunc.html#
4b80: 6c 69 6b 65 22 3e 6c 69 6b 65 28 3c 69 3e 59 3c  like">like(<i>Y<
4b90: 2f 69 3e 2c 3c 69 3e 58 3c 2f 69 3e 2c 3c 69 3e  /i>,<i>X</i>,<i>
4ba0: 5a 3c 2f 69 3e 29 3c 2f 61 3e 3c 2f 61 3e 2e 3c  Z</i>)</a></a>.<
4bb0: 2f 70 3e 0a 0a 3c 70 3e 54 68 65 20 4c 49 4b 45  /p>..<p>The LIKE
4bc0: 20 6f 70 65 72 61 74 6f 72 20 63 61 6e 20 62 65   operator can be
4bd0: 20 6d 61 64 65 20 63 61 73 65 20 73 65 6e 73 69   made case sensi
4be0: 74 69 76 65 20 75 73 69 6e 67 20 74 68 65 0a 3c  tive using the.<
4bf0: 61 20 68 72 65 66 3d 22 70 72 61 67 6d 61 2e 68  a href="pragma.h
4c00: 74 6d 6c 23 70 72 61 67 6d 61 5f 63 61 73 65 5f  tml#pragma_case_
4c10: 73 65 6e 73 69 74 69 76 65 5f 6c 69 6b 65 22 3e  sensitive_like">
4c20: 63 61 73 65 5f 73 65 6e 73 69 74 69 76 65 5f 6c  case_sensitive_l
4c30: 69 6b 65 20 70 72 61 67 6d 61 3c 2f 61 3e 2e 3c  ike pragma</a>.<
4c40: 2f 70 3e 0a 0a 3c 61 20 6e 61 6d 65 3d 22 67 6c  /p>..<a name="gl
4c50: 6f 62 22 3e 3c 2f 61 3e 0a 0a 3c 70 3e 54 68 65  ob"></a>..<p>The
4c60: 20 47 4c 4f 42 20 6f 70 65 72 61 74 6f 72 20 69   GLOB operator i
4c70: 73 20 73 69 6d 69 6c 61 72 20 74 6f 20 4c 49 4b  s similar to LIK
4c80: 45 20 62 75 74 20 75 73 65 73 20 74 68 65 20 55  E but uses the U
4c90: 6e 69 78 0a 66 69 6c 65 20 67 6c 6f 62 62 69 6e  nix.file globbin
4ca0: 67 20 73 79 6e 74 61 78 20 66 6f 72 20 69 74 73  g syntax for its
4cb0: 20 77 69 6c 64 63 61 72 64 73 2e 20 20 41 6c 73   wildcards.  Als
4cc0: 6f 2c 20 47 4c 4f 42 20 69 73 20 63 61 73 65 0a  o, GLOB is case.
4cd0: 73 65 6e 73 69 74 69 76 65 2c 20 75 6e 6c 69 6b  sensitive, unlik
4ce0: 65 20 4c 49 4b 45 2e 20 20 42 6f 74 68 20 47 4c  e LIKE.  Both GL
4cf0: 4f 42 20 61 6e 64 20 4c 49 4b 45 20 6d 61 79 20  OB and LIKE may 
4d00: 62 65 20 70 72 65 63 65 64 65 64 20 62 79 0a 74  be preceded by.t
4d10: 68 65 20 4e 4f 54 20 6b 65 79 77 6f 72 64 20 74  he NOT keyword t
4d20: 6f 20 69 6e 76 65 72 74 20 74 68 65 20 73 65 6e  o invert the sen
4d30: 73 65 20 6f 66 20 74 68 65 20 74 65 73 74 2e 20  se of the test. 
4d40: 20 54 68 65 20 69 6e 66 69 78 20 47 4c 4f 42 20   The infix GLOB 
4d50: 0a 6f 70 65 72 61 74 6f 72 20 69 73 20 69 6d 70  .operator is imp
4d60: 6c 65 6d 65 6e 74 65 64 20 62 79 20 63 61 6c 6c  lemented by call
4d70: 69 6e 67 20 74 68 65 20 66 75 6e 63 74 69 6f 6e  ing the function
4d80: 0a 3c 61 20 68 72 65 66 3d 22 6c 61 6e 67 5f 63  .<a href="lang_c
4d90: 6f 72 65 66 75 6e 63 2e 68 74 6d 6c 23 67 6c 6f  orefunc.html#glo
4da0: 62 22 3e 67 6c 6f 62 28 3c 69 3e 59 3c 2f 69 3e  b">glob(<i>Y</i>
4db0: 2c 3c 69 3e 58 3c 2f 69 3e 29 3c 2f 61 3e 20 61  ,<i>X</i>)</a> a
4dc0: 6e 64 20 63 61 6e 20 62 65 20 6d 6f 64 69 66 69  nd can be modifi
4dd0: 65 64 20 62 79 20 6f 76 65 72 72 69 64 69 6e 67  ed by overriding
4de0: 0a 74 68 61 74 20 66 75 6e 63 74 69 6f 6e 2e 3c  .that function.<
4df0: 2f 70 3e 0a 0a 3c 61 20 6e 61 6d 65 3d 22 72 65  /p>..<a name="re
4e00: 67 65 78 70 22 3e 3c 2f 61 3e 0a 0a 3c 70 3e 54  gexp"></a>..<p>T
4e10: 68 65 20 52 45 47 45 58 50 20 6f 70 65 72 61 74  he REGEXP operat
4e20: 6f 72 20 69 73 20 61 20 73 70 65 63 69 61 6c 20  or is a special 
4e30: 73 79 6e 74 61 78 20 66 6f 72 20 74 68 65 20 72  syntax for the r
4e40: 65 67 65 78 70 28 29 0a 75 73 65 72 20 66 75 6e  egexp().user fun
4e50: 63 74 69 6f 6e 2e 20 20 4e 6f 20 72 65 67 65 78  ction.  No regex
4e60: 70 28 29 20 75 73 65 72 20 66 75 6e 63 74 69 6f  p() user functio
4e70: 6e 20 69 73 20 64 65 66 69 6e 65 64 20 62 79 20  n is defined by 
4e80: 64 65 66 61 75 6c 74 0a 61 6e 64 20 73 6f 20 75  default.and so u
4e90: 73 65 20 6f 66 20 74 68 65 20 52 45 47 45 58 50  se of the REGEXP
4ea0: 20 6f 70 65 72 61 74 6f 72 20 77 69 6c 6c 20 6e   operator will n
4eb0: 6f 72 6d 61 6c 6c 79 20 72 65 73 75 6c 74 20 69  ormally result i
4ec0: 6e 20 61 6e 0a 65 72 72 6f 72 20 6d 65 73 73 61  n an.error messa
4ed0: 67 65 2e 20 20 49 66 20 61 6e 20 3c 61 20 68 72  ge.  If an <a hr
4ee0: 65 66 3d 22 63 33 72 65 66 2f 63 72 65 61 74 65  ef="c3ref/create
4ef0: 5f 66 75 6e 63 74 69 6f 6e 2e 68 74 6d 6c 22 3e  _function.html">
4f00: 61 70 70 6c 69 63 61 74 69 6f 6e 2d 64 65 66 69  application-defi
4f10: 6e 65 64 20 53 51 4c 20 66 75 6e 63 74 69 6f 6e  ned SQL function
4f20: 3c 2f 61 3e 20 6e 61 6d 65 64 20 22 72 65 67 65  </a> named "rege
4f30: 78 70 22 0a 69 73 20 61 64 64 65 64 20 61 74 20  xp".is added at 
4f40: 72 75 6e 2d 74 69 6d 65 2c 20 74 68 65 6e 20 74  run-time, then t
4f50: 68 65 20 22 3c 69 3e 58 3c 2f 69 3e 20 52 45 47  he "<i>X</i> REG
4f60: 45 58 50 20 3c 69 3e 59 3c 2f 69 3e 22 20 6f 70  EXP <i>Y</i>" op
4f70: 65 72 61 74 6f 72 20 77 69 6c 6c 0a 62 65 20 69  erator will.be i
4f80: 6d 70 6c 65 6d 65 6e 74 65 64 20 61 73 20 61 20  mplemented as a 
4f90: 63 61 6c 6c 20 74 6f 20 22 72 65 67 65 78 70 28  call to "regexp(
4fa0: 3c 69 3e 59 3c 2f 69 3e 2c 3c 69 3e 58 3c 2f 69  <i>Y</i>,<i>X</i
4fb0: 3e 29 22 2e 3c 2f 70 3e 0a 0a 3c 61 20 6e 61 6d  >)".</p>..<a nam
4fc0: 65 3d 22 6d 61 74 63 68 22 3e 3c 2f 61 3e 0a 0a  e="match"></a>..
4fd0: 3c 70 3e 54 68 65 20 4d 41 54 43 48 20 6f 70 65  <p>The MATCH ope
4fe0: 72 61 74 6f 72 20 69 73 20 61 20 73 70 65 63 69  rator is a speci
4ff0: 61 6c 20 73 79 6e 74 61 78 20 66 6f 72 20 74 68  al syntax for th
5000: 65 20 6d 61 74 63 68 28 29 0a 61 70 70 6c 69 63  e match().applic
5010: 61 74 69 6f 6e 2d 64 65 66 69 6e 65 64 20 66 75  ation-defined fu
5020: 6e 63 74 69 6f 6e 2e 20 20 54 68 65 20 64 65 66  nction.  The def
5030: 61 75 6c 74 20 6d 61 74 63 68 28 29 20 66 75 6e  ault match() fun
5040: 63 74 69 6f 6e 20 69 6d 70 6c 65 6d 65 6e 74 61  ction implementa
5050: 74 69 6f 6e 0a 72 61 69 73 65 73 20 61 6e 20 65  tion.raises an e
5060: 78 63 65 70 74 69 6f 6e 20 61 6e 64 20 69 73 20  xception and is 
5070: 6e 6f 74 20 72 65 61 6c 6c 79 20 75 73 65 66 75  not really usefu
5080: 6c 20 66 6f 72 20 61 6e 79 74 68 69 6e 67 2e 0a  l for anything..
5090: 42 75 74 20 65 78 74 65 6e 73 69 6f 6e 73 20 63  But extensions c
50a0: 61 6e 20 6f 76 65 72 72 69 64 65 20 74 68 65 20  an override the 
50b0: 6d 61 74 63 68 28 29 20 66 75 6e 63 74 69 6f 6e  match() function
50c0: 20 77 69 74 68 20 6d 6f 72 65 0a 68 65 6c 70 66   with more.helpf
50d0: 75 6c 20 6c 6f 67 69 63 2e 3c 2f 70 3e 0a 0a 3c  ul logic.</p>..<
50e0: 61 20 6e 61 6d 65 3d 22 62 65 74 77 65 65 6e 22  a name="between"
50f0: 3e 3c 2f 61 3e 0a 0a 3c 68 33 3e 54 68 65 20 42  ></a>..<h3>The B
5100: 45 54 57 45 45 4e 20 6f 70 65 72 61 74 6f 72 3c  ETWEEN operator<
5110: 2f 68 33 3e 0a 3c 70 3e 54 68 65 20 42 45 54 57  /h3>.<p>The BETW
5120: 45 45 4e 20 6f 70 65 72 61 74 6f 72 20 69 73 20  EEN operator is 
5130: 6c 6f 67 69 63 61 6c 6c 79 20 65 71 75 69 76 61  logically equiva
5140: 6c 65 6e 74 20 74 6f 20 61 20 70 61 69 72 20 6f  lent to a pair o
5150: 66 20 63 6f 6d 70 61 72 69 73 6f 6e 73 2e 0a 22  f comparisons.."
5160: 3c 69 3e 78 3c 2f 69 3e 20 3c 62 3e 42 45 54 57  <i>x</i> <b>BETW
5170: 45 45 4e 3c 2f 62 3e 20 3c 69 3e 79 3c 2f 69 3e  EEN</b> <i>y</i>
5180: 20 3c 62 3e 41 4e 44 3c 2f 62 3e 20 3c 69 3e 7a   <b>AND</b> <i>z
5190: 3c 2f 69 3e 22 20 69 73 20 0a 65 71 75 69 76 61  </i>" is .equiva
51a0: 6c 65 6e 74 20 74 6f 20 0a 22 3c 69 3e 78 3c 2f  lent to ."<i>x</
51b0: 69 3e 3c 62 3e 26 67 74 3b 3d 3c 2f 62 3e 3c 69  i><b>&gt;=</b><i
51c0: 3e 79 3c 2f 69 3e 20 3c 62 3e 41 4e 44 3c 2f 62  >y</i> <b>AND</b
51d0: 3e 20 3c 69 3e 78 3c 2f 69 3e 3c 62 3e 26 6c 74  > <i>x</i><b>&lt
51e0: 3b 3d 3c 2f 62 3e 3c 69 3e 7a 3c 2f 69 3e 22 20  ;=</b><i>z</i>" 
51f0: 65 78 63 65 70 74 0a 74 68 61 74 20 77 69 74 68  except.that with
5200: 20 42 45 54 57 45 45 4e 2c 20 74 68 65 20 3c 69   BETWEEN, the <i
5210: 3e 78 3c 2f 69 3e 20 65 78 70 72 65 73 73 69 6f  >x</i> expressio
5220: 6e 20 69 73 20 6f 6e 6c 79 20 65 76 61 6c 75 61  n is only evalua
5230: 74 65 64 20 6f 6e 63 65 2e 0a 54 68 65 20 70 72  ted once..The pr
5240: 65 63 65 64 65 6e 63 65 20 6f 66 20 74 68 65 20  ecedence of the 
5250: 42 45 54 57 45 45 4e 20 6f 70 65 72 61 74 6f 72  BETWEEN operator
5260: 20 69 73 20 74 68 65 20 73 61 6d 65 20 61 73 20   is the same as 
5270: 74 68 65 20 70 72 65 63 65 64 65 6e 63 65 0a 61  the precedence.a
5280: 73 20 6f 70 65 72 61 74 6f 72 73 20 3c 62 3e 3d  s operators <b>=
5290: 3d 3c 2f 62 3e 20 61 6e 64 20 3c 62 3e 21 3d 3c  =</b> and <b>!=<
52a0: 2f 62 3e 20 61 6e 64 20 3c 62 3e 4c 49 4b 45 3c  /b> and <b>LIKE<
52b0: 2f 62 3e 20 61 6e 64 20 67 72 6f 75 70 73 20 6c  /b> and groups l
52c0: 65 66 74 20 74 6f 20 72 69 67 68 74 2e 0a 0a 3c  eft to right...<
52d0: 61 20 6e 61 6d 65 3d 22 63 61 73 65 22 3e 3c 2f  a name="case"></
52e0: 61 3e 0a 0a 3c 68 33 3e 54 68 65 20 43 41 53 45  a>..<h3>The CASE
52f0: 20 65 78 70 72 65 73 73 69 6f 6e 3c 2f 68 33 3e   expression</h3>
5300: 0a 3c 70 3e 41 20 43 41 53 45 20 65 78 70 72 65  .<p>A CASE expre
5310: 73 73 69 6f 6e 20 73 65 72 76 65 73 20 61 20 72  ssion serves a r
5320: 6f 6c 65 20 73 69 6d 69 6c 61 72 20 74 6f 20 49  ole similar to I
5330: 46 2d 54 48 45 4e 2d 45 4c 53 45 20 69 6e 20 6f  F-THEN-ELSE in o
5340: 74 68 65 72 0a 70 72 6f 67 72 61 6d 6d 69 6e 67  ther.programming
5350: 20 6c 61 6e 67 75 61 67 65 73 2e 20 20 0a 0a 3c   languages.  ..<
5360: 70 3e 54 68 65 20 6f 70 74 69 6f 6e 61 6c 20 65  p>The optional e
5370: 78 70 72 65 73 73 69 6f 6e 20 74 68 61 74 20 6f  xpression that o
5380: 63 63 75 72 73 20 69 6e 20 62 65 74 77 65 65 6e  ccurs in between
5390: 20 74 68 65 20 43 41 53 45 20 6b 65 79 77 6f 72   the CASE keywor
53a0: 64 20 61 6e 64 20 74 68 65 0a 66 69 72 73 74 20  d and the.first 
53b0: 57 48 45 4e 20 6b 65 79 77 6f 72 64 20 69 73 20  WHEN keyword is 
53c0: 63 61 6c 6c 65 64 20 74 68 65 20 22 62 61 73 65  called the "base
53d0: 22 20 65 78 70 72 65 73 73 69 6f 6e 2e 20 54 68  " expression. Th
53e0: 65 72 65 20 61 72 65 20 74 77 6f 20 62 61 73 69  ere are two basi
53f0: 63 20 66 6f 72 6d 73 0a 6f 66 20 74 68 65 20 43  c forms.of the C
5400: 41 53 45 20 65 78 70 72 65 73 73 69 6f 6e 3a 20  ASE expression: 
5410: 74 68 6f 73 65 20 77 69 74 68 20 61 20 62 61 73  those with a bas
5420: 65 20 65 78 70 72 65 73 73 69 6f 6e 20 61 6e 64  e expression and
5430: 20 74 68 6f 73 65 20 77 69 74 68 6f 75 74 2e 0a   those without..
5440: 0a 3c 70 3e 49 6e 20 61 20 43 41 53 45 20 77 69  .<p>In a CASE wi
5450: 74 68 6f 75 74 20 61 20 62 61 73 65 20 65 78 70  thout a base exp
5460: 72 65 73 73 69 6f 6e 2c 20 65 61 63 68 20 57 48  ression, each WH
5470: 45 4e 20 65 78 70 72 65 73 73 69 6f 6e 20 69 73  EN expression is
5480: 20 65 76 61 6c 75 61 74 65 64 0a 61 6e 64 20 74   evaluated.and t
5490: 68 65 20 72 65 73 75 6c 74 20 74 72 65 61 74 65  he result treate
54a0: 64 20 61 73 20 61 20 62 6f 6f 6c 65 61 6e 2c 20  d as a boolean, 
54b0: 73 74 61 72 74 69 6e 67 20 77 69 74 68 20 74 68  starting with th
54c0: 65 20 6c 65 66 74 6d 6f 73 74 20 61 6e 64 20 63  e leftmost and c
54d0: 6f 6e 74 69 6e 75 69 6e 67 0a 74 6f 20 74 68 65  ontinuing.to the
54e0: 20 72 69 67 68 74 2e 20 54 68 65 20 72 65 73 75   right. The resu
54f0: 6c 74 20 6f 66 20 74 68 65 20 43 41 53 45 20 65  lt of the CASE e
5500: 78 70 72 65 73 73 69 6f 6e 20 69 73 20 74 68 65  xpression is the
5510: 20 65 76 61 6c 75 61 74 69 6f 6e 20 6f 66 20 74   evaluation of t
5520: 68 65 20 54 48 45 4e 0a 65 78 70 72 65 73 73 69  he THEN.expressi
5530: 6f 6e 20 74 68 61 74 20 63 6f 72 72 65 73 70 6f  on that correspo
5540: 6e 64 73 20 74 6f 20 74 68 65 20 66 69 72 73 74  nds to the first
5550: 20 57 48 45 4e 20 65 78 70 72 65 73 73 69 6f 6e   WHEN expression
5560: 20 74 68 61 74 20 65 76 61 6c 75 61 74 65 73 20   that evaluates 
5570: 74 6f 0a 74 72 75 65 2e 20 4f 72 2c 20 69 66 20  to.true. Or, if 
5580: 6e 6f 6e 65 20 6f 66 20 74 68 65 20 57 48 45 4e  none of the WHEN
5590: 20 65 78 70 72 65 73 73 69 6f 6e 73 20 65 76 61   expressions eva
55a0: 6c 75 61 74 65 20 74 6f 20 74 72 75 65 2c 20 74  luate to true, t
55b0: 68 65 20 72 65 73 75 6c 74 20 6f 66 0a 65 76 61  he result of.eva
55c0: 6c 75 61 74 69 6e 67 20 74 68 65 20 45 4c 53 45  luating the ELSE
55d0: 20 65 78 70 72 65 73 73 69 6f 6e 2c 20 69 66 20   expression, if 
55e0: 61 6e 79 2e 20 49 66 20 74 68 65 72 65 20 69 73  any. If there is
55f0: 20 6e 6f 20 45 4c 53 45 20 65 78 70 72 65 73 73   no ELSE express
5600: 69 6f 6e 20 61 6e 64 0a 6e 6f 6e 65 20 6f 66 20  ion and.none of 
5610: 74 68 65 20 57 48 45 4e 20 65 78 70 72 65 73 73  the WHEN express
5620: 69 6f 6e 73 20 61 72 65 20 74 72 75 65 2c 20 74  ions are true, t
5630: 68 65 6e 20 74 68 65 20 6f 76 65 72 61 6c 6c 20  hen the overall 
5640: 72 65 73 75 6c 74 20 69 73 20 4e 55 4c 4c 2e 0a  result is NULL..
5650: 0a 3c 70 3e 41 20 4e 55 4c 4c 20 72 65 73 75 6c  .<p>A NULL resul
5660: 74 20 69 73 20 63 6f 6e 73 69 64 65 72 65 64 20  t is considered 
5670: 75 6e 74 72 75 65 20 77 68 65 6e 20 65 76 61 6c  untrue when eval
5680: 75 61 74 69 6e 67 20 57 48 45 4e 20 74 65 72 6d  uating WHEN term
5690: 73 2e 0a 0a 3c 70 3e 49 6e 20 61 20 43 41 53 45  s...<p>In a CASE
56a0: 20 77 69 74 68 20 61 20 62 61 73 65 20 65 78 70   with a base exp
56b0: 72 65 73 73 69 6f 6e 2c 20 74 68 65 20 62 61 73  ression, the bas
56c0: 65 20 65 78 70 72 65 73 73 69 6f 6e 20 69 73 20  e expression is 
56d0: 65 76 61 6c 75 61 74 65 64 20 6a 75 73 74 0a 6f  evaluated just.o
56e0: 6e 63 65 20 61 6e 64 20 74 68 65 20 72 65 73 75  nce and the resu
56f0: 6c 74 20 69 73 20 63 6f 6d 70 61 72 65 64 20 61  lt is compared a
5700: 67 61 69 6e 73 74 20 74 68 65 20 65 76 61 6c 75  gainst the evalu
5710: 61 74 69 6f 6e 20 6f 66 20 65 61 63 68 20 57 48  ation of each WH
5720: 45 4e 20 0a 65 78 70 72 65 73 73 69 6f 6e 20 66  EN .expression f
5730: 72 6f 6d 20 6c 65 66 74 20 74 6f 20 72 69 67 68  rom left to righ
5740: 74 2e 20 54 68 65 20 72 65 73 75 6c 74 20 6f 66  t. The result of
5750: 20 74 68 65 20 43 41 53 45 20 65 78 70 72 65 73   the CASE expres
5760: 73 69 6f 6e 20 69 73 20 74 68 65 20 0a 65 76 61  sion is the .eva
5770: 6c 75 61 74 69 6f 6e 20 6f 66 20 74 68 65 20 54  luation of the T
5780: 48 45 4e 20 65 78 70 72 65 73 73 69 6f 6e 20 74  HEN expression t
5790: 68 61 74 20 63 6f 72 72 65 73 70 6f 6e 64 73 20  hat corresponds 
57a0: 74 6f 20 74 68 65 20 66 69 72 73 74 20 57 48 45  to the first WHE
57b0: 4e 0a 65 78 70 72 65 73 73 69 6f 6e 20 66 6f 72  N.expression for
57c0: 20 77 68 69 63 68 20 74 68 65 20 63 6f 6d 70 61   which the compa
57d0: 72 69 73 6f 6e 20 69 73 20 74 72 75 65 2e 20 4f  rison is true. O
57e0: 72 2c 20 69 66 20 6e 6f 6e 65 20 6f 66 20 74 68  r, if none of th
57f0: 65 20 57 48 45 4e 0a 65 78 70 72 65 73 73 69 6f  e WHEN.expressio
5800: 6e 73 20 65 76 61 6c 75 61 74 65 20 74 6f 20 61  ns evaluate to a
5810: 20 76 61 6c 75 65 20 65 71 75 61 6c 20 74 6f 20   value equal to 
5820: 74 68 65 20 62 61 73 65 20 65 78 70 72 65 73 73  the base express
5830: 69 6f 6e 2c 20 74 68 65 20 72 65 73 75 6c 74 0a  ion, the result.
5840: 6f 66 20 65 76 61 6c 75 61 74 69 6e 67 20 74 68  of evaluating th
5850: 65 20 45 4c 53 45 20 65 78 70 72 65 73 73 69 6f  e ELSE expressio
5860: 6e 2c 20 69 66 20 61 6e 79 2e 20 49 66 20 74 68  n, if any. If th
5870: 65 72 65 20 69 73 20 6e 6f 20 45 4c 53 45 20 65  ere is no ELSE e
5880: 78 70 72 65 73 73 69 6f 6e 20 61 6e 64 0a 6e 6f  xpression and.no
5890: 6e 65 20 6f 66 20 74 68 65 20 57 48 45 4e 20 65  ne of the WHEN e
58a0: 78 70 72 65 73 73 69 6f 6e 73 20 70 72 6f 64 75  xpressions produ
58b0: 63 65 20 61 20 72 65 73 75 6c 74 20 65 71 75 61  ce a result equa
58c0: 6c 20 74 6f 20 74 68 65 20 62 61 73 65 20 65 78  l to the base ex
58d0: 70 72 65 73 73 69 6f 6e 2c 0a 74 68 65 20 6f 76  pression,.the ov
58e0: 65 72 61 6c 6c 20 72 65 73 75 6c 74 20 69 73 20  erall result is 
58f0: 4e 55 4c 4c 2e 0a 0a 3c 70 3e 57 68 65 6e 20 63  NULL...<p>When c
5900: 6f 6d 70 61 72 69 6e 67 20 61 20 62 61 73 65 20  omparing a base 
5910: 65 78 70 72 65 73 73 69 6f 6e 20 61 67 61 69 6e  expression again
5920: 73 74 20 61 20 57 48 45 4e 20 65 78 70 72 65 73  st a WHEN expres
5930: 73 69 6f 6e 2c 20 74 68 65 20 73 61 6d 65 0a 63  sion, the same.c
5940: 6f 6c 6c 61 74 69 6e 67 20 73 65 71 75 65 6e 63  ollating sequenc
5950: 65 2c 20 61 66 66 69 6e 69 74 79 2c 20 61 6e 64  e, affinity, and
5960: 20 4e 55 4c 4c 2d 68 61 6e 64 6c 69 6e 67 20 72   NULL-handling r
5970: 75 6c 65 73 20 61 70 70 6c 79 20 61 73 20 69 66  ules apply as if
5980: 20 74 68 65 0a 62 61 73 65 20 65 78 70 72 65 73   the.base expres
5990: 73 69 6f 6e 20 61 6e 64 20 57 48 45 4e 20 65 78  sion and WHEN ex
59a0: 70 72 65 73 73 69 6f 6e 20 61 72 65 20 72 65 73  pression are res
59b0: 70 65 63 74 69 76 65 6c 79 20 74 68 65 20 6c 65  pectively the le
59c0: 66 74 2d 20 61 6e 64 0a 72 69 67 68 74 2d 68 61  ft- and.right-ha
59d0: 6e 64 20 6f 70 65 72 61 6e 64 73 20 6f 66 20 61  nd operands of a
59e0: 6e 20 3c 62 69 67 3e 3c 62 3e 3d 3c 2f 62 3e 3c  n <big><b>=</b><
59f0: 2f 62 69 67 3e 20 6f 70 65 72 61 74 6f 72 2e 3c  /big> operator.<
5a00: 2f 70 3e 20 49 66 20 74 68 65 20 62 61 73 65 20  /p> If the base 
5a10: 0a 65 78 70 72 65 73 73 69 6f 6e 20 69 73 20 4e  .expression is N
5a20: 55 4c 4c 20 74 68 65 6e 20 74 68 65 20 72 65 73  ULL then the res
5a30: 75 6c 74 20 6f 66 20 74 68 65 20 43 41 53 45 20  ult of the CASE 
5a40: 69 73 20 61 6c 77 61 79 73 20 74 68 65 20 72 65  is always the re
5a50: 73 75 6c 74 20 0a 6f 66 20 65 76 61 6c 75 61 74  sult .of evaluat
5a60: 69 6e 67 20 74 68 65 20 45 4c 53 45 20 65 78 70  ing the ELSE exp
5a70: 72 65 73 73 69 6f 6e 20 69 66 20 69 74 20 65 78  ression if it ex
5a80: 69 73 74 73 2c 20 6f 72 20 4e 55 4c 4c 20 69 66  ists, or NULL if
5a90: 20 69 74 20 64 6f 65 73 20 6e 6f 74 2e 0a 0a 3c   it does not...<
5aa0: 70 3e 42 6f 74 68 20 66 6f 72 6d 73 20 6f 66 20  p>Both forms of 
5ab0: 74 68 65 20 43 41 53 45 20 65 78 70 72 65 73 73  the CASE express
5ac0: 69 6f 6e 20 75 73 65 20 6c 61 7a 79 2c 20 6f 72  ion use lazy, or
5ad0: 20 73 68 6f 72 74 2d 63 69 72 63 75 69 74 2c 20   short-circuit, 
5ae0: 0a 65 76 61 6c 75 61 74 69 6f 6e 2e 0a 0a 3c 70  .evaluation...<p
5af0: 3e 54 68 65 20 6f 6e 6c 79 20 64 69 66 66 65 72  >The only differ
5b00: 65 6e 63 65 20 62 65 74 77 65 65 6e 20 74 68 65  ence between the
5b10: 20 66 6f 6c 6c 6f 77 69 6e 67 20 74 77 6f 20 43   following two C
5b20: 41 53 45 20 65 78 70 72 65 73 73 69 6f 6e 73 20  ASE expressions 
5b30: 69 73 20 74 68 61 74 20 0a 74 68 65 20 3c 69 3e  is that .the <i>
5b40: 78 3c 2f 69 3e 20 65 78 70 72 65 73 73 69 6f 6e  x</i> expression
5b50: 20 69 73 20 65 76 61 6c 75 61 74 65 64 20 65 78   is evaluated ex
5b60: 61 63 74 6c 79 20 6f 6e 63 65 20 69 6e 20 74 68  actly once in th
5b70: 65 20 66 69 72 73 74 20 65 78 61 6d 70 6c 65 20  e first example 
5b80: 62 75 74 20 0a 6d 69 67 68 74 20 62 65 20 65 76  but .might be ev
5b90: 61 6c 75 61 74 65 64 20 6d 75 6c 74 69 70 6c 65  aluated multiple
5ba0: 20 74 69 6d 65 73 20 69 6e 20 74 68 65 20 73 65   times in the se
5bb0: 63 6f 6e 64 3a 0a 0a 3c 75 6c 3e 3c 70 72 65 3e  cond:..<ul><pre>
5bc0: 0a 3c 6c 69 3e 43 41 53 45 20 78 20 57 48 45 4e  .<li>CASE x WHEN
5bd0: 20 77 31 20 54 48 45 4e 20 72 31 20 57 48 45 4e   w1 THEN r1 WHEN
5be0: 20 77 32 20 54 48 45 4e 20 72 32 20 45 4c 53 45   w2 THEN r2 ELSE
5bf0: 20 72 33 20 45 4e 44 0a 3c 6c 69 3e 43 41 53 45   r3 END.<li>CASE
5c00: 20 57 48 45 4e 20 78 3d 77 31 20 54 48 45 4e 20   WHEN x=w1 THEN 
5c10: 72 31 20 57 48 45 4e 20 78 3d 77 32 20 54 48 45  r1 WHEN x=w2 THE
5c20: 4e 20 72 32 20 45 4c 53 45 20 72 33 20 45 4e 44  N r2 ELSE r3 END
5c30: 0a 3c 2f 70 72 65 3e 3c 2f 75 6c 3e 0a 0a 0a 3c  .</pre></ul>...<
5c40: 61 20 6e 61 6d 65 3d 22 69 6e 5f 6f 70 22 3e 3c  a name="in_op"><
5c50: 2f 61 3e 0a 0a 3c 68 33 3e 54 68 65 20 49 4e 20  /a>..<h3>The IN 
5c60: 61 6e 64 20 4e 4f 54 20 49 4e 20 6f 70 65 72 61  and NOT IN opera
5c70: 74 6f 72 73 3c 2f 68 33 3e 0a 3c 70 3e 54 68 65  tors</h3>.<p>The
5c80: 20 49 4e 20 61 6e 64 20 4e 4f 54 20 49 4e 20 6f   IN and NOT IN o
5c90: 70 65 72 61 74 6f 72 73 20 74 61 6b 65 20 61 20  perators take a 
5ca0: 73 69 6e 67 6c 65 20 73 63 61 6c 61 72 20 6f 70  single scalar op
5cb0: 65 72 61 6e 64 20 6f 6e 20 74 68 65 0a 6c 65 66  erand on the.lef
5cc0: 74 20 61 6e 64 20 61 20 76 65 63 74 6f 72 20 6f  t and a vector o
5cd0: 70 65 72 61 6e 64 20 6f 6e 20 74 68 65 20 72 69  perand on the ri
5ce0: 67 68 74 0a 66 6f 72 6d 65 64 20 62 79 20 61 6e  ght.formed by an
5cf0: 20 65 78 70 6c 69 63 69 74 20 6c 69 73 74 20 6f   explicit list o
5d00: 66 20 7a 65 72 6f 20 6f 72 20 6d 6f 72 65 20 73  f zero or more s
5d10: 63 61 6c 61 72 73 20 6f 72 20 62 79 20 61 20 0a  calars or by a .
5d20: 73 69 6e 67 6c 65 20 73 75 62 71 75 65 72 79 2e  single subquery.
5d30: 0a 57 68 65 6e 20 74 68 65 20 72 69 67 68 74 20  .When the right 
5d40: 6f 70 65 72 61 6e 64 20 6f 66 20 61 6e 20 49 4e  operand of an IN
5d50: 20 6f 72 20 4e 4f 54 20 49 4e 20 6f 70 65 72 61   or NOT IN opera
5d60: 74 6f 72 20 69 73 20 61 20 73 75 62 71 75 65 72  tor is a subquer
5d70: 79 2c 20 74 68 65 0a 73 75 62 71 75 65 72 79 20  y, the.subquery 
5d80: 6d 75 73 74 20 68 61 76 65 20 61 20 73 69 6e 67  must have a sing
5d90: 6c 65 20 72 65 73 75 6c 74 20 63 6f 6c 75 6d 6e  le result column
5da0: 2e 0a 57 68 65 6e 20 74 68 65 20 72 69 67 68 74  ..When the right
5db0: 20 6f 70 65 72 61 6e 64 20 69 73 20 61 6e 20 65   operand is an e
5dc0: 6d 70 74 79 20 73 65 74 2c 20 74 68 65 20 72 65  mpty set, the re
5dd0: 73 75 6c 74 20 6f 66 20 49 4e 20 69 73 20 66 61  sult of IN is fa
5de0: 6c 73 65 20 61 6e 64 20 74 68 65 0a 72 65 73 75  lse and the.resu
5df0: 6c 74 20 6f 66 20 4e 4f 54 20 49 4e 20 69 73 20  lt of NOT IN is 
5e00: 74 72 75 65 2c 20 72 65 67 61 72 64 6c 65 73 73  true, regardless
5e10: 20 6f 66 20 74 68 65 20 6c 65 66 74 20 6f 70 65   of the left ope
5e20: 72 61 6e 64 20 61 6e 64 20 65 76 65 6e 20 69 66  rand and even if
5e30: 20 74 68 65 0a 6c 65 66 74 20 6f 70 65 72 61 6e   the.left operan
5e40: 64 20 69 73 20 4e 55 4c 4c 2e 0a 54 68 65 20 72  d is NULL..The r
5e50: 65 73 75 6c 74 20 6f 66 20 61 6e 20 49 4e 20 6f  esult of an IN o
5e60: 72 20 4e 4f 54 20 49 4e 20 6f 70 65 72 61 74 6f  r NOT IN operato
5e70: 72 20 69 73 20 64 65 74 65 72 6d 69 6e 65 64 20  r is determined 
5e80: 62 79 20 74 68 65 20 66 6f 6c 6c 6f 77 69 6e 67  by the following
5e90: 0a 6d 61 74 72 69 78 3a 0a 0a 3c 63 65 6e 74 65  .matrix:..<cente
5ea0: 72 3e 0a 3c 74 61 62 6c 65 20 62 6f 72 64 65 72  r>.<table border
5eb0: 3d 31 3e 0a 3c 74 72 3e 0a 3c 74 68 3e 4c 65 66  =1>.<tr>.<th>Lef
5ec0: 74 20 6f 70 65 72 61 6e 64 20 3c 62 72 3e 69 73  t operand <br>is
5ed0: 20 4e 55 4c 4c 0a 3c 74 68 3e 52 69 67 68 74 20   NULL.<th>Right 
5ee0: 6f 70 65 72 61 6e 64 20 3c 62 72 3e 63 6f 6e 74  operand <br>cont
5ef0: 61 69 6e 73 20 4e 55 4c 4c 0a 3c 74 68 3e 52 69  ains NULL.<th>Ri
5f00: 67 68 74 20 6f 70 65 72 61 6e 64 20 3c 62 72 3e  ght operand <br>
5f10: 69 73 20 61 6e 20 65 6d 70 74 79 20 73 65 74 0a  is an empty set.
5f20: 3c 74 68 3e 4c 65 66 74 20 6f 70 65 72 61 6e 64  <th>Left operand
5f30: 20 66 6f 75 6e 64 20 3c 62 72 3e 77 69 74 68 69   found <br>withi
5f40: 6e 20 72 69 67 68 74 20 6f 70 65 72 61 6e 64 0a  n right operand.
5f50: 3c 74 68 3e 52 65 73 75 6c 74 20 6f 66 20 3c 62  <th>Result of <b
5f60: 72 3e 49 4e 20 6f 70 65 72 61 74 6f 72 0a 3c 74  r>IN operator.<t
5f70: 68 3e 52 65 73 75 6c 74 20 6f 66 20 3c 62 72 3e  h>Result of <br>
5f80: 4e 4f 54 20 49 4e 20 6f 70 65 72 61 74 6f 72 0a  NOT IN operator.
5f90: 3c 74 72 3e 0a 3c 74 64 20 61 6c 69 67 6e 3d 22  <tr>.<td align="
5fa0: 63 65 6e 74 65 72 22 3e 6e 6f 0a 3c 74 64 20 61  center">no.<td a
5fb0: 6c 69 67 6e 3d 22 63 65 6e 74 65 72 22 3e 6e 6f  lign="center">no
5fc0: 0a 3c 74 64 20 61 6c 69 67 6e 3d 22 63 65 6e 74  .<td align="cent
5fd0: 65 72 22 3e 6e 6f 0a 3c 74 64 20 61 6c 69 67 6e  er">no.<td align
5fe0: 3d 22 63 65 6e 74 65 72 22 3e 6e 6f 0a 3c 74 64  ="center">no.<td
5ff0: 20 61 6c 69 67 6e 3d 22 63 65 6e 74 65 72 22 3e   align="center">
6000: 66 61 6c 73 65 0a 3c 74 64 20 61 6c 69 67 6e 3d  false.<td align=
6010: 22 63 65 6e 74 65 72 22 3e 74 72 75 65 0a 3c 74  "center">true.<t
6020: 72 3e 0a 3c 74 64 20 61 6c 69 67 6e 3d 22 63 65  r>.<td align="ce
6030: 6e 74 65 72 22 3e 64 6f 65 73 20 6e 6f 74 20 6d  nter">does not m
6040: 61 74 74 65 72 0a 3c 74 64 20 61 6c 69 67 6e 3d  atter.<td align=
6050: 22 63 65 6e 74 65 72 22 3e 6e 6f 0a 3c 74 64 20  "center">no.<td 
6060: 61 6c 69 67 6e 3d 22 63 65 6e 74 65 72 22 3e 79  align="center">y
6070: 65 73 0a 3c 74 64 20 61 6c 69 67 6e 3d 22 63 65  es.<td align="ce
6080: 6e 74 65 72 22 3e 6e 6f 0a 3c 74 64 20 61 6c 69  nter">no.<td ali
6090: 67 6e 3d 22 63 65 6e 74 65 72 22 3e 66 61 6c 73  gn="center">fals
60a0: 65 0a 3c 74 64 20 61 6c 69 67 6e 3d 22 63 65 6e  e.<td align="cen
60b0: 74 65 72 22 3e 74 72 75 65 0a 3c 74 72 3e 0a 3c  ter">true.<tr>.<
60c0: 74 64 20 61 6c 69 67 6e 3d 22 63 65 6e 74 65 72  td align="center
60d0: 22 3e 6e 6f 0a 3c 74 64 20 61 6c 69 67 6e 3d 22  ">no.<td align="
60e0: 63 65 6e 74 65 72 22 3e 64 6f 65 73 20 6e 6f 74  center">does not
60f0: 20 6d 61 74 74 65 72 0a 3c 74 64 20 61 6c 69 67   matter.<td alig
6100: 6e 3d 22 63 65 6e 74 65 72 22 3e 6e 6f 0a 3c 74  n="center">no.<t
6110: 64 20 61 6c 69 67 6e 3d 22 63 65 6e 74 65 72 22  d align="center"
6120: 3e 79 65 73 0a 3c 74 64 20 61 6c 69 67 6e 3d 22  >yes.<td align="
6130: 63 65 6e 74 65 72 22 3e 74 72 75 65 0a 3c 74 64  center">true.<td
6140: 20 61 6c 69 67 6e 3d 22 63 65 6e 74 65 72 22 3e   align="center">
6150: 66 61 6c 73 65 0a 3c 74 72 3e 0a 3c 74 64 20 61  false.<tr>.<td a
6160: 6c 69 67 6e 3d 22 63 65 6e 74 65 72 22 3e 6e 6f  lign="center">no
6170: 0a 3c 74 64 20 61 6c 69 67 6e 3d 22 63 65 6e 74  .<td align="cent
6180: 65 72 22 3e 79 65 73 0a 3c 74 64 20 61 6c 69 67  er">yes.<td alig
6190: 6e 3d 22 63 65 6e 74 65 72 22 3e 6e 6f 0a 3c 74  n="center">no.<t
61a0: 64 20 61 6c 69 67 6e 3d 22 63 65 6e 74 65 72 22  d align="center"
61b0: 3e 6e 6f 0a 3c 74 64 20 61 6c 69 67 6e 3d 22 63  >no.<td align="c
61c0: 65 6e 74 65 72 22 3e 4e 55 4c 4c 0a 3c 74 64 20  enter">NULL.<td 
61d0: 61 6c 69 67 6e 3d 22 63 65 6e 74 65 72 22 3e 4e  align="center">N
61e0: 55 4c 4c 0a 3c 74 72 3e 0a 3c 74 64 20 61 6c 69  ULL.<tr>.<td ali
61f0: 67 6e 3d 22 63 65 6e 74 65 72 22 3e 79 65 73 0a  gn="center">yes.
6200: 3c 74 64 20 61 6c 69 67 6e 3d 22 63 65 6e 74 65  <td align="cente
6210: 72 22 3e 64 6f 65 73 20 6e 6f 74 20 6d 61 74 74  r">does not matt
6220: 65 72 0a 3c 74 64 20 61 6c 69 67 6e 3d 22 63 65  er.<td align="ce
6230: 6e 74 65 72 22 3e 6e 6f 0a 3c 74 64 20 61 6c 69  nter">no.<td ali
6240: 67 6e 3d 22 63 65 6e 74 65 72 22 3e 64 6f 65 73  gn="center">does
6250: 20 6e 6f 74 20 6d 61 74 74 65 72 0a 3c 74 64 20   not matter.<td 
6260: 61 6c 69 67 6e 3d 22 63 65 6e 74 65 72 22 3e 4e  align="center">N
6270: 55 4c 4c 0a 3c 74 64 20 61 6c 69 67 6e 3d 22 63  ULL.<td align="c
6280: 65 6e 74 65 72 22 3e 4e 55 4c 4c 0a 3c 2f 74 61  enter">NULL.</ta
6290: 62 6c 65 3e 0a 3c 2f 63 65 6e 74 65 72 3e 0a 0a  ble>.</center>..
62a0: 3c 70 3e 4e 6f 74 65 20 74 68 61 74 20 53 51 4c  <p>Note that SQL
62b0: 69 74 65 20 61 6c 6c 6f 77 73 20 74 68 65 20 70  ite allows the p
62c0: 61 72 65 6e 74 68 65 73 69 7a 65 64 20 6c 69 73  arenthesized lis
62d0: 74 20 6f 66 20 73 63 61 6c 61 72 20 76 61 6c 75  t of scalar valu
62e0: 65 73 20 6f 6e 0a 74 68 65 20 72 69 67 68 74 2d  es on.the right-
62f0: 68 61 6e 64 20 73 69 64 65 20 6f 66 20 61 6e 20  hand side of an 
6300: 49 4e 20 6f 72 20 4e 4f 54 20 49 4e 20 6f 70 65  IN or NOT IN ope
6310: 72 61 74 6f 72 20 74 6f 20 62 65 20 61 6e 20 65  rator to be an e
6320: 6d 70 74 79 20 6c 69 73 74 20 62 75 74 0a 6d 6f  mpty list but.mo
6330: 73 74 20 6f 74 68 65 72 20 53 51 4c 20 64 61 74  st other SQL dat
6340: 61 62 61 73 65 20 64 61 74 61 62 61 73 65 20 65  abase database e
6350: 6e 67 69 6e 65 73 20 61 6e 64 20 74 68 65 20 53  ngines and the S
6360: 51 4c 39 32 20 73 74 61 6e 64 61 72 64 20 72 65  QL92 standard re
6370: 71 75 69 72 65 0a 74 68 65 20 6c 69 73 74 20 74  quire.the list t
6380: 6f 20 63 6f 6e 74 61 69 6e 20 61 74 20 6c 65 61  o contain at lea
6390: 73 74 20 6f 6e 65 20 65 6c 65 6d 65 6e 74 2e 3c  st one element.<
63a0: 2f 70 3e 0a 0a 3c 61 20 6e 61 6d 65 3d 22 69 6e  /p>..<a name="in
63b0: 5f 6f 70 22 3e 3c 2f 61 3e 0a 0a 3c 68 33 3e 54  _op"></a>..<h3>T
63c0: 68 65 20 45 58 49 53 54 53 20 6f 70 65 72 61 74  he EXISTS operat
63d0: 6f 72 3c 2f 68 33 3e 0a 0a 3c 70 3e 54 68 65 20  or</h3>..<p>The 
63e0: 45 58 49 53 54 53 20 6f 70 65 72 61 74 6f 72 20  EXISTS operator 
63f0: 61 6c 77 61 79 73 20 65 76 61 6c 75 61 74 65 73  always evaluates
6400: 20 74 6f 20 6f 6e 65 20 6f 66 20 74 68 65 20 69   to one of the i
6410: 6e 74 65 67 65 72 20 76 61 6c 75 65 73 20 30 20  nteger values 0 
6420: 0a 61 6e 64 20 31 2e 20 49 66 20 65 78 65 63 75  .and 1. If execu
6430: 74 69 6e 67 20 74 68 65 20 53 45 4c 45 43 54 20  ting the SELECT 
6440: 73 74 61 74 65 6d 65 6e 74 20 73 70 65 63 69 66  statement specif
6450: 69 65 64 20 61 73 20 74 68 65 20 72 69 67 68 74  ied as the right
6460: 2d 68 61 6e 64 20 0a 6f 70 65 72 61 6e 64 20 6f  -hand .operand o
6470: 66 20 74 68 65 20 45 58 49 53 54 53 20 6f 70 65  f the EXISTS ope
6480: 72 61 74 6f 72 20 77 6f 75 6c 64 20 72 65 74 75  rator would retu
6490: 72 6e 20 6f 6e 65 20 6f 72 20 6d 6f 72 65 20 72  rn one or more r
64a0: 6f 77 73 2c 20 74 68 65 6e 20 74 68 65 0a 45 58  ows, then the.EX
64b0: 49 53 54 53 20 6f 70 65 72 61 74 6f 72 20 65 76  ISTS operator ev
64c0: 61 6c 75 61 74 65 73 20 74 6f 20 31 2e 20 49 66  aluates to 1. If
64d0: 20 65 78 65 63 75 74 69 6e 67 20 74 68 65 20 53   executing the S
64e0: 45 4c 45 43 54 20 77 6f 75 6c 64 20 72 65 74 75  ELECT would retu
64f0: 72 6e 0a 6e 6f 20 72 6f 77 73 20 61 74 20 61 6c  rn.no rows at al
6500: 6c 2c 20 74 68 65 6e 20 74 68 65 20 45 58 49 53  l, then the EXIS
6510: 54 53 20 6f 70 65 72 61 74 6f 72 20 65 76 61 6c  TS operator eval
6520: 75 61 74 65 73 20 74 6f 20 30 2e 20 0a 0a 3c 70  uates to 0. ..<p
6530: 3e 54 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 63  >The number of c
6540: 6f 6c 75 6d 6e 73 20 69 6e 20 65 61 63 68 20 72  olumns in each r
6550: 6f 77 20 72 65 74 75 72 6e 65 64 20 62 79 20 74  ow returned by t
6560: 68 65 20 53 45 4c 45 43 54 20 73 74 61 74 65 6d  he SELECT statem
6570: 65 6e 74 0a 28 69 66 20 61 6e 79 29 20 61 6e 64  ent.(if any) and
6580: 20 74 68 65 20 73 70 65 63 69 66 69 63 20 76 61   the specific va
6590: 6c 75 65 73 20 72 65 74 75 72 6e 65 64 20 68 61  lues returned ha
65a0: 76 65 20 6e 6f 20 65 66 66 65 63 74 20 6f 6e 20  ve no effect on 
65b0: 74 68 65 20 72 65 73 75 6c 74 73 0a 6f 66 20 74  the results.of t
65c0: 68 65 20 45 58 49 53 54 53 20 6f 70 65 72 61 74  he EXISTS operat
65d0: 6f 72 2e 20 49 6e 20 70 61 72 74 69 63 75 6c 61  or. In particula
65e0: 72 2c 20 72 6f 77 73 20 63 6f 6e 74 61 69 6e 69  r, rows containi
65f0: 6e 67 20 4e 55 4c 4c 20 76 61 6c 75 65 73 20 61  ng NULL values a
6600: 72 65 0a 6e 6f 74 20 68 61 6e 64 6c 65 64 20 61  re.not handled a
6610: 6e 79 20 64 69 66 66 65 72 65 6e 74 6c 79 20 66  ny differently f
6620: 72 6f 6d 20 72 6f 77 73 20 77 69 74 68 6f 75 74  rom rows without
6630: 20 4e 55 4c 4c 20 76 61 6c 75 65 73 2e 0a 0a 3c   NULL values...<
6640: 68 33 3e 53 63 61 6c 61 72 20 53 75 62 71 75 65  h3>Scalar Subque
6650: 72 69 65 73 3c 2f 68 33 3e 0a 0a 3c 70 3e 41 20  ries</h3>..<p>A 
6660: 3c 61 20 68 72 65 66 3d 22 6c 61 6e 67 5f 73 65  <a href="lang_se
6670: 6c 65 63 74 2e 68 74 6d 6c 22 3e 53 45 4c 45 43  lect.html">SELEC
6680: 54 3c 2f 61 3e 20 73 74 61 74 65 6d 65 6e 74 20  T</a> statement 
6690: 65 6e 63 6c 6f 73 65 64 20 69 6e 20 70 61 72 65  enclosed in pare
66a0: 6e 74 68 65 73 65 73 20 6d 61 79 20 61 70 70 65  ntheses may appe
66b0: 61 72 20 61 73 20 61 20 73 63 61 6c 61 72 0a 71  ar as a scalar.q
66c0: 75 61 6e 74 69 74 79 2e 20 41 20 3c 61 20 68 72  uantity. A <a hr
66d0: 65 66 3d 22 6c 61 6e 67 5f 73 65 6c 65 63 74 2e  ef="lang_select.
66e0: 68 74 6d 6c 22 3e 53 45 4c 45 43 54 3c 2f 61 3e  html">SELECT</a>
66f0: 20 75 73 65 64 20 61 73 20 61 20 73 63 61 6c 61   used as a scala
6700: 72 20 71 75 61 6e 74 69 74 79 20 6d 75 73 74 20  r quantity must 
6710: 72 65 74 75 72 6e 20 61 20 72 65 73 75 6c 74 20  return a result 
6720: 73 65 74 0a 77 69 74 68 20 61 20 73 69 6e 67 6c  set.with a singl
6730: 65 20 63 6f 6c 75 6d 6e 2e 20 54 68 65 20 72 65  e column. The re
6740: 73 75 6c 74 20 6f 66 20 74 68 65 20 65 78 70 72  sult of the expr
6750: 65 73 73 69 6f 6e 20 69 73 20 74 68 65 20 76 61  ession is the va
6760: 6c 75 65 20 6f 66 20 74 68 65 0a 6f 6e 6c 79 20  lue of the.only 
6770: 63 6f 6c 75 6d 6e 20 69 6e 20 74 68 65 20 66 69  column in the fi
6780: 72 73 74 20 72 6f 77 20 72 65 74 75 72 6e 65 64  rst row returned
6790: 20 62 79 20 74 68 65 20 53 45 4c 45 43 54 20 73   by the SELECT s
67a0: 74 61 74 65 6d 65 6e 74 2e 20 49 66 20 74 68 65  tatement. If the
67b0: 20 53 45 4c 45 43 54 20 0a 79 69 65 6c 64 73 20   SELECT .yields 
67c0: 6d 6f 72 65 20 74 68 61 6e 20 6f 6e 65 20 72 65  more than one re
67d0: 73 75 6c 74 20 72 6f 77 2c 20 61 6c 6c 20 72 6f  sult row, all ro
67e0: 77 73 20 61 66 74 65 72 20 74 68 65 20 66 69 72  ws after the fir
67f0: 73 74 20 61 72 65 20 69 67 6e 6f 72 65 64 2e 20  st are ignored. 
6800: 49 66 0a 74 68 65 20 53 45 4c 45 43 54 20 79 69  If.the SELECT yi
6810: 65 6c 64 73 20 6e 6f 20 72 6f 77 73 2c 20 74 68  elds no rows, th
6820: 65 6e 20 74 68 65 20 76 61 6c 75 65 20 6f 66 20  en the value of 
6830: 74 68 65 20 65 78 70 72 65 73 73 69 6f 6e 20 69  the expression i
6840: 73 20 4e 55 4c 4c 2e 0a 54 68 65 20 4c 49 4d 49  s NULL..The LIMI
6850: 54 20 6f 66 20 61 20 73 63 61 6c 61 72 20 73 75  T of a scalar su
6860: 62 71 75 65 72 79 20 69 73 20 61 6c 77 61 79 73  bquery is always
6870: 20 31 2e 0a 41 6e 79 20 6f 74 68 65 72 20 4c 49   1..Any other LI
6880: 4d 49 54 20 76 61 6c 75 65 20 67 69 76 65 6e 20  MIT value given 
6890: 69 6e 20 74 68 65 20 53 51 4c 20 74 65 78 74 20  in the SQL text 
68a0: 69 73 20 69 67 6e 6f 72 65 64 2e 0a 0a 3c 70 3e  is ignored...<p>
68b0: 41 6c 6c 20 74 79 70 65 73 20 6f 66 20 3c 61 20  All types of <a 
68c0: 68 72 65 66 3d 22 6c 61 6e 67 5f 73 65 6c 65 63  href="lang_selec
68d0: 74 2e 68 74 6d 6c 22 3e 53 45 4c 45 43 54 3c 2f  t.html">SELECT</
68e0: 61 3e 20 73 74 61 74 65 6d 65 6e 74 2c 20 69 6e  a> statement, in
68f0: 63 6c 75 64 69 6e 67 20 61 67 67 72 65 67 61 74  cluding aggregat
6900: 65 20 61 6e 64 20 3c 61 20 68 72 65 66 3d 22 6c  e and <a href="l
6910: 61 6e 67 5f 73 65 6c 65 63 74 2e 68 74 6d 6c 23  ang_select.html#
6920: 63 6f 6d 70 6f 75 6e 64 22 3e 63 6f 6d 70 6f 75  compound">compou
6930: 6e 64 20 53 45 4c 45 43 54 3c 2f 61 3e 0a 71 75  nd SELECT</a>.qu
6940: 65 72 69 65 73 20 28 71 75 65 72 69 65 73 20 77  eries (queries w
6950: 69 74 68 20 6b 65 79 77 6f 72 64 73 20 6c 69 6b  ith keywords lik
6960: 65 20 55 4e 49 4f 4e 20 6f 72 20 45 58 43 45 50  e UNION or EXCEP
6970: 54 29 20 61 72 65 20 61 6c 6c 6f 77 65 64 20 61  T) are allowed a
6980: 73 20 73 63 61 6c 61 72 0a 73 75 62 71 75 65 72  s scalar.subquer
6990: 69 65 73 2e 0a 0a 3c 68 33 3e 54 61 62 6c 65 20  ies...<h3>Table 
69a0: 43 6f 6c 75 6d 6e 20 4e 61 6d 65 73 3c 2f 68 33  Column Names</h3
69b0: 3e 0a 0a 3c 70 3e 41 20 63 6f 6c 75 6d 6e 20 6e  >..<p>A column n
69c0: 61 6d 65 20 63 61 6e 20 62 65 20 61 6e 79 20 6f  ame can be any o
69d0: 66 20 74 68 65 20 6e 61 6d 65 73 20 64 65 66 69  f the names defi
69e0: 6e 65 64 20 69 6e 20 74 68 65 20 3c 61 20 68 72  ned in the <a hr
69f0: 65 66 3d 22 6c 61 6e 67 5f 63 72 65 61 74 65 74  ef="lang_createt
6a00: 61 62 6c 65 2e 68 74 6d 6c 22 3e 43 52 45 41 54  able.html">CREAT
6a10: 45 20 54 41 42 4c 45 3c 2f 61 3e 0a 73 74 61 74  E TABLE</a>.stat
6a20: 65 6d 65 6e 74 20 6f 72 20 6f 6e 65 20 6f 66 20  ement or one of 
6a30: 74 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 73 70  the following sp
6a40: 65 63 69 61 6c 20 69 64 65 6e 74 69 66 69 65 72  ecial identifier
6a50: 73 3a 20 22 3c 62 3e 52 4f 57 49 44 3c 2f 62 3e  s: "<b>ROWID</b>
6a60: 22 2c 0a 22 3c 62 3e 4f 49 44 3c 2f 62 3e 22 2c  ",."<b>OID</b>",
6a70: 20 6f 72 20 22 3c 62 3e 5f 52 4f 57 49 44 5f 3c   or "<b>_ROWID_<
6a80: 2f 62 3e 22 2e 0a 54 68 65 20 74 68 72 65 65 20  /b>"..The three 
6a90: 73 70 65 63 69 61 6c 20 69 64 65 6e 74 69 66 69  special identifi
6aa0: 65 72 73 20 64 65 73 63 72 69 62 65 20 74 68 65  ers describe the
6ab0: 0a 75 6e 69 71 75 65 20 69 6e 74 65 67 65 72 20  .unique integer 
6ac0: 6b 65 79 20 28 74 68 65 20 3c 61 20 68 72 65 66  key (the <a href
6ad0: 3d 22 6c 61 6e 67 5f 63 72 65 61 74 65 74 61 62  ="lang_createtab
6ae0: 6c 65 2e 68 74 6d 6c 23 72 6f 77 69 64 22 3e 72  le.html#rowid">r
6af0: 6f 77 69 64 3c 2f 61 3e 29 20 61 73 73 6f 63 69  owid</a>) associ
6b00: 61 74 65 64 20 77 69 74 68 20 65 76 65 72 79 20  ated with every 
6b10: 0a 72 6f 77 20 6f 66 20 65 76 65 72 79 20 74 61  .row of every ta
6b20: 62 6c 65 20 61 6e 64 20 73 6f 20 61 72 65 20 6e  ble and so are n
6b30: 6f 74 20 61 76 61 69 6c 61 62 6c 65 20 6f 6e 20  ot available on 
6b40: 3c 61 20 68 72 65 66 3d 22 77 69 74 68 6f 75 74  <a href="without
6b50: 72 6f 77 69 64 2e 68 74 6d 6c 22 3e 57 49 54 48  rowid.html">WITH
6b60: 4f 55 54 20 52 4f 57 49 44 3c 2f 61 3e 20 74 61  OUT ROWID</a> ta
6b70: 62 6c 65 73 2e 0a 54 68 65 20 73 70 65 63 69 61  bles..The specia
6b80: 6c 20 69 64 65 6e 74 69 66 69 65 72 73 20 6f 6e  l identifiers on
6b90: 6c 79 20 72 65 66 65 72 20 74 6f 20 74 68 65 20  ly refer to the 
6ba0: 72 6f 77 20 6b 65 79 20 69 66 20 74 68 65 20 3c  row key if the <
6bb0: 61 20 68 72 65 66 3d 22 6c 61 6e 67 5f 63 72 65  a href="lang_cre
6bc0: 61 74 65 74 61 62 6c 65 2e 68 74 6d 6c 22 3e 43  atetable.html">C
6bd0: 52 45 41 54 45 20 54 41 42 4c 45 3c 2f 61 3e 0a  REATE TABLE</a>.
6be0: 73 74 61 74 65 6d 65 6e 74 20 64 6f 65 73 20 6e  statement does n
6bf0: 6f 74 20 64 65 66 69 6e 65 20 61 20 72 65 61 6c  ot define a real
6c00: 20 63 6f 6c 75 6d 6e 20 77 69 74 68 20 74 68 65   column with the
6c10: 20 73 61 6d 65 20 6e 61 6d 65 2e 0a 54 68 65 20   same name..The 
6c20: 72 6f 77 69 64 20 63 61 6e 20 62 65 20 75 73 65  rowid can be use
6c30: 64 20 61 6e 79 77 68 65 72 65 20 61 20 72 65 67  d anywhere a reg
6c40: 75 6c 61 72 0a 63 6f 6c 75 6d 6e 20 63 61 6e 20  ular.column can 
6c50: 62 65 20 75 73 65 64 2e 3c 2f 70 3e 0a 0a 3c 70  be used.</p>..<p
6c60: 3e 41 20 3c 61 20 68 72 65 66 3d 22 6c 61 6e 67  >A <a href="lang
6c70: 5f 73 65 6c 65 63 74 2e 68 74 6d 6c 22 3e 53 45  _select.html">SE
6c80: 4c 45 43 54 3c 2f 61 3e 20 73 74 61 74 65 6d 65  LECT</a> stateme
6c90: 6e 74 20 75 73 65 64 20 61 73 20 65 69 74 68 65  nt used as eithe
6ca0: 72 20 61 20 73 63 61 6c 61 72 20 73 75 62 71 75  r a scalar subqu
6cb0: 65 72 79 20 6f 72 20 61 73 20 74 68 65 20 0a 72  ery or as the .r
6cc0: 69 67 68 74 2d 68 61 6e 64 20 6f 70 65 72 61 6e  ight-hand operan
6cd0: 64 20 6f 66 20 61 6e 20 49 4e 2c 20 4e 4f 54 20  d of an IN, NOT 
6ce0: 49 4e 20 6f 72 20 45 58 49 53 54 53 20 65 78 70  IN or EXISTS exp
6cf0: 72 65 73 73 69 6f 6e 20 6d 61 79 20 63 6f 6e 74  ression may cont
6d00: 61 69 6e 20 0a 72 65 66 65 72 65 6e 63 65 73 20  ain .references 
6d10: 74 6f 20 63 6f 6c 75 6d 6e 73 20 69 6e 20 74 68  to columns in th
6d20: 65 20 6f 75 74 65 72 20 71 75 65 72 79 2e 20 53  e outer query. S
6d30: 75 63 68 20 61 20 73 75 62 71 75 65 72 79 20 69  uch a subquery i
6d40: 73 20 6b 6e 6f 77 6e 20 61 73 0a 61 20 63 6f 72  s known as.a cor
6d50: 72 65 6c 61 74 65 64 20 73 75 62 71 75 65 72 79  related subquery
6d60: 2e 20 41 20 63 6f 72 72 65 6c 61 74 65 64 20 73  . A correlated s
6d70: 75 62 71 75 65 72 79 20 69 73 20 72 65 65 76 61  ubquery is reeva
6d80: 6c 75 61 74 65 64 20 65 61 63 68 20 74 69 6d 65  luated each time
6d90: 0a 69 74 73 20 72 65 73 75 6c 74 20 69 73 20 72  .its result is r
6da0: 65 71 75 69 72 65 64 2e 20 41 6e 20 75 6e 63 6f  equired. An unco
6db0: 72 72 65 6c 61 74 65 64 20 73 75 62 71 75 65 72  rrelated subquer
6dc0: 79 20 69 73 20 65 76 61 6c 75 61 74 65 64 20 6f  y is evaluated o
6dd0: 6e 6c 79 20 6f 6e 63 65 0a 61 6e 64 20 74 68 65  nly once.and the
6de0: 20 72 65 73 75 6c 74 20 72 65 75 73 65 64 20 61   result reused a
6df0: 73 20 6e 65 63 65 73 73 61 72 79 2e 0a 0a 3c 61  s necessary...<a
6e00: 20 6e 61 6d 65 3d 22 63 61 73 74 65 78 70 72 22   name="castexpr"
6e10: 3e 3c 2f 61 3e 0a 0a 3c 68 33 3e 43 41 53 54 20  ></a>..<h3>CAST 
6e20: 65 78 70 72 65 73 73 69 6f 6e 73 3c 2f 68 33 3e  expressions</h3>
6e30: 0a 0a 3c 70 3e 41 20 43 41 53 54 20 65 78 70 72  ..<p>A CAST expr
6e40: 65 73 73 69 6f 6e 20 6f 66 20 74 68 65 20 66 6f  ession of the fo
6e50: 72 6d 20 22 43 41 53 54 28 26 6c 74 3b 65 78 70  rm "CAST(&lt;exp
6e60: 72 26 67 74 3b 20 41 53 20 26 6c 74 3b 74 79 70  r&gt; AS &lt;typ
6e70: 65 2d 6e 61 6d 65 26 67 74 3b 29 22 0a 69 73 20  e-name&gt;)".is 
6e80: 75 73 65 64 20 74 6f 20 63 6f 6e 76 65 72 74 20  used to convert 
6e90: 74 68 65 20 76 61 6c 75 65 20 6f 66 20 26 6c 74  the value of &lt
6ea0: 3b 65 78 70 72 26 67 74 3b 20 74 6f 20 0a 61 20  ;expr&gt; to .a 
6eb0: 64 69 66 66 65 72 65 6e 74 20 3c 61 20 68 72 65  different <a hre
6ec0: 66 3d 22 64 61 74 61 74 79 70 65 33 2e 68 74 6d  f="datatype3.htm
6ed0: 6c 23 73 74 6f 72 61 67 65 63 6c 61 73 73 65 73  l#storageclasses
6ee0: 22 3e 73 74 6f 72 61 67 65 20 63 6c 61 73 73 3c  ">storage class<
6ef0: 2f 61 3e 20 73 70 65 63 69 66 69 65 64 20 62 79  /a> specified by
6f00: 20 26 6c 74 3b 74 79 70 65 2d 6e 61 6d 65 26 67   &lt;type-name&g
6f10: 74 3b 2e 0a 41 20 43 41 53 54 20 63 6f 6e 76 65  t;..A CAST conve
6f20: 72 73 69 6f 6e 20 69 73 20 73 69 6d 69 6c 61 72  rsion is similar
6f30: 20 74 6f 20 74 68 65 20 63 6f 6e 76 65 72 73 69   to the conversi
6f40: 6f 6e 20 74 68 61 74 20 74 61 6b 65 73 0a 70 6c  on that takes.pl
6f50: 61 63 65 20 77 68 65 6e 20 61 20 3c 61 20 68 72  ace when a <a hr
6f60: 65 66 3d 22 64 61 74 61 74 79 70 65 33 2e 68 74  ef="datatype3.ht
6f70: 6d 6c 23 61 66 66 69 6e 69 74 79 22 3e 63 6f 6c  ml#affinity">col
6f80: 75 6d 6e 20 61 66 66 69 6e 69 74 79 3c 2f 61 3e  umn affinity</a>
6f90: 20 69 73 20 61 70 70 6c 69 65 64 20 74 6f 20 61   is applied to a
6fa0: 20 76 61 6c 75 65 20 65 78 63 65 70 74 20 74 68   value except th
6fb0: 61 74 20 77 69 74 68 0a 74 68 65 20 43 41 53 54  at with.the CAST
6fc0: 20 6f 70 65 72 61 74 6f 72 20 74 68 65 20 63 6f   operator the co
6fd0: 6e 76 65 72 73 69 6f 6e 20 61 6c 77 61 79 73 20  nversion always 
6fe0: 74 61 6b 65 73 20 70 6c 61 63 65 20 65 76 65 6e  takes place even
6ff0: 20 69 66 20 74 68 65 20 63 6f 6e 76 65 72 73 69   if the conversi
7000: 6f 6e 0a 6c 6f 73 73 79 20 61 6e 64 20 69 72 72  on.lossy and irr
7010: 65 76 65 72 73 69 62 6c 65 2c 20 77 68 65 72 65  eversible, where
7020: 61 73 20 63 6f 6c 75 6d 6e 20 61 66 66 69 6e 69  as column affini
7030: 74 79 20 6f 6e 6c 79 20 63 68 61 6e 67 65 73 20  ty only changes 
7040: 74 68 65 20 64 61 74 61 20 74 79 70 65 0a 6f 66  the data type.of
7050: 20 61 20 76 61 6c 75 65 20 69 66 20 74 68 65 20   a value if the 
7060: 63 68 61 6e 67 65 20 69 73 20 6c 6f 73 73 6c 65  change is lossle
7070: 73 73 20 61 6e 64 20 72 65 76 65 72 73 69 62 6c  ss and reversibl
7080: 65 2e 0a 0a 3c 70 3e 49 66 20 74 68 65 20 76 61  e...<p>If the va
7090: 6c 75 65 20 6f 66 20 26 6c 74 3b 65 78 70 72 26  lue of &lt;expr&
70a0: 67 74 3b 20 69 73 20 4e 55 4c 4c 2c 20 74 68 65  gt; is NULL, the
70b0: 6e 20 74 68 65 20 72 65 73 75 6c 74 20 6f 66 20  n the result of 
70c0: 74 68 65 20 43 41 53 54 0a 65 78 70 72 65 73 73  the CAST.express
70d0: 69 6f 6e 20 69 73 20 61 6c 73 6f 20 4e 55 4c 4c  ion is also NULL
70e0: 2e 20 4f 74 68 65 72 77 69 73 65 2c 20 74 68 65  . Otherwise, the
70f0: 20 73 74 6f 72 61 67 65 20 63 6c 61 73 73 20 6f   storage class o
7100: 66 20 74 68 65 20 72 65 73 75 6c 74 0a 69 73 20  f the result.is 
7110: 64 65 74 65 72 6d 69 6e 65 64 20 62 79 20 61 70  determined by ap
7120: 70 6c 79 69 6e 67 20 74 68 65 20 3c 61 20 68 72  plying the <a hr
7130: 65 66 3d 22 64 61 74 61 74 79 70 65 33 2e 68 74  ef="datatype3.ht
7140: 6d 6c 23 61 66 66 6e 61 6d 65 22 3e 72 75 6c 65  ml#affname">rule
7150: 73 20 66 6f 72 20 64 65 74 65 72 6d 69 6e 69 6e  s for determinin
7160: 67 20 63 6f 6c 75 6d 6e 20 61 66 66 69 6e 69 74  g column affinit
7170: 79 3c 2f 61 3e 20 74 6f 0a 74 68 65 20 26 6c 74  y</a> to.the &lt
7180: 3b 74 79 70 65 2d 6e 61 6d 65 26 67 74 3b 2e 0a  ;type-name&gt;..
7190: 0a 3c 74 61 62 6c 65 20 62 6f 72 64 65 72 3d 31  .<table border=1
71a0: 3e 0a 3c 74 72 3e 0a 20 20 3c 74 68 3e 20 41 66  >.<tr>.  <th> Af
71b0: 66 69 6e 69 74 79 20 6f 66 20 26 6c 74 3b 74 79  finity of &lt;ty
71c0: 70 65 2d 6e 61 6d 65 26 67 74 3b 0a 20 20 3c 74  pe-name&gt;.  <t
71d0: 68 3e 20 43 6f 6e 76 65 72 73 69 6f 6e 20 50 72  h> Conversion Pr
71e0: 6f 63 65 73 73 69 6e 67 0a 3c 74 72 3e 0a 20 20  ocessing.<tr>.  
71f0: 3c 74 64 3e 20 4e 4f 4e 45 20 0a 20 20 3c 74 64  <td> NONE .  <td
7200: 3e 20 43 61 73 74 69 6e 67 20 61 20 76 61 6c 75  > Casting a valu
7210: 65 20 74 6f 20 61 20 26 6c 74 3b 74 79 70 65 2d  e to a &lt;type-
7220: 6e 61 6d 65 26 67 74 3b 20 77 69 74 68 20 6e 6f  name&gt; with no
7230: 20 61 66 66 69 6e 69 74 79 20 63 61 75 73 65 73   affinity causes
7240: 20 74 68 65 20 76 61 6c 75 65 20 74 6f 0a 20 20   the value to.  
7250: 62 65 20 63 6f 6e 76 65 72 74 65 64 20 69 6e 74  be converted int
7260: 6f 20 61 20 42 4c 4f 42 2e 20 20 43 61 73 74 69  o a BLOB.  Casti
7270: 6e 67 20 74 6f 20 61 20 42 4c 4f 42 20 63 6f 6e  ng to a BLOB con
7280: 73 69 73 74 73 20 6f 66 20 66 69 72 73 74 20 63  sists of first c
7290: 61 73 74 69 6e 67 0a 20 20 74 68 65 20 76 61 6c  asting.  the val
72a0: 75 65 20 74 6f 20 54 45 58 54 20 69 6e 20 74 68  ue to TEXT in th
72b0: 65 20 3c 61 20 68 72 65 66 3d 22 70 72 61 67 6d  e <a href="pragm
72c0: 61 2e 68 74 6d 6c 23 70 72 61 67 6d 61 5f 65 6e  a.html#pragma_en
72d0: 63 6f 64 69 6e 67 22 3e 65 6e 63 6f 64 69 6e 67  coding">encoding
72e0: 3c 2f 61 3e 20 6f 66 20 74 68 65 20 64 61 74 61  </a> of the data
72f0: 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 2c  base connection,
7300: 20 74 68 65 6e 0a 20 20 69 6e 74 65 72 70 72 65   then.  interpre
7310: 74 69 6e 67 20 74 68 65 20 72 65 73 75 6c 74 69  ting the resulti
7320: 6e 67 20 62 79 74 65 20 73 65 71 75 65 6e 63 65  ng byte sequence
7330: 20 61 73 20 61 20 42 4c 4f 42 20 69 6e 73 74 65   as a BLOB inste
7340: 61 64 20 6f 66 20 61 73 20 54 45 58 54 2e 0a 0a  ad of as TEXT...
7350: 3c 74 72 3e 0a 20 20 3c 74 64 3e 20 54 45 58 54  <tr>.  <td> TEXT
7360: 0a 20 20 3c 74 64 3e 20 54 6f 20 63 61 73 74 20  .  <td> To cast 
7370: 61 20 42 4c 4f 42 20 76 61 6c 75 65 20 74 6f 20  a BLOB value to 
7380: 54 45 58 54 2c 20 74 68 65 20 73 65 71 75 65 6e  TEXT, the sequen
7390: 63 65 20 6f 66 20 62 79 74 65 73 20 74 68 61 74  ce of bytes that
73a0: 20 6d 61 6b 65 20 75 70 20 74 68 65 0a 20 20 42   make up the.  B
73b0: 4c 4f 42 20 69 73 20 69 6e 74 65 72 70 72 65 74  LOB is interpret
73c0: 65 64 20 61 73 20 74 65 78 74 20 65 6e 63 6f 64  ed as text encod
73d0: 65 64 20 75 73 69 6e 67 20 74 68 65 20 64 61 74  ed using the dat
73e0: 61 62 61 73 65 20 65 6e 63 6f 64 69 6e 67 2e 0a  abase encoding..
73f0: 20 20 3c 70 3e 0a 20 20 20 43 61 73 74 69 6e 67    <p>.   Casting
7400: 20 61 6e 20 49 4e 54 45 47 45 52 20 6f 72 20 52   an INTEGER or R
7410: 45 41 4c 20 76 61 6c 75 65 20 69 6e 74 6f 20 54  EAL value into T
7420: 45 58 54 20 72 65 6e 64 65 72 73 20 74 68 65 20  EXT renders the 
7430: 76 61 6c 75 65 20 61 73 20 69 66 20 76 69 61 20  value as if via 
7440: 0a 20 20 20 20 3c 61 20 68 72 65 66 3d 22 63 33  .    <a href="c3
7450: 72 65 66 2f 6d 70 72 69 6e 74 66 2e 68 74 6d 6c  ref/mprintf.html
7460: 22 3e 73 71 6c 69 74 65 33 5f 73 6e 70 72 69 6e  ">sqlite3_snprin
7470: 74 66 28 29 3c 2f 61 3e 20 65 78 63 65 70 74 20  tf()</a> except 
7480: 74 68 61 74 20 74 68 65 20 72 65 73 75 6c 74 69  that the resulti
7490: 6e 67 20 54 45 58 54 20 75 73 65 73 20 74 68 65  ng TEXT uses the
74a0: 20 3c 61 20 68 72 65 66 3d 22 70 72 61 67 6d 61   <a href="pragma
74b0: 2e 68 74 6d 6c 23 70 72 61 67 6d 61 5f 65 6e 63  .html#pragma_enc
74c0: 6f 64 69 6e 67 22 3e 65 6e 63 6f 64 69 6e 67 3c  oding">encoding<
74d0: 2f 61 3e 20 6f 66 0a 20 20 20 20 74 68 65 20 64  /a> of.    the d
74e0: 61 74 61 62 61 73 65 20 63 6f 6e 6e 65 63 74 69  atabase connecti
74f0: 6f 6e 2e 0a 0a 3c 74 72 3e 0a 20 20 3c 74 64 3e  on...<tr>.  <td>
7500: 20 52 45 41 4c 0a 20 20 3c 74 64 3e 20 57 68 65   REAL.  <td> Whe
7510: 6e 20 63 61 73 74 69 6e 67 20 61 20 42 4c 4f 42  n casting a BLOB
7520: 20 76 61 6c 75 65 20 74 6f 20 61 20 52 45 41 4c   value to a REAL
7530: 2c 20 74 68 65 20 76 61 6c 75 65 20 69 73 20 66  , the value is f
7540: 69 72 73 74 20 63 6f 6e 76 65 72 74 65 64 20 74  irst converted t
7550: 6f 0a 20 20 20 20 20 20 20 20 54 45 58 54 2e 0a  o.        TEXT..
7560: 20 20 20 20 20 20 20 3c 70 3e 57 68 65 6e 20 63         <p>When c
7570: 61 73 74 69 6e 67 20 61 20 54 45 58 54 20 76 61  asting a TEXT va
7580: 6c 75 65 20 74 6f 20 52 45 41 4c 2c 20 74 68 65  lue to REAL, the
7590: 20 6c 6f 6e 67 65 73 74 20 70 6f 73 73 69 62 6c   longest possibl
75a0: 65 20 70 72 65 66 69 78 20 6f 66 0a 20 20 20 20  e prefix of.    
75b0: 20 20 20 20 74 68 65 20 76 61 6c 75 65 20 74 68      the value th
75c0: 61 74 20 63 61 6e 20 62 65 20 69 6e 74 65 72 70  at can be interp
75d0: 72 65 74 65 64 20 61 73 20 61 20 72 65 61 6c 20  reted as a real 
75e0: 6e 75 6d 62 65 72 20 69 73 20 65 78 74 72 61 63  number is extrac
75f0: 74 65 64 20 66 72 6f 6d 0a 20 20 20 20 20 20 20  ted from.       
7600: 20 74 68 65 20 54 45 58 54 20 76 61 6c 75 65 20   the TEXT value 
7610: 61 6e 64 20 74 68 65 20 72 65 6d 61 69 6e 64 65  and the remainde
7620: 72 20 69 67 6e 6f 72 65 64 2e 20 41 6e 79 20 6c  r ignored. Any l
7630: 65 61 64 69 6e 67 20 73 70 61 63 65 73 20 69 6e  eading spaces in
7640: 20 74 68 65 0a 20 20 20 20 20 20 20 20 54 45 58   the.        TEX
7650: 54 20 76 61 6c 75 65 20 61 72 65 20 69 67 6e 6f  T value are igno
7660: 72 65 64 20 77 68 65 6e 20 63 6f 6e 76 65 72 67  red when converg
7670: 69 6e 67 20 66 72 6f 6d 20 54 45 58 54 20 74 6f  ing from TEXT to
7680: 20 52 45 41 4c 2e 20 49 66 20 74 68 65 72 65 20   REAL. If there 
7690: 69 73 0a 20 20 20 20 20 20 20 20 6e 6f 20 70 72  is.        no pr
76a0: 65 66 69 78 20 74 68 61 74 20 63 61 6e 20 62 65  efix that can be
76b0: 20 69 6e 74 65 72 70 72 65 74 65 64 20 61 73 20   interpreted as 
76c0: 61 20 72 65 61 6c 20 6e 75 6d 62 65 72 2c 20 74  a real number, t
76d0: 68 65 20 72 65 73 75 6c 74 20 6f 66 20 74 68 65  he result of the
76e0: 0a 20 20 20 20 20 20 20 20 63 6f 6e 76 65 72 73  .        convers
76f0: 69 6f 6e 20 69 73 20 30 2e 30 2e 0a 0a 3c 74 72  ion is 0.0...<tr
7700: 3e 0a 20 20 3c 74 64 3e 20 49 4e 54 45 47 45 52  >.  <td> INTEGER
7710: 0a 20 20 3c 74 64 3e 20 57 68 65 6e 20 63 61 73  .  <td> When cas
7720: 74 69 6e 67 20 61 20 42 4c 4f 42 20 76 61 6c 75  ting a BLOB valu
7730: 65 20 74 6f 20 49 4e 54 45 47 45 52 2c 20 74 68  e to INTEGER, th
7740: 65 20 76 61 6c 75 65 20 69 73 20 66 69 72 73 74  e value is first
7750: 20 63 6f 6e 76 65 72 74 65 64 20 74 6f 0a 20 20   converted to.  
7760: 20 20 20 20 20 20 54 45 58 54 2e 0a 20 20 20 20        TEXT..    
7770: 20 20 20 3c 70 3e 57 68 65 6e 20 63 61 73 74 69     <p>When casti
7780: 6e 67 20 61 20 54 45 58 54 20 76 61 6c 75 65 20  ng a TEXT value 
7790: 74 6f 20 49 4e 54 45 47 45 52 2c 20 74 68 65 20  to INTEGER, the 
77a0: 6c 6f 6e 67 65 73 74 20 70 6f 73 73 69 62 6c 65  longest possible
77b0: 20 70 72 65 66 69 78 20 6f 66 0a 20 20 20 20 20   prefix of.     
77c0: 20 20 20 74 68 65 20 76 61 6c 75 65 20 74 68 61     the value tha
77d0: 74 20 63 61 6e 20 62 65 20 69 6e 74 65 72 70 72  t can be interpr
77e0: 65 74 65 64 20 61 73 20 61 6e 20 69 6e 74 65 67  eted as an integ
77f0: 65 72 20 6e 75 6d 62 65 72 20 69 73 20 65 78 74  er number is ext
7800: 72 61 63 74 65 64 20 66 72 6f 6d 0a 20 20 20 20  racted from.    
7810: 20 20 20 20 74 68 65 20 54 45 58 54 20 76 61 6c      the TEXT val
7820: 75 65 20 61 6e 64 20 74 68 65 20 72 65 6d 61 69  ue and the remai
7830: 6e 64 65 72 20 69 67 6e 6f 72 65 64 2e 20 41 6e  nder ignored. An
7840: 79 20 6c 65 61 64 69 6e 67 20 73 70 61 63 65 73  y leading spaces
7850: 20 69 6e 20 74 68 65 0a 20 20 20 20 20 20 20 20   in the.        
7860: 54 45 58 54 20 76 61 6c 75 65 20 77 68 65 6e 20  TEXT value when 
7870: 63 6f 6e 76 65 72 74 69 6e 67 20 66 72 6f 6d 20  converting from 
7880: 54 45 58 54 20 74 6f 20 49 4e 54 45 47 45 52 20  TEXT to INTEGER 
7890: 61 72 65 20 69 67 6e 6f 72 65 64 2e 20 49 66 20  are ignored. If 
78a0: 74 68 65 72 65 0a 20 20 20 20 20 20 20 20 69 73  there.        is
78b0: 20 6e 6f 20 70 72 65 66 69 78 20 74 68 61 74 20   no prefix that 
78c0: 63 61 6e 20 62 65 20 69 6e 74 65 72 70 72 65 74  can be interpret
78d0: 65 64 20 61 73 20 61 6e 20 69 6e 74 65 67 65 72  ed as an integer
78e0: 20 6e 75 6d 62 65 72 2c 20 74 68 65 20 72 65 73   number, the res
78f0: 75 6c 74 0a 20 20 20 20 20 20 20 20 6f 66 20 74  ult.        of t
7900: 68 65 20 63 6f 6e 76 65 72 73 69 6f 6e 20 69 73  he conversion is
7910: 20 30 2e 20 20 54 68 65 20 43 41 53 54 20 6f 70   0.  The CAST op
7920: 65 72 61 74 6f 72 20 75 6e 64 65 72 73 74 61 6e  erator understan
7930: 64 73 20 64 65 63 69 6d 61 6c 20 69 6e 74 65 67  ds decimal integ
7940: 65 72 73 0a 20 20 20 20 20 20 20 20 6f 6e 6c 79  ers.        only
7950: 20 26 6d 64 61 73 68 3b 20 63 6f 6e 76 65 72 73   &mdash; convers
7960: 69 6f 6e 20 6f 66 20 3c 61 20 68 72 65 66 3d 22  ion of <a href="
7970: 6c 61 6e 67 5f 65 78 70 72 2e 68 74 6d 6c 23 68  lang_expr.html#h
7980: 65 78 69 6e 74 22 3e 68 65 78 61 64 65 63 69 6d  exint">hexadecim
7990: 61 6c 20 69 6e 74 65 67 65 72 73 3c 2f 61 3e 20  al integers</a> 
79a0: 73 74 6f 70 73 20 61 74 20 74 68 65 20 22 78 22  stops at the "x"
79b0: 20 69 6e 20 74 68 65 0a 20 20 20 20 20 20 20 20   in the.        
79c0: 22 30 78 22 20 70 72 65 66 69 78 20 6f 66 20 74  "0x" prefix of t
79d0: 68 65 20 68 65 78 61 64 65 63 69 6d 61 6c 20 69  he hexadecimal i
79e0: 6e 74 65 67 65 72 20 73 74 72 69 6e 67 20 61 6e  nteger string an
79f0: 64 20 74 68 75 73 20 72 65 73 75 6c 74 20 6f 66  d thus result of
7a00: 20 74 68 65 20 0a 20 20 20 20 20 20 20 20 43 41   the .        CA
7a10: 53 54 20 69 73 20 61 6c 77 61 79 73 20 7a 65 72  ST is always zer
7a20: 6f 2e 0a 0a 20 20 20 20 20 20 3c 70 3e 41 20 63  o...      <p>A c
7a30: 61 73 74 20 6f 66 20 61 20 52 45 41 4c 20 76 61  ast of a REAL va
7a40: 6c 75 65 20 69 6e 74 6f 20 61 6e 20 49 4e 54 45  lue into an INTE
7a50: 47 45 52 20 72 65 73 75 6c 74 73 20 69 6e 20 74  GER results in t
7a60: 68 65 20 69 6e 74 65 67 65 72 0a 20 20 20 20 20  he integer.     
7a70: 20 62 65 74 77 65 65 6e 20 74 68 65 20 52 45 41   between the REA
7a80: 4c 20 76 61 6c 75 65 20 61 6e 64 20 7a 65 72 6f  L value and zero
7a90: 20 74 68 61 74 20 69 73 20 63 6c 6f 73 65 73 74   that is closest
7aa0: 20 74 6f 20 74 68 65 20 52 45 41 4c 20 76 61 6c   to the REAL val
7ab0: 75 65 2e 0a 20 20 20 20 20 20 49 66 20 61 20 52  ue..      If a R
7ac0: 45 41 4c 20 69 73 20 67 72 65 61 74 65 72 20 74  EAL is greater t
7ad0: 68 61 6e 20 74 68 65 20 67 72 65 61 74 65 73 74  han the greatest
7ae0: 20 70 6f 73 73 69 62 6c 65 20 73 69 67 6e 65 64   possible signed
7af0: 0a 20 20 20 20 20 20 69 6e 74 65 67 65 72 20 28  .      integer (
7b00: 2b 39 32 32 33 33 37 32 30 33 36 38 35 34 37 37  +922337203685477
7b10: 35 38 30 37 29 20 74 68 65 6e 20 74 68 65 20 72  5807) then the r
7b20: 65 73 75 6c 74 20 69 73 20 74 68 65 20 67 72 65  esult is the gre
7b30: 61 74 65 73 74 20 70 6f 73 73 69 62 6c 65 0a 20  atest possible. 
7b40: 20 20 20 20 20 73 69 67 6e 65 64 20 69 6e 74 65       signed inte
7b50: 67 65 72 20 61 6e 64 20 69 66 20 74 68 65 20 52  ger and if the R
7b60: 45 41 4c 20 69 73 20 6c 65 73 73 20 74 68 61 6e  EAL is less than
7b70: 20 74 68 65 20 6c 65 61 73 74 20 70 6f 73 73 69   the least possi
7b80: 62 6c 65 20 73 69 67 6e 65 64 0a 20 20 20 20 20  ble signed.     
7b90: 20 69 6e 74 65 67 65 72 20 28 2d 39 32 32 33 33   integer (-92233
7ba0: 37 32 30 33 36 38 35 34 37 37 35 38 30 38 29 20  72036854775808) 
7bb0: 74 68 65 6e 20 74 68 65 20 72 65 73 75 6c 74 20  then the result 
7bc0: 69 73 20 74 68 65 20 6c 65 61 73 74 20 70 6f 73  is the least pos
7bd0: 73 69 62 6c 65 0a 20 20 20 20 20 20 73 69 67 6e  sible.      sign
7be0: 65 64 20 69 6e 74 65 67 65 72 2e 0a 0a 20 20 20  ed integer...   
7bf0: 20 20 20 3c 70 3e 50 72 69 6f 72 20 74 6f 20 53     <p>Prior to S
7c00: 51 4c 69 74 65 20 76 65 72 73 69 6f 6e 20 33 2e  QLite version 3.
7c10: 38 2e 32 2c 20 63 61 73 74 69 6e 67 20 61 20 52  8.2, casting a R
7c20: 45 41 4c 20 76 61 6c 75 65 20 67 72 65 61 74 65  EAL value greate
7c30: 72 20 74 68 61 6e 0a 20 20 20 20 20 20 2b 39 32  r than.      +92
7c40: 32 33 33 37 32 30 33 36 38 35 34 37 37 35 38 30  2337203685477580
7c50: 37 2e 30 20 69 6e 74 6f 20 61 6e 20 69 6e 74 65  7.0 into an inte
7c60: 67 65 72 20 72 65 73 75 6c 74 65 64 20 69 6e 20  ger resulted in 
7c70: 74 68 65 20 6d 6f 73 74 20 6e 65 67 61 74 69 76  the most negativ
7c80: 65 0a 20 20 20 20 20 20 69 6e 74 65 67 65 72 2c  e.      integer,
7c90: 20 2d 39 32 32 33 33 37 32 30 33 36 38 35 34 37   -92233720368547
7ca0: 37 35 38 30 38 2e 20 20 54 68 69 73 20 62 65 68  75808.  This beh
7cb0: 61 76 69 6f 72 20 77 61 73 20 6d 65 61 6e 74 20  avior was meant 
7cc0: 74 6f 20 65 6d 75 6c 61 74 65 20 74 68 65 0a 20  to emulate the. 
7cd0: 20 20 20 20 20 62 65 68 61 76 69 6f 72 20 6f 66       behavior of
7ce0: 20 78 38 36 2f 78 36 34 20 68 61 72 64 77 61 72   x86/x64 hardwar
7cf0: 65 20 77 68 65 6e 20 64 6f 69 6e 67 20 74 68 65  e when doing the
7d00: 20 65 71 75 69 76 61 6c 65 6e 74 20 63 61 73 74   equivalent cast
7d10: 2e 0a 0a 3c 74 72 3e 0a 20 20 3c 74 64 3e 20 4e  ...<tr>.  <td> N
7d20: 55 4d 45 52 49 43 0a 20 20 3c 74 64 3e 20 43 61  UMERIC.  <td> Ca
7d30: 73 74 69 6e 67 20 61 20 54 45 58 54 20 6f 72 20  sting a TEXT or 
7d40: 42 4c 4f 42 20 76 61 6c 75 65 20 69 6e 74 6f 20  BLOB value into 
7d50: 4e 55 4d 45 52 49 43 20 66 69 72 73 74 20 64 6f  NUMERIC first do
7d60: 65 73 20 61 20 66 6f 72 63 65 64 0a 20 20 20 63  es a forced.   c
7d70: 6f 6e 76 65 72 73 69 6f 6e 20 69 6e 74 6f 20 52  onversion into R
7d80: 45 41 4c 20 62 75 74 20 74 68 65 6e 20 66 75 72  EAL but then fur
7d90: 74 68 65 72 20 63 6f 6e 76 65 72 74 73 20 74 68  ther converts th
7da0: 65 20 72 65 73 75 6c 74 20 69 6e 74 6f 20 49 4e  e result into IN
7db0: 54 45 47 45 52 20 69 66 0a 20 20 20 61 6e 64 20  TEGER if.   and 
7dc0: 6f 6e 6c 79 20 69 66 20 74 68 65 20 63 6f 6e 76  only if the conv
7dd0: 65 72 73 69 6f 6e 20 66 72 6f 6d 20 52 45 41 4c  ersion from REAL
7de0: 20 74 6f 20 49 4e 54 45 47 45 52 20 69 73 20 6c   to INTEGER is l
7df0: 6f 73 73 6c 65 73 73 20 61 6e 64 20 72 65 76 65  ossless and reve
7e00: 72 73 69 62 6c 65 2e 0a 20 20 20 54 68 69 73 20  rsible..   This 
7e10: 69 73 20 74 68 65 20 6f 6e 6c 79 20 63 6f 6e 74  is the only cont
7e20: 65 78 74 20 69 6e 20 53 51 4c 69 74 65 20 77 68  ext in SQLite wh
7e30: 65 72 65 20 74 68 65 20 4e 55 4d 45 52 49 43 20  ere the NUMERIC 
7e40: 61 6e 64 20 49 4e 54 45 47 45 52 20 3c 61 20 68  and INTEGER <a h
7e50: 72 65 66 3d 22 64 61 74 61 74 79 70 65 33 2e 68  ref="datatype3.h
7e60: 74 6d 6c 23 61 66 66 69 6e 69 74 79 22 3e 61 66  tml#affinity">af
7e70: 66 69 6e 69 74 69 65 73 3c 2f 61 3e 0a 20 20 20  finities</a>.   
7e80: 62 65 68 61 76 65 20 64 69 66 66 65 72 65 6e 74  behave different
7e90: 6c 79 2e 0a 20 20 20 3c 70 3e 20 43 61 73 74 69  ly..   <p> Casti
7ea0: 6e 67 20 61 20 52 45 41 4c 20 6f 72 20 49 4e 54  ng a REAL or INT
7eb0: 45 47 45 52 20 76 61 6c 75 65 20 74 6f 20 4e 55  EGER value to NU
7ec0: 4d 45 52 49 43 20 69 73 20 61 20 6e 6f 2d 6f 70  MERIC is a no-op
7ed0: 2c 20 65 76 65 6e 20 69 66 20 61 20 72 65 61 6c  , even if a real
7ee0: 0a 20 20 20 76 61 6c 75 65 20 63 6f 75 6c 64 20  .   value could 
7ef0: 62 65 20 6c 6f 73 73 6c 65 73 73 6c 79 20 63 6f  be losslessly co
7f00: 6e 76 65 72 74 65 64 20 74 6f 20 61 6e 20 69 6e  nverted to an in
7f10: 74 65 67 65 72 2e 0a 0a 3c 2f 74 72 3e 0a 0a 3c  teger...</tr>..<
7f20: 2f 74 61 62 6c 65 3e 0a 0a 3c 70 3e 4e 6f 74 65  /table>..<p>Note
7f30: 20 74 68 61 74 20 74 68 65 20 72 65 73 75 6c 74   that the result
7f40: 20 66 72 6f 6d 20 63 61 73 74 69 6e 67 20 61 6e   from casting an
7f50: 79 20 6e 6f 6e 2d 42 4c 4f 42 20 76 61 6c 75 65  y non-BLOB value
7f60: 20 69 6e 74 6f 20 61 20 0a 42 4c 4f 42 20 61 6e   into a .BLOB an
7f70: 64 20 74 68 65 20 72 65 73 75 6c 74 20 66 72 6f  d the result fro
7f80: 6d 20 63 61 73 74 69 6e 67 20 61 6e 79 20 42 4c  m casting any BL
7f90: 4f 42 20 76 61 6c 75 65 20 69 6e 74 6f 20 61 20  OB value into a 
7fa0: 6e 6f 6e 2d 42 4c 4f 42 20 76 61 6c 75 65 0a 6d  non-BLOB value.m
7fb0: 61 79 20 62 65 20 64 69 66 66 65 72 65 6e 74 20  ay be different 
7fc0: 64 65 70 65 6e 64 69 6e 67 20 6f 6e 20 77 68 65  depending on whe
7fd0: 74 68 65 72 20 74 68 65 20 64 61 74 61 62 61 73  ther the databas
7fe0: 65 20 3c 61 20 68 72 65 66 3d 22 70 72 61 67 6d  e <a href="pragm
7ff0: 61 2e 68 74 6d 6c 23 70 72 61 67 6d 61 5f 65 6e  a.html#pragma_en
8000: 63 6f 64 69 6e 67 22 3e 65 6e 63 6f 64 69 6e 67  coding">encoding
8010: 3c 2f 61 3e 20 69 73 20 55 54 46 2d 38 2c 0a 55  </a> is UTF-8,.U
8020: 54 46 2d 31 36 62 65 2c 20 6f 72 20 55 54 46 2d  TF-16be, or UTF-
8030: 31 36 6c 65 2e 0a 0a 0a 3c 61 20 6e 61 6d 65 3d  16le....<a name=
8040: 22 62 6f 6f 6c 65 61 6e 65 78 70 72 22 3e 3c 2f  "booleanexpr"></
8050: 61 3e 0a 0a 3c 68 33 3e 42 6f 6f 6c 65 61 6e 20  a>..<h3>Boolean 
8060: 45 78 70 72 65 73 73 69 6f 6e 73 3c 2f 68 33 3e  Expressions</h3>
8070: 0a 0a 3c 70 3e 54 68 65 20 53 51 4c 20 6c 61 6e  ..<p>The SQL lan
8080: 67 75 61 67 65 20 66 65 61 74 75 72 65 73 20 73  guage features s
8090: 65 76 65 72 61 6c 20 63 6f 6e 74 65 78 74 73 20  everal contexts 
80a0: 77 68 65 72 65 20 61 6e 20 65 78 70 72 65 73 73  where an express
80b0: 69 6f 6e 20 69 73 20 0a 65 76 61 6c 75 61 74 65  ion is .evaluate
80c0: 64 20 61 6e 64 20 74 68 65 20 72 65 73 75 6c 74  d and the result
80d0: 20 63 6f 6e 76 65 72 74 65 64 20 74 6f 20 61 20   converted to a 
80e0: 62 6f 6f 6c 65 61 6e 20 28 74 72 75 65 20 6f 72  boolean (true or
80f0: 20 66 61 6c 73 65 29 20 76 61 6c 75 65 2e 20 54   false) value. T
8100: 68 65 73 65 0a 63 6f 6e 74 65 78 74 73 20 61 72  hese.contexts ar
8110: 65 3a 0a 0a 20 20 3c 75 6c 3e 0a 20 20 20 20 3c  e:..  <ul>.    <
8120: 6c 69 3e 20 74 68 65 20 57 48 45 52 45 20 63 6c  li> the WHERE cl
8130: 61 75 73 65 20 6f 66 20 61 20 53 45 4c 45 43 54  ause of a SELECT
8140: 2c 20 55 50 44 41 54 45 20 6f 72 20 44 45 4c 45  , UPDATE or DELE
8150: 54 45 20 73 74 61 74 65 6d 65 6e 74 2c 0a 20 20  TE statement,.  
8160: 20 20 3c 6c 69 3e 20 74 68 65 20 4f 4e 20 6f 72    <li> the ON or
8170: 20 55 53 49 4e 47 20 63 6c 61 75 73 65 20 6f 66   USING clause of
8180: 20 61 20 6a 6f 69 6e 20 69 6e 20 61 20 53 45 4c   a join in a SEL
8190: 45 43 54 20 73 74 61 74 65 6d 65 6e 74 2c 0a 20  ECT statement,. 
81a0: 20 20 20 3c 6c 69 3e 20 74 68 65 20 48 41 56 49     <li> the HAVI
81b0: 4e 47 20 63 6c 61 75 73 65 20 6f 66 20 61 20 53  NG clause of a S
81c0: 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e 74 2c  ELECT statement,
81d0: 0a 20 20 20 20 3c 6c 69 3e 20 74 68 65 20 57 48  .    <li> the WH
81e0: 45 4e 20 63 6c 61 75 73 65 20 6f 66 20 61 6e 20  EN clause of an 
81f0: 53 51 4c 20 74 72 69 67 67 65 72 2c 20 61 6e 64  SQL trigger, and
8200: 0a 20 20 20 20 3c 6c 69 3e 20 74 68 65 20 57 48  .    <li> the WH
8210: 45 4e 20 63 6c 61 75 73 65 20 6f 72 20 63 6c 61  EN clause or cla
8220: 75 73 65 73 20 6f 66 20 73 6f 6d 65 20 43 41 53  uses of some CAS
8230: 45 20 65 78 70 72 65 73 73 69 6f 6e 73 2e 0a 20  E expressions.. 
8240: 20 3c 2f 75 6c 3e 0a 0a 3c 70 3e 54 6f 20 63 6f   </ul>..<p>To co
8250: 6e 76 65 72 74 20 74 68 65 20 72 65 73 75 6c 74  nvert the result
8260: 73 20 6f 66 20 61 6e 20 53 51 4c 20 65 78 70 72  s of an SQL expr
8270: 65 73 73 69 6f 6e 20 74 6f 20 61 20 62 6f 6f 6c  ession to a bool
8280: 65 61 6e 20 76 61 6c 75 65 2c 20 53 51 4c 69 74  ean value, SQLit
8290: 65 0a 66 69 72 73 74 20 63 61 73 74 73 20 74 68  e.first casts th
82a0: 65 20 72 65 73 75 6c 74 20 74 6f 20 61 20 4e 55  e result to a NU
82b0: 4d 45 52 49 43 20 76 61 6c 75 65 20 69 6e 20 74  MERIC value in t
82c0: 68 65 20 73 61 6d 65 20 77 61 79 20 61 73 20 61  he same way as a
82d0: 20 0a 3c 61 20 68 72 65 66 3d 22 6c 61 6e 67 5f   .<a href="lang_
82e0: 65 78 70 72 2e 68 74 6d 6c 23 63 61 73 74 65 78  expr.html#castex
82f0: 70 72 22 3e 43 41 53 54 20 65 78 70 72 65 73 73  pr">CAST express
8300: 69 6f 6e 3c 2f 61 3e 2e 20 41 20 6e 75 6d 65 72  ion</a>. A numer
8310: 69 63 20 7a 65 72 6f 20 76 61 6c 75 65 20 28 69  ic zero value (i
8320: 6e 74 65 67 65 72 20 76 61 6c 75 65 20 30 20 6f  nteger value 0 o
8330: 72 20 72 65 61 6c 20 0a 76 61 6c 75 65 20 30 2e  r real .value 0.
8340: 30 29 20 69 73 20 63 6f 6e 73 69 64 65 72 65 64  0) is considered
8350: 20 74 6f 20 62 65 20 66 61 6c 73 65 2e 20 20 41   to be false.  A
8360: 20 4e 55 4c 4c 20 76 61 6c 75 65 20 69 73 20 73   NULL value is s
8370: 74 69 6c 6c 20 4e 55 4c 4c 2e 0a 41 6c 6c 20 6f  till NULL..All o
8380: 74 68 65 72 20 76 61 6c 75 65 73 20 61 72 65 20  ther values are 
8390: 63 6f 6e 73 69 64 65 72 65 64 20 74 72 75 65 2e  considered true.
83a0: 0a 0a 3c 70 3e 46 6f 72 20 65 78 61 6d 70 6c 65  ..<p>For example
83b0: 2c 20 74 68 65 20 76 61 6c 75 65 73 20 4e 55 4c  , the values NUL
83c0: 4c 2c 20 30 2e 30 2c 20 30 2c 20 27 65 6e 67 6c  L, 0.0, 0, 'engl
83d0: 69 73 68 27 20 61 6e 64 20 27 30 27 20 61 72 65  ish' and '0' are
83e0: 20 61 6c 6c 20 63 6f 6e 73 69 64 65 72 65 64 0a   all considered.
83f0: 74 6f 20 62 65 20 66 61 6c 73 65 2e 20 56 61 6c  to be false. Val
8400: 75 65 73 20 31 2c 20 31 2e 30 2c 20 30 2e 31 2c  ues 1, 1.0, 0.1,
8410: 20 2d 30 2e 31 20 61 6e 64 20 27 31 65 6e 67 6c   -0.1 and '1engl
8420: 69 73 68 27 20 61 72 65 20 63 6f 6e 73 69 64 65  ish' are conside
8430: 72 65 64 20 74 6f 20 0a 62 65 20 74 72 75 65 2e  red to .be true.
8440: 0a 0a 3c 68 33 3e 46 75 6e 63 74 69 6f 6e 73 3c  ..<h3>Functions<
8450: 2f 68 33 3e 0a 3c 70 3e 53 51 4c 69 74 65 20 73  /h3>.<p>SQLite s
8460: 75 70 70 6f 72 74 73 20 6d 61 6e 79 20 3c 61 20  upports many <a 
8470: 68 72 65 66 3d 22 6c 61 6e 67 5f 63 6f 72 65 66  href="lang_coref
8480: 75 6e 63 2e 68 74 6d 6c 22 3e 73 69 6d 70 6c 65  unc.html">simple
8490: 3c 2f 61 3e 20 61 6e 64 20 3c 61 20 68 72 65 66  </a> and <a href
84a0: 3d 22 6c 61 6e 67 5f 61 67 67 66 75 6e 63 2e 68  ="lang_aggfunc.h
84b0: 74 6d 6c 22 3e 61 67 67 72 65 67 61 74 65 3c 2f  tml">aggregate</
84c0: 61 3e 0a 53 51 4c 20 66 75 6e 63 74 69 6f 6e 73  a>.SQL functions
84d0: 2e 20 20 46 6f 72 20 70 72 65 73 65 6e 74 61 74  .  For presentat
84e0: 69 6f 6e 20 70 75 72 70 6f 73 65 73 2c 20 73 69  ion purposes, si
84f0: 6d 70 6c 65 20 66 75 6e 63 74 69 6f 6e 73 20 61  mple functions a
8500: 72 65 20 66 75 72 74 68 65 72 0a 73 75 62 64 69  re further.subdi
8510: 76 69 64 65 64 20 69 6e 74 6f 20 3c 61 20 68 72  vided into <a hr
8520: 65 66 3d 22 6c 61 6e 67 5f 63 6f 72 65 66 75 6e  ef="lang_corefun
8530: 63 2e 68 74 6d 6c 22 3e 63 6f 72 65 20 66 75 6e  c.html">core fun
8540: 63 74 69 6f 6e 73 3c 2f 61 3e 20 61 6e 64 20 3c  ctions</a> and <
8550: 61 20 68 72 65 66 3d 22 6c 61 6e 67 5f 64 61 74  a href="lang_dat
8560: 65 66 75 6e 63 2e 68 74 6d 6c 22 3e 64 61 74 65  efunc.html">date
8570: 2d 74 69 6d 65 20 66 75 6e 63 74 69 6f 6e 73 3c  -time functions<
8580: 2f 61 3e 2e 0a 41 70 70 6c 69 63 61 74 69 6f 6e  /a>..Application
8590: 73 20 63 61 6e 20 61 64 64 20 6e 65 77 20 66 75  s can add new fu
85a0: 6e 63 74 69 6f 6e 73 2c 20 77 72 69 74 74 65 6e  nctions, written
85b0: 20 69 6e 20 43 2f 43 2b 2b 2c 20 75 73 69 6e 67   in C/C++, using
85c0: 20 74 68 65 0a 3c 61 20 68 72 65 66 3d 22 63 33   the.<a href="c3
85d0: 72 65 66 2f 63 72 65 61 74 65 5f 66 75 6e 63 74  ref/create_funct
85e0: 69 6f 6e 2e 68 74 6d 6c 22 3e 73 71 6c 69 74 65  ion.html">sqlite
85f0: 33 5f 63 72 65 61 74 65 5f 66 75 6e 63 74 69 6f  3_create_functio
8600: 6e 28 29 3c 2f 61 3e 20 69 6e 74 65 72 66 61 63  n()</a> interfac
8610: 65 2e 0a 3c 2f 70 3e 0a 0a 3c 70 3e 49 74 20 69  e..</p>..<p>It i
8620: 73 20 70 6f 73 73 69 62 6c 65 20 74 6f 20 68 61  s possible to ha
8630: 76 65 20 61 6e 20 61 67 67 72 65 67 61 74 65 20  ve an aggregate 
8640: 66 75 6e 63 74 69 6f 6e 20 77 69 74 68 20 74 68  function with th
8650: 65 20 73 61 6d 65 20 6e 61 6d 65 20 61 73 20 61  e same name as a
8660: 0a 73 69 6d 70 6c 65 20 66 75 6e 63 74 69 6f 6e  .simple function
8670: 2c 20 61 73 20 6c 6f 6e 67 20 61 73 20 74 68 65  , as long as the
8680: 20 6e 75 6d 62 65 72 20 6f 66 20 61 72 67 75 6d   number of argum
8690: 65 6e 74 73 20 66 6f 72 20 74 68 65 20 74 77 6f  ents for the two
86a0: 20 66 6f 72 6d 73 20 6f 66 20 74 68 65 0a 66 75   forms of the.fu
86b0: 6e 63 74 69 6f 6e 20 61 72 65 20 64 69 66 66 65  nction are diffe
86c0: 72 65 6e 74 2e 20 20 46 6f 72 20 65 78 61 6d 70  rent.  For examp
86d0: 6c 65 2c 20 74 68 65 20 3c 61 20 68 72 65 66 3d  le, the <a href=
86e0: 22 6c 61 6e 67 5f 61 67 67 66 75 6e 63 2e 68 74  "lang_aggfunc.ht
86f0: 6d 6c 23 6d 61 78 67 67 75 6e 63 22 3e 6d 61 78  ml#maxggunc">max
8700: 28 29 3c 2f 61 3e 20 66 75 6e 63 74 69 6f 6e 20  ()</a> function 
8710: 77 69 74 68 20 61 0a 73 69 6e 67 6c 65 20 61 72  with a.single ar
8720: 67 75 6d 65 6e 74 20 69 73 20 61 6e 20 61 67 67  gument is an agg
8730: 72 65 67 61 74 65 20 61 6e 64 20 74 68 65 20 3c  regate and the <
8740: 61 20 68 72 65 66 3d 22 6c 61 6e 67 5f 63 6f 72  a href="lang_cor
8750: 65 66 75 6e 63 2e 68 74 6d 6c 23 6d 61 78 6f 72  efunc.html#maxor
8760: 65 75 6e 63 22 3e 6d 61 78 28 29 3c 2f 61 3e 20  eunc">max()</a> 
8770: 66 75 6e 63 74 69 6f 6e 20 77 69 74 68 20 74 77  function with tw
8780: 6f 20 6f 72 20 6d 6f 72 65 0a 61 72 67 75 6d 65  o or more.argume
8790: 6e 74 73 20 69 73 20 61 20 73 69 6d 70 6c 65 20  nts is a simple 
87a0: 66 75 6e 63 74 69 6f 6e 2e 0a 0a 0a              function....