File: postmodern.html

package info (click to toggle)
cl-postmodern 20141006-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 580 kB
  • ctags: 760
  • sloc: lisp: 4,585; makefile: 4
file content (1257 lines) | stat: -rw-r--r-- 48,954 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
1210
1211
1212
1213
1214
1215
1216
1217
1218
1219
1220
1221
1222
1223
1224
1225
1226
1227
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">

  <head>
    <title>Postmodern reference manual</title>
    <link rel="stylesheet" type="text/css" href="style.css"/>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
  </head>

  <body>

    <h1>Postmodern reference manual</h1>

    <p>This is the reference manual for the component named
    postmodern, which is part of a <a href="index.html">library</a> of
    the same name.</p>

    <p>Note that this package also exports the <a
    href="cl-postgres.html#database-connection"><code>database-connection</code></a>
    and <a
    href="cl-postgres.html#database-error"><code>database-error</code></a>
    types from <a href="cl-postgres.html">CL-postgres</a>, and a few
    operators from <a href="s-sql.html">S-SQL</a>.</p>

    <p><a href="#query"><code>query</code></a>, <a
    href="#execute"><code>execute</code></a>, and any other function
    that would logically need to communicate with the database will
    raise a condition of the type <a
    href="cl-postgres.html#conditions"><code>database-error</code></a>
    when something goes wrong. As a special case, errors that break
    the connection (socket errors, database shutdowns) will be raised
    as subtypes of <a
    href="cl-postgres.html#database-connection-error"><code>database-connection-error</code></a>,
    providing a <code>:reconnect</code> restart to re-try the
    operation that encountered to the error.</p>

    <h2>Contents</h2>

    <ol>
      <li><a href="#connecting">Connecting</a></li>
      <li><a href="#querying">Querying</a></li>
      <li><a href="#inspect">Inspecting the database</a></li>
      <li><a href="#daos">Database access objects</a></li>
      <li><a href="#tabledef">Table definition and creation</a></li>
      <li><a href="#schemata">Schemata</a></li>
      <li><a href="#index">Symbol-index</a></li>
    </ol>

    <h2><a name="connecting"></a>Connecting</h2>

    <p class="def">
      <span>class</span>
      <a name="database-connection"></a>
      database-connection
    </p>

    <p class="desc">Objects of this type represent database connections.</p>

    <p class="def">
      <span>function</span>
      <a name="connect"></a>
      connect (database user password host &amp;key (port 5432) pooled-p use-ssl)
      <br/>&#8594; database-connection
    </p>

    <p class="desc">Create a new database connection for the given
    user and database. Port will default to 5432, which is where most
    PostgreSQL server are running. If <code>pooled-p</code> is true, a
    connection will be taken from a pool of connections of this type,
    if one is available there, and when the connection is disconnected
    it will be put back into this pool instead. <code>use-ssl</code>
    can be <code>:no</code>, <code>:yes</code>, or <code>:try</code>,
    as in <a
    href="cl-postgres.html#open-database"><code>open-database</code></a>,
    and defaults to the value of <a
    href="#*default-use-ssl*"><code>*default-use-ssl*</code></a>.</p>

    <p class="def">
      <span>variable</span>
      <a name="*default-use-ssl*"></a>
      *default-use-ssl*
    </p>

    <p class="desc">The default for <a
    href="#connect"><code>connect</code></a>'s <code>use-ssl</code>
    argument. This starts at <code>:no</code>. If you set it to
    anything else, be sure to also load the <a
    href="http://common-lisp.net/project/cl-plus-ssl/">CL+SSL</a>
    library.</p>

    <p class="def">
      <span>method</span>
      <a name="disconnect"></a>
      disconnect (database-connection)
    </p>

    <p class="desc">Disconnects a normal database connection, or moves
    a pooled connection into the pool.</p>

    <p class="def">
      <span>function</span>
      <a name="connected-p"></a>
      connected-p (database-connection)
      <br/>&#8594; boolean
    </p>

    <p class="desc">Returns a boolean indicating whether the given
    connection is still connected to the server.</p>

    <p class="def">
      <span>method</span>
      <a name="reconnect"></a>
      reconnect (database-connection)
    </p>

    <p class="desc">Reconnect a disconnected database connection. This
    is not allowed for pooled connections &#x2015; after they are
    disconnected they might be in use by some other process, and
    should no longer be used.</p>

    <p class="def">
      <span>variable</span>
      <a name="*database*"></a>
      *database*
    </p>

    <p class="desc">Special variable holding the current database.
    Most functions and macros operating on a database assume this
    contains a connected database.</p>

    <p class="def">
      <span>macro</span>
      <a name="with-connection"></a>
      with-connection (spec &amp;body body)
    </p>

    <p class="desc">Evaluates the body with <a
    href="#*database*"><code>*database*</code></a> bound to a
    connection as specified by <code>spec</code>, which should be list
    that <a href="#connect"><code>connect</code></a> can be applied
    to.</p>

    <p class="def">
      <span>macro</span>
      <a name="call-with-connection"></a>
      call-with-connection (spec thunk)
    </p>

    <p class="desc">The functional backend to <a
    href="#with-connection"><code>with-connection</code></a>. Binds <a
    href="#*database*"><code>*database*</code></a> to a new connection
    as specified by <code>spec</code>, which should be a list that <a
    href="#connect"><code>connect</code></a> can be applied to, and
    runs the zero-argument function given as second argument in the
    new environment. When the function returns or throws, the new
    connection is disconnected.</p>

    <p class="def">
      <span>function</span>
      <a name="connect-toplevel"></a>
      connect-toplevel  (database user password host &amp;key (port 5432))
    </p>

    <p class="desc">Set <a
    href="#*database*"><code>*database*</code></a> to a new
    connection. Use this if you only need one connection, or if you
    want a connection for debugging from the REPL.</p>

    <p class="def">
      <span>function</span>
      <a name="disconnect-toplevel"></a>
      disconnect-toplevel ()
    </p>

    <p class="desc">Disconnect <a
    href="#*database*"><code>*database*</code></a>.</p>

    <p class="def">
      <span>function</span>
      <a name="clear-connection-pool"></a>
      clear-connection-pool ()
    </p>

    <p class="desc">Disconnect and remove all connections in the
    connection pools.</p>

    <p class="def">
      <span>variable</span>
      <a name="*max-pool-size*"></a>
      *max-pool-size*
    </p>

    <p class="desc">Set the maximum amount of connections kept in a
    <em>single</em> connection pool, where a pool consists of all the
    stored connections with the exact same connect arguments. Defaults
    to <code>NIL</code>, which means there is no maximum.</p>

    <h2><a name="querying"></a>Querying</h2>

    <p class="def">
      <span>macro</span>
      <a name="query"></a>
      query (query &amp;rest args/format)
      <br/>&#8594; result
    </p>

    <p class="desc">Execute the given query, which can be either a
    string or an <a href="s-sql.html">S-SQL</a> form (list starting
    with a keyword). If the query contains placeholders
    (<code>$1</code>, <code>$2</code>, etc) their values can be given
    as extra arguments. If one of these arguments is a keyword
    occurring in the table below, it will not be used as a query
    argument, but will determine the format in which the results are
    returned instead. Any of the following formats can be used, with
    the default being <code>:rows</code>:</p>

    <table class="desc">
      <tr><td><code>:none</code></td><td>Ignore the result values.</td></tr>
      <tr><td><code>:lists</code>, <code>:rows</code></td><td>Return a
      list of lists, each list containing the values for a
      row.</td></tr>
      <tr><td><code>:list</code>, <code>:row</code></td><td>Return a
      single row as a list.</td></tr>
      <tr><td><code>:alists</code></td><td>Return a list of alists which map column
      names to values,with the names represented as
      keywords.</td></tr>
      <tr><td><code>:alist</code></td><td>Return a single row as an alist.</td></tr>
      <tr><td><code>:str-alists</code></td><td>Like
      <code>:alists</code>, but use the original column
      names.</td></tr>
      <tr><td><code>:str-alist</code></td><td>Return a single row as an alist, with
      strings for names.</td></tr>
      <tr><td><code>:plists</code></td><td>Return a list of plists which map column
      names to values,with the names represented as keywords.</td></tr>
      <tr><td><code>:plist</code></td><td>Return a single row as a plist.</td></tr>
      <tr><td><code>:column</code></td><td>Return a single column as a list.</td></tr>
      <tr><td><code>:single</code></td><td>Return a single value.</td></tr>
      <tr><td><code>:single!</code></td><td>Like <code>:single</code>,
      but raise an error when the number of selected rows is not equal
      to 1.</td></tr>
      <tr><td><code>(:dao type)</code></td><td>Return a list of DAOs of the given type. The names of the fields returned by the query must match slots in the DAO class the same way as with <a href="#query-dao"><code>query-dao</code></a>.</td></tr>
      <tr><td><code>(:dao type :single)</code></td><td>Return a single DAO of the given type.</td></tr>
     </table>

    <p class="desc">If the database returns information about the
    amount rows that were affected, such as with updating or deleting
    queries, this is returned as a second value.</p>

    <p class="def">
      <span>macro</span>
      <a name="execute"></a>
      execute (query &amp;rest args)
    </p>

    <p class="desc">Like <a href="#query"><code>query</code></a>, but
    called with <code>format</code> :none, and returning the amount of
    affected rows as its first returned value. (Also returns this
    amount as the second returned value, but use of this is
    deprecated.)</p>

    <p class="def">
      <span>macro</span>
      <a name="doquery"></a>
      doquery (query (&amp;rest names) &amp;body body)
    </p>

    <p class="desc">Execute the given query (a string or a list
    starting with a keyword), iterating over the rows in the result.
    The body will be executed with the values in the row bound to the
    symbols given in <code>names</code>. To iterate over a
    parameterised query, one can specify a list whose car is the
    query, and whose cdr contains the arguments. For example:</p>

    <pre class="code">
(doquery (:select 'name 'score :from 'scores) (n s)
  (incf (gethash n *scores*) s))

(doquery ((:select 'name :from 'scores :where (:> 'score '$1)) 100) (name)
  (print name))</pre>

    <p class="def">
      <span>macro</span>
      <a name="prepare"></a>
      prepare (query &amp;optional (format :rows))
      <br/>&#8594; function
    </p>

    <p class="desc">Creates a function that can be used as the
    interface to a prepared statement. The given query (either a
    string or an <a href="s-sql.html">S-SQL</a> form) may contain
    placeholders, which look like <code>$1</code>, <code>$2</code>,
    etc. The resulting function takes one argument for every
    placeholder in the query, executes the prepared query, and returns
    the result in the format specified (allowed formats are the same
    as for <a href="#query"><code>query</code></a>).</p>

    <p class="desc">For queries that have to be run very often,
    especially when they are complex, it may help performance if the
    server only has to plan them once. See <a
    href="http://www.postgresql.org/docs/current/static/sql-prepare.html">the
    PostgreSQL manual</a> for details.</p>

    <p class="desc">In some cases, the server will complain about not
    being able to deduce the type of the arguments in a statement. In
    that case you should add type declarations (either with the
    <code>::</code> syntax or with S-SQL's <a
    href="s-sql.html#type"><code>:type</code></a> construct) to help it
    out.</p>

    <p class="def">
      <span>macro</span>
      <a name="defprepared"></a>
      defprepared (name query &amp;optional (format :rows))
    </p>

    <p class="desc">This is the <code>defun</code>-style variant of <a
    href="#prepare"><code>prepare</code></a>. It will define a
    top-level function for the prepared statement.</p>

    <p class="def">
      <span>macro</span>
      <a name="defprepared-with-names"></a>
      defprepared-with-names (name (&amp;rest args) (query &amp;rest query-args) &amp;optional (format :rows))
    </p>

    <p class="desc">Like <a href="#defprepared"><code>defprepared</code></a>,
    but allows to specify names of the function arguments as well as arguments
    supplied to the query.</p>

    <pre class="code">
(defprepared-with-names user-messages (user &amp;key (limit 10))
  ("select * from messages
    where user_id = $1
    order by date desc
    limit $2" (user-id user) limit)
  :plists)
    </pre>

    <p class="def">
      <span>macro</span>
      <a name="with-transaction"></a>
      with-transaction ((&amp;optional name) &amp;body body)
    </p>

    <p class="desc">Execute the given body within a database
    transaction, committing it when the body exits normally, and
    aborting otherwise. An optional name can be given to the
    transaction, which can be used to force a commit or abort before
    the body unwinds.</p>

    <p class="def">
      <span>function</span>
      <a name="commit-transaction"></a>
      commit-transaction (transaction)
    </p>

    <p class="desc">Commit the given database transaction.</p>

    <p class="def">
      <span>function</span>
      <a name="abort-transaction"></a>
      abort-transaction (transaction)
    </p>

    <p class="desc">Roll back the given database transaction.</p>

     <p class="def">
      <span>macro</span>
      <a name="with-savepoint"></a>
      with-savepoint (name &amp;body body)
    </p>

    <p class="desc">Can only be used within a transaction. Establishes
    a savepoint with the given name at the start of <code>body</code>,
    and binds the same name to a handle for that savepoint. At the end
    of <code>body</code>, the savepoint is released, unless a
    condition is thrown, in which case it is rolled back.</p>

    <p class="def">
      <span>function</span>
      <a name="release-savepoint"></a>
      release-savepoint (savepoint)
    </p>

    <p class="desc">Explicitly release the given savepoint.</p>

    <p class="def">
      <span>function</span>
      <a name="rollback-savepoint"></a>
      rollback-savepoint (transaction)
    </p>

    <p class="desc">Roll back the given savepoint.</p>

    <p class="def">
      <span>function</span>
      <a name="commit-hooks"></a>
      commit-hooks (transaction-or-savepoint), 
      setf (commit-hooks transaction-or-savepoint)
    </p>

    <p class="desc">An accessor for the transaction or savepoint's list of commit hooks, each of which should be a function with no required arguments. These functions will be executed when a transaction is successfully committed or a savepoint successfully released.</p>

    <p class="def">
      <span>function</span>
      <a name="abort-hooks"></a>
      abort-hooks (transaction-or-savepoint), setf (abort-hooks transaction-or-savepoint)
    </p>

    <p class="desc">An accessor for the transaction or savepoint's list of abort hooks, each of which should be a function with no required arguments. These functions will be executed when a transaction is aborted or a savepoint rolled back (whether via a non-local transfer of control or explicit call to <code>abort-transaction</code> or <code>rollback-savepoint</code>).

    <p class="def">
      <span>macro</span>
      <a name="with-logical-transaction"></a>
      with-logical-transaction ((&amp;optional name) &amp;body body)
    </p>

    <p class="desc">Executes <code>body</code> within
    a <code>with-transaction</code> form is no transaction is
    currently in progress, otherwise simulates a nested transaction by
    executing it within a <code>with-savepoint</code> form. The
    transaction or savepoint is bound to <code>name</code> if one is
    supplied.</p>

    <p class="def">
      <span>function</span>
      <a name="abort-logical-transaction"></a>
      abort-logical-transaction (transaction-or-savepoint)
    </p>

    <p class="desc">Roll back the given logical transaction, regardless of whether it is a true transaction or a savepoint.</p>

    <p class="def">
      <span>function</span>
      <a name="commit-logical-transaction"></a>
      commit-logical-transaction (transaction-or-savepoint)
    </p>

    <p class="desc">Commit the given logical transaction, regardless of whether it is a true transaction or a savepoint.</p>

    <p class="def">
      <a name="*current-logical-transaction*"></a>
      <span>variable</span>
      *current-logical-transaction*
    </p>

    <p class="desc">This is bound to the
    current <code>transaction-handle</code>
    or <code>savepoint-handle</code> instance representing the
    innermost open logical transaction.</p>


    <p class="def">
      <span>macro</span>
      <a name="ensure-transaction"></a>
      ensure-transaction (&amp;body body)
    </p>

    <p class="desc">Ensures that <code>body</code> is executed within
    a transaction, but does not begin a new transaction if one is
    already in progress.</p>

    <p class="def">
      <span>macro</span>
      <a name="with-schema"></a>
      with-schema ((namespace &amp;key :strict t :if-not-exist
                               :create :drop-after ) &amp;body body)
    </p>

    <p class="desc">Executes the <code>body</code> within a
    namespace. Before executing <code>body</code> the variable
    search_path is set to the given schema name. After
    executing <code>body</code> the search_path variable is set to its
    original and stored value.

    If the keyword <code>:strict</code> is set to a true value
    the <code>search_path</code> only contains the namespace before
    exucting body. otherwise the schema is prepended
    to <code>search_path</code>. If the
    keyword <code>:if-not-exist</code> is set to nil, an error is
    signaled. If the keyword <code>:drop-after</code> is set to true
    the namesapce is removed from the database.
    </p>

    <p class="def">
      <span>function</span>
      <a name="sequence-next"></a>
      sequence-next (sequence)
      <br/>&#8594; integer
    </p>

    <p class="desc">Get the next value from a sequence. The sequence
    identifier can be either a string or a symbol, in the latter case
    it will be converted to a string with <a
    href="s-sql.html">S-SQL</a> rules.</p>

    <p class="def">
      <span>function</span>
      <a name="coalesce"></a>
      coalesce (&amp;rest arguments)
      <br/>&#8594; value
    </p>

    <p class="desc">Returns the first non-<code>NIL</code>, non-null
    (as in <code>:null</code>) argument, or <code>NIL</code> if none
    are present. Useful for providing a fall-back value for the result
    of a query, or, when given only one argument, for transforming
    <code>:null</code>s to <code>NIL</code>.</p>

    <h2><a name="inspect"></a>Inspecting the database</h2>

    <p class="def">
      <span>function</span>
      <a name="list-tables"></a>
      list-tables (&amp;optional strings-p)
      <br/>&#8594; list
    </p>

    <p class="desc">Returns a list of the tables in the current
    database. When <code>strings-p</code> is true, the names will be
    given as strings, otherwise as keywords.</p>

    <p class="def">
      <span>function</span>
      <a name="table-exists-p"></a>
      table-exists-p (name)
      <br/>&#8594; boolean
    </p>

    <p class="desc">Tests whether a table with the given name
    exists. The name can be either a string or a symbol.</p>

    <p class="def">
      <span>function</span>
      <a name="table-description"></a>
      table-description (name &amp;optional schema-name)
      <br/>&#8594; list
    </p>

    <p class="desc">Returns a list of the fields in the named table.
    Each field is represented by a list of three elements: the field
    name, the type, and a boolean indicating whether the field may be
    null.  Optionally, schema-name can be specified to restrict the
    result to fields from the named schema.  Without it, all fields in
    the table are returned, regardless of their schema.</p>

    <p class="def">
      <span>function</span>
      <a name="list-sequences"></a>
      list-sequences (&amp;optional strings-p)
      <br/>&#8594; list
    </p>

    <p class="desc">Returns a list of the sequences in the current
    database. When <code>strings-p</code> is true, the names will be
    given as strings, otherwise as keywords.</p>

    <p class="def">
      <span>function</span>
      <a name="sequence-exists-p"></a>
      sequence-exists-p (name)
      <br/>&#8594; boolean
    </p>

    <p class="desc">Tests whether a sequence with the given name
    exists. The name can be either a string or a symbol.</p>

    <p class="def">
      <span>function</span>
      <a name="list-views"></a>
      list-views (&amp;optional strings-p)
      <br/>&#8594; list
    </p>

    <p class="desc">Returns a list of the views in the current
    database. When <code>strings-p</code> is true, the names will be
    given as strings, otherwise as keywords.</p>

    <p class="def">
      <span>function</span>
      <a name="view-exists-p"></a>
      view-exists-p (name)
      <br/>&#8594; boolean
    </p>

    <p class="desc">Tests whether a view with the given name exists.
    The name can be either a string or a symbol.</p>

    <p class="def">
      <span>function</span>
      <a name="list-schemata"></a>
      list-schemata ()
      <br/>&#8594; list
    </p>

    <p class="desc">
        Lists all existing schemata in a list of names (String) and
        the quantity of existing schemata.
    </p>

    <p class="def">
        <span>function</span>
        <a name="schema-exist-p"></a>
        schema-exist-p (schema)
        <br/>&#8594; boolean
    </p>

    <p class="desc">
        Tests thes existence of a given schema. Returns T if the
        schema exists, otherwise NIL.
    </p>

    <h2><a name="daos"></a>Database access objects</h2>

    <p>Postmodern contains a simple system for defining CLOS classes
    that represent rows in the database. This is not intended as as a
    full-fledged object-relational magic system &#x2015; while serious
    ORM systems have their place, they are notoriously hard to get
    right, and are outside of the scope of a humble SQL library like
    this.</p>

    <p class="def">
      <span>metaclass</span>
      <a name="dao-class"></a>
      dao-class
    </p>

    <p class="desc">At the heart of Postmodern's DAO system is the
    <code>dao-class</code> metaclass. It allows you to define classes
    for your database-access objects as regular CLOS classes. Some of
    the slots in these classes will refer to columns in the database.
    To specify that a slot refers to a column, give it a
    <code>:col-type</code> option containing
    an <a href="s-sql.html">S-SQL</a> type expression (useful if you
    want to be able to derive a table definition from the class
    definition), or simply a <code>:column</code> option with
    value <code>t</code>.  Such slots can also take
    a <code>:col-default</code> option, used to provide a
    database-side default value as an S-SQL expression. You can use
    the <code>:col-name</code> initarg (whose unevaluated value will
    be passed to to-sql-name) to specify the slot's column's name.</p>

    <p class="desc">DAO class definitions support two extra class
    options: <code>:table-name</code> to give the name of the table
    that the class refers to (defaults to the class name), and
    <code>:keys</code> to provide a set of primary keys for the table.
    When no primary keys are defined, operations such as <a
    href="#update-dao"><code>update-dao</code></a> and <a
    href="#get-dao"><code>get-dao</code></a> will not work.</p>

    <p class="desc">Simple example:</p>

    <pre class="code">
(defclass user ()
  ((name :col-type string :initarg :name :accessor user-name)
   (creditcard :col-type (or db-null integer) :initarg :card :col-default :null)
   (score :col-type bigint :col-default 0 :accessor user-score))
  (:metaclass dao-class)
  (:keys name))</pre>

    <p class="desc">The <code>(or db-null integer)</code> form is used
    to indicate a column can have NULL values.</p>

    <p class="desc">When inheriting from DAO classes, a subclass' set
    of columns also contains all the columns in its superclasses. The
    primary key for such a class is the union of its own keys and all
    the keys from its superclasses. Classes inheriting from DAO
    classes should probably always use the <code>dao-class</code>
    metaclass themselves.</p>

    <p class="desc">When a DAO is created with
    <code>make-instance</code>, it can be passed a
    <code>:fetch-defaults</code> keyword parameter which, when true,
    will cause a query to be made to fetch the default values for all
    slots that have column default values and were not bound through
    initargs. In some cases, such as <code>serial</code> columns,
    which have an implicit default, this will not work. You can work
    around this by creating your own sequence and defining a
    <code>(:nextval "my_sequence")</code> default.</p>

    <p class="desc">Finally, DAO class slots can have an option
    <code>:ghost t</code> to specify them as ghost slots. These are
    selected when retrieving instances, but not written when updating
    or inserting, or even included in the table definition. The only
    know use for this to date is to create your table with
    <code>(oids=true)</code>, and specify a slot like this:</p>

    <pre class="code">
(oid :col-type integer :ghost t :accessor get-oid)</pre>

    <p class="def">
      <span>method</span>
      <a name="dao-keys"></a>
      dao-keys (class)
      <br/>&#8594; list
    </p>

    <p class="desc">
      Returns list of slot names that are the primary key of DAO class
      CLASS.
    </p>

    <p class="def">
      <span>method</span>
      dao-keys (dao)
      <br/>&#8594; list
    </p>

    <p class="desc">
      Returns list of values that are the primary key of DAO.
    </p>

    <p class="def">
      <span>method</span>
      <a name="dao-exists-p"></a>
      dao-exists-p (dao)
      <br/>&#8594; boolean
    </p>

    <p class="desc">Test whether a row with the same primary key as
    the given DAO exists in the database. Will also return
    <code>NIL</code> when any of the key slots in the object are
    unbound.</p>

    <p class="def">
      <span>method</span>
      <a name="make-dao"></a>
      make-dao (type &amp;rest args &amp;key &amp;allow-other-keys)
      <br/>&#8594; dao
    </p>

    <p class="desc">Combines <code>make-instance</code> with
    <a href="#insert-dao"><code>insert-dao</code></a>. Return the
    created dao.</p>

    <p class="def">
      <span>macro</span>
      <a name="define-dao-finalization"></a>
      define-dao-finalization (((dao-name class) &amp;rest keyword-args) &amp;body body)
    </p>

    <p class="desc">Create an <code>:around</code>-method for <a href="#make-dao">
    <code>make-dao</code></a>. Code <code>body</code> is executed in
    a lexical environment where variable <code>dao-name</code> is bound
    to a freshly created and inserted DAO. The representation of the DAO in the
    database is then updated to reflect changes that <code>body</code> might
    have introduced. Useful for processing values of slots with the type
    <code>serial</code>, which are unknown before <a href="#insert-dao">
    <code>insert-dao</code></a>.</p>

    <p class="def">
      <span>method</span>
      <a name="get-dao"></a>
      get-dao (type &amp;rest keys)
      <br/>&#8594; dao
    </p>

    <p class="desc">Select the DAO object from the row that has the
    given primary key values, or <code>NIL</code> if no such row
    exists. Objects created by this function will have
    <code>initialize-instance</code> called on them (after loading in
    the values from the database) without any arguments &#x2015; even
    <code>:default-initargs</code> are skipped. The same goes for <a
    href="#select-dao"><code>select-dao</code></a> and <a
    href="#query-dao"><code>query-dao</code></a>.</p>

    <p class="def">
      <span>macro</span>
      <a name="select-dao"></a>
      select-dao (type &amp;optional (test t) &amp;rest sort)
      <br/>&#8594; list
    </p>

    <p class="desc">Select DAO objects for the rows in the associated
    table for which the given test (either an <a
    href="s-sql.html">S-SQL</a> expression or a string) holds. When
    sorting arguments are given, which can also be S-SQL forms or
    strings, these are used to sort the result. (Note that, if you
    want to sort, you <em>have</em> to pass a test value.)</p>

    <pre class="code">(select-dao 'user (:> 'score 10000) 'name)</pre>

    <p class="def">
      <span>macro</span>
      <a name="do-select-dao"></a>
      do-select-dao (((type type-var) &amp;optional (test t) &amp;rest sort) &amp;body body)
    </p>

    <p class="desc">Like <a href="#select-dao"><code>select-dao</code></a>, but iterates over the results rather than returning them. For each matching DAO, <code>body</code> is evaluated with <code>type-var</code> bound to the DAO instance.</p>

    <pre class="code">(do-select-dao (('user user) (:> 'score 10000) 'name)
  (pushnew user high-scorers))</pre>

    <p class="def">
      <span>function</span>
      <a name="query-dao"></a>
      query-dao (type query &amp;rest args)
      <br/>&#8594; list
    </p>

    <p class="desc">Execute the given query (which can be either a
    string or an <a href="s-sql.html">S-SQL</a> expression) and return
    the result as DAOs of the given type. If the query contains placeholders
    ($1, $2, etc) their values can be given as extra arguments.
    The names of the fields returned by the query must either match slots
    in the DAO class, or be bound through <a
    href="#with-column-writers"><code>with-column-writers</code></a>.</p>

    <p class="def">
      <span>function</span>
      <a name="do-query-dao"></a>
      do-query-dao (((type type-var) query &amp;rest args) &body body)
      <br/>&#8594; list
    </p>

    <p class="desc">Like <a href="#query-dao"><code>query-dao</code></a>, but iterates over the results rather than returning them. For each matching DAO, <code>body</code> is evaluated with <code>type-var</code> bound to the DAO instance.</p>

    <pre class="code">(do-query-dao (('user user) (:order-by (:select '* :from 'user :where (:> 'score 10000)) 'name))
  (pushnew user high-scorers))</pre>

    <p class="def">
      <span>variable</span>
      <a name="*ignore-unknown-columns*"></a>
      *ignore-unknown-columns*
    </p>

    <p class="desc">Normally,
    when <code><a href="#get-dao">get-dao</a></code>,
    <code><a href="#select-dao">select-dao</a></code>,
    or <code><a href="#query-dao">query-dao</a></code> finds a column
    in the database that's not in the DAO class, it will raise an
    error. Setting this variable to a truthy value will cause it to
    simply ignore the unknown column.</p>

    <p class="def">
      <span>method</span>
      <a name="insert-dao"></a>
      insert-dao (dao)
      <br/>&#8594; dao
    </p>

    <p class="desc">Insert the given DAO into the database. When any
    column slots in the object are unbound, these will be updated with
    the values they default to in the database. (If they have no
    defaults, it is an error to insert them.) <em>Note</em>: This
    feature only works on PostgreSQL 8.2 and up. On older versions, do
    not insert DAOs with unbound slots.</p>

    <p class="def">
      <span>method</span>
      <a name="update-dao"></a>
      update-dao (dao)
      <br/>&#8594; dao
    </p>

    <p class="desc">Update the representation of the given DAO in the
    database with the values in the object. This is not defined for
    tables that do not have any non-primary-key columns. Raises an
    error when no row matching the DAO exists.</p>

    <p class="def">
      <span>function</span>
      <a name="save-dao"></a>
      save-dao (dao)
      <br/>&#8594; boolean
    </p>

    <p class="desc">Tries to insert the given DAO using <a
    href="#insert-dao"><code>insert-dao</code></a>. If this raises a
    unique key violation error, it tries to update it using <a
    href="#update-dao"><code>update-dao</code></a> instead. Be aware
    that there is a possible race condition here &#x2015; if some
    other process deletes the row at just the right moment, the update
    fails as well. Returns a boolean telling you whether a new row was
    inserted.</p>

    <p class="desc">This function is unsafe to use inside of a
    transaction &#x2015; when a row with the given keys already
    exists, the transaction will be abandoned. Use <a
    href="#save-dao/transaction"><code>save-dao/transaction</code></a>
    instead in such a situation.</p>

    <p class="desc"><b>See also:</b> <a href="#upsert-dao"><code>upsert-dao</code></a>.</p>

    <p class="def">
      <span>function</span>
      <a name="save-dao/transaction"></a>
      save-dao/transaction (dao)
      <br/>&#8594; boolean
    </p>

    <p class="desc">Acts exactly like <a
    href="#save-dao"><code>save-dao</code></a>, except that it
    protects its attempt to insert the object with a rollback point,
    so that a failure will not abort the transaction.</p>

    <p class="desc"><b>See also:</b> <a href="#upsert-dao"><code>upsert-dao</code></a>.</p>

    <p class="def">
      <span>method</span>
      <a name="upsert-dao"></a>
      upsert-dao (dao)
      <br/>&#8594; dao
    </p>

    <p class="desc">
      Like <a href="#save-dao"><code>save-dao</code></a>
      or <a href="#save-dao/transaction"><code>save-dao/transaction</code></a>
      but using a different method that doesn't involve a database
      exception.  This is safe to use both in and outside a transaction,
      though it's advisable to always do it in a transaction to prevent a
      race condition.  The way it works is:
    </p>

    <ol class="desc">
      <li>If the object contains unbound slots, we
      call <a href="#insert-dao"><code>insert-dao</code></a> directly, thus
      the behavior is like <code>save-dao</code>.</li>
      <li>Otherwise we try to update a record with the same primary key.  If
      it already exists in the database, Postgres will return a non-zero
      value and we stop here.</li>
      <li>If the update operation succeeds but returns zero, it means the
      record does not exist and we call <code>insert-dao</code>.
    </ol>

    <p class="desc">
      The race condition might occur at step 3 <em>if there's no
      transaction:</em> if <code>update</code> returns zero and another
      thread inserts the record at that moment, our insertion will fail.
    </p>

    <p class="desc">
      This method returns two values: the DAO object and a boolean
      (<code>T</code> if the object was inserted, <code>NIL</code> if
      it was updated).
    </p>

    <p class="def">
      <span>method</span>
      <a name="delete-dao"></a>
      delete-dao (dao)
    </p>

    <p class="desc">Delete the given DAO from the database.</p>

    <p class="def">
      <span>function</span>
      <a name="dao-table-name"></a>
      dao-table-name (table)
      <br/>&#8594; string
    </p>

    <p class="desc">Get the table name associated with the given DAO
    class (or symbol naming such a class).</p>

    <p class="def">
      <span>function</span>
      <a name="dao-table-definition"></a>
      dao-table-definition (table)
      <br/>&#8594; string
    </p>

    <p class="desc">Given a DAO class, or the name of one, this will
    produce an SQL query string with a definition of the table. This
    is just the bare simple definition, so if you need any extra
    indices or or constraints, you'll have to write your own queries
    to add them.</p>

    <p class="def">
      <span>macro</span>
      <a name="with-column-writers"></a>
      with-column-writers ((&amp;rest writers) &amp;body body)
    </p>

    <p class="desc">Provides control over the way <code><a
    href="#get-dao">get-dao</a></code>, <code><a
    href="#select-dao">select-dao</a></code>, and <code><a
    href="#query-dao">query-dao</a></code> read values from the
    database. This is not commonly needed, but can be used to reduce
    the amount of queries a system makes. <code>writers</code> should
    be a list of alternating column names (strings or symbols) and
    writers, where writers are either symbols referring to a slot in
    the objects, or functions taking two arguments &#x2015; an
    instance and a value &#x2015; which can be used to somehow store
    the value in the new instance. When any DAO-fetching function is
    called in the body, and columns matching the given names are
    encountered in the result, the writers are used instead of the
    default behaviour (try and store the value in the slot that
    matches the column name).</p>

    <p class="desc">A common use for this is to add some non-column
    slots to a DAO class, and use <code><a
    href="#query-dao">query-dao</a></code> within a
    <code>with-column-writers</code> form to pull in extra information
    about the objects, and immediately store it in the new
    instances.</p>

    <h2 id="tabledef">Table definition and creation</h2>

    <p>It can be useful to have the SQL statements needed to build an
    application's tables available from the code, to do things like
    automatically initialising a database. The following macro and
    functions allow you to group sets of SQL statements under symbols,
    with some shortcuts for common elements in table definitions.</p>

    <p class="def" id="deftable">
      <span>macro</span>
      deftable (name &amp;body definition)
    </p>

    <p class="desc">Define a table. name can be either a symbol or a
    <code>(symbol string)</code> list. In the first case, the table
    name is derived from the symbol by <a
    href="s-sql.html">S-SQL</a>'s rules, in the second case, the name
    is given explicitly. The body of definitions can contain anything
    that evaluates to a string, as well as S-SQL expressions. In this
    body, the variables <a
    href="#*table-name*"><code>*table-name*</code></a> and <a
    href="#*table-name*"><code>*table-symbol*</code></a> are bound to
    the relevant values. Note that the definitions are evaluated in
    order, so you'll generally want to first create your table and
    then start defining indices on it.</p>

    <p class="def" id="create-table">
      <span>function</span>
      create-table (symbol)
    </p>

    <p class="desc">Creates the table identified by
    <code>symbol</code> by <a href="#execute">executing</a> the result
    of all the forms in its definition.</p>

    <p class="def" id="create-all-tables">
      <span>function</span>
      create-all-tables ()
    </p>

    <p class="desc">Creates all defined tables.</p>

    <p class="def" id="create-package-tables">
      <span>function</span>
      create-package-tables (package)
    </p>

    <p class="desc">Creates all tables whose identifying symbol is
    interned in the given package.</p>

    <p class="def">
      <a name="*table-name*"></a>
      <span>variables</span>
      *table-name*, *table-symbol*
    </p>

    <p class="desc">These are bound to the relevant symbol and name
    while the clauses of a table definition are evaluated. Can be used
    to define shorthands like the ones below.</p>

    <p class="def">
      <a name="!dao-def"></a>
      <span>function</span>
      !dao-def ()
    </p>

    <p class="desc">Should only be used inside <a
    href="#deftable"><code>deftable</code></a> forms. Adds the result
    of calling <a
    href="#dao-table-definition"><code>dao-table-definition</code></a>
    on <a href="#*table-symbol*"><code>*table-symbol*</code></a> to
    the definition.</p>

    <p class="def">
      <a name="!index"></a>
      <span>function</span>
      !index (&amp;rest columns), !unique-index (&amp;rest columns)
    </p>

    <p class="desc">Define an index on the table being defined. The
    columns can be given as symbols or strings.</p>

    <p class="def">
      <a name="!foreign"></a>
      <span>function</span>
      !foreign (target-table columns &amp;optional target-columns &amp;key on-delete on-update deferrable initially-deferred)
    </p>

    <p class="desc">Add a foreign key to the table being defined.
    <code>target-table</code> is the table the index refers to,
    <code>columns</code> is a list of column names or single name in
    <em>this</em> table, and, if the columns have different names in
    the table referred to, <code>target-columns</code> should be
    another list of names or single name for the target table, or
    <code>:primary-key</code> to indicate that the primary key of the
    target table should be referenced.</p>

    <p class="desc">The <code>on-delete</code> and
    <code>on-update</code> arguments can be used to specify ON DELETE
    and ON UPDATE actions, as per the keywords allowed in <a
    href="s-sql.html#create-table"><code>create-table</code></a>. In
    addition, the deferrable and initially-deferred arguments can be
    used to indicate whether constraint checking can be deferred until
    the current transaction is completed, and whether this should be
    done by default. Note that none of these are really &amp;key
    arguments, but rather are picked out of a &amp;rest arg at
    runtime, so that they can be specified even when
    <code>target-columns</code> is not given.</p>

    <p class="def">
      <a name="!unique"></a>
      <span>function</span>
      !unique (target-fields &amp;key deferrable initially-deferred)
    </p>

    <p class="desc">Constrains one or more columns to only contain
    unique (combinations of) values, with deferrable and
    initially-deferred defined as in <a
    href="#!foreign"><code>!foreign</code></a></p>

    <h2 id="schemata">Schemata</h2>

    Schema allow you to seperate tables into differnet name spaces. In
    different schemata two tables with the same name are allowed to
    exists. The tables can be referenced by fully qualified names or
    with the macro <a href="#with-schema">with-schema</a>. You could
    also set the search path
    with <a href="#set-search-path">set-search-path<a/>. For listing
    end checking there are also the
    functions <a href="#list-schemata">list-schemata</a>
    and <a href="#schema-exist-p">schema-exist-p</a>. The following
    functions allow you to create, drop schemata and to set the search
    path.

    <p class="def">
        <span>function</span>
        <a name="create-schema"></a>
        create-schema (schema)
    </p>

    <p class="desc">
        Creates a new schema, raises an error if the schema is already existing.
    </p>

    <p class="def">
        <span>function</span>
        <a name="drop-schema"></a>
        drop-schema (schema)
    </p>

    <p class="desc">
        Removes a schema. The schema must be empty, otherwise an error
        is raised.
    </p>
    
    <p class="def">
      <span>function</span>
      <a name="get-search-path"></a>
      get-search-path ()
    </p>

    <p class="desc">
        Retrieve the current search path.
    </p>
    
    <p class="def">
      <span>function</span>
      <a name="set-search-path"></a>
      set-search-path (name)
    </p>

    <p class="desc">
        Sets the search path to a new value. This function is used
        by <a href="#with-schema">with-schema</a>.
    </p>

    <h2 id="index">Symbol-index</h2>

    <ul class="symbol-index">
      <li><a href="#abort-transaction">abort-transaction</a></li>
      <li><a href="#deftable">deftable</a></li>
      <li><a href="#call-with-connection">call-with-connection</a></li>
      <li><a href="#clear-connection-pool">clear-connection-pool</a></li>
      <li><a href="#clear-template">clear-template</a></li>
      <li><a href="#commit-transaction">commit-transaction</a></li>
      <li><a href="#connect">connect</a></li>
      <li><a href="#connect-toplevel">connect-toplevel</a></li>
      <li><a href="#connected-p">connected-p</a></li>
      <li><a href="#create-all-tables">create-all-tables</a></li>
      <li><a href="#create-package-tables">create-package-tables</a></li>
      <li><a href="#create-schema">create-schema</a></li>
      <li><a href="#create-table">create-table</a></li>
      <li><a href="#dao-class">dao-class</a></li>
      <li><a href="#!dao-def">!dao-def</a></li>
      <li><a href="#dao-exists-p">dao-exists-p</a></li>
      <li><a href="#dao-keys">dao-keys</a></li>
      <li><a href="#dao-table-definition">dao-table-definition</a></li>
      <li><a href="#dao-table-name">dao-table-name</a></li>
      <li><a href="#*database*">*database*</a></li>
      <li><a href="#database-connection">database-connection</a></li>
      <li><a href="#define-dao-finalization">define-dao-finalization</a></li>
      <li><a href="cl-postgres.html#database-connection-lost">database-connection-lost</a></li>
      <li><a href="cl-postgres.html#database-error">database-error</a></li>
      <li><a href="cl-postgres.html#database-error-cause">database-error-cause</a></li>
      <li><a href="cl-postgres.html#database-error-code">database-error-code</a></li>
      <li><a href="cl-postgres.html#database-error-detail">database-error-detail</a></li>
      <li><a href="cl-postgres.html#database-error-query">database-error-query</a></li>
      <li><a href="cl-postgres.html#database-error-message">database-error-message</a></li>
      <li><a href="#*default-use-ssl*">*default-use-ssl*</a></li>
      <li><a href="#defprepared">defprepared</a></li>
      <li><a href="#defprepared">defprepared-with-names</a></li>
      <li><a href="#delete-dao">delete-dao</a></li>
      <li><a href="#disconnect">disconnect</a></li>
      <li><a href="#disconnect-toplevel">disconnect-toplevel</a></li>
      <li><a href="#doquery">doquery</a></li>
      <li><a href="#drop-schema">drop-schema</a></li>
      <li><a href="#execute">execute</a></li>
      <li><a href="#!foreign">!foreign</a></li>
      <li><a href="#!unique">!unique</a></li>
      <li><a href="#get-dao">get-dao</a></li>
      <li><a href="#get-search-path">get-search-path</a></li>
      <li><a href="#*ignore-unknown-columns*">*ignore-unknown-columns*</a></li>
      <li><a href="#!index">!index</a></li>
      <li><a href="#insert-dao">insert-dao</a></li>
      <li><a href="#list-sequences">list-sequences</a></li>
      <li><a href="#list-schemata">list-schemata</a></li>
      <li><a href="#list-tables">list-tables</a></li>
      <li><a href="#list-views">list-views</a></li>
      <li><a href="#make-dao">make-dao</a></li>
      <li><a href="#*max-pool-size*">*max-pool-size*</a></li>
      <li><a href="#prepare">prepare</a></li>
      <li><a href="#query">query</a></li>
      <li><a href="#query-dao">query-dao</a></li>
      <li><a href="#reconnect">reconnect</a></li>
      <li><a href="#release-savepoint">release-savepoint</a></li>
      <li><a href="#reset-table">reset-table</a></li>
      <li><a href="#rollback-savepoint">rollback-savepoint</a></li>
      <li><a href="#save-dao">save-dao</a></li>
      <li><a href="#save-dao/transaction">save-dao/transaction</a></li>
      <li><a href="#select-dao">select-dao</a></li>
      <li><a href="#set-search-path">set-search-path</a></li>
      <li><a href="#schema-exist-p">schema-exist-p</a></li>
      <li><a href="#sequence-exists-p">sequence-exists-p</a></li>
      <li><a href="#sequence-next">sequence-next</a></li>
      <li><a href="#table-description">table-description</a></li>
      <li><a href="#table-exists-p">table-exists-p</a></li>
      <li><a href="#*table-name*">*table-name*</a></li>
      <li><a href="#*table-name*">*table-symbol*</a></li>
      <li><a href="#!index">!unique-index</a></li>
      <li><a href="#update-dao">update-dao</a></li>
      <li><a href="#view-exists-p">view-exists-p</a></li>
      <li><a href="#with-column-writers">with-column-writers</a></li>
      <li><a href="#with-connection">with-connection</a></li>
      <li><a href="#with-savepoint">with-savepoint</a></li>
      <li><a href="#with-schema">with-schema</a></li>
      <li><a href="#with-transaction">with-transaction</a></li>
    </ul>

  </body>
</html>