-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathkvs-sql.ss
46 lines (37 loc) · 1.45 KB
/
kvs-sql.ss
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
;;;; Key Value Store for SQL in general (to be specialized by SQLite, PostgreSQL, etc.)
(import
:std/db/dbi
:std/iter
:std/misc/path
:std/sugar
:clan/path-config
:clan/persist/kvs)
(export #t)
(defstruct (KvsSql Kvs)
(begin-tx-stmt commit-tx-stmt abort-tx-stmt
read-stmt write-stmt delete-stmt)
constructor: :init!)
(defmethod {:init! KvsSql}
(lambda (self connection begin-tx-stmt commit-tx-stmt abort-tx-stmt read-stmt write-stmt delete-stmt)
(struct-instance-init! self connection begin-tx-stmt commit-tx-stmt abort-tx-stmt read-stmt write-stmt delete-stmt)))
(defmethod {begin-transaction KvsSql} (lambda (self) (sql-exec (KvsSql-begin-tx-stmt self))))
(defmethod {abort-transaction KvsSql} (lambda (self) (sql-exec (KvsSql-abort-tx-stmt self))))
(defmethod {commit-transaction KvsSql} (lambda (self) (sql-exec (KvsSql-commit-tx-stmt self))))
(defrule (with-statement (var stmt args ...) body ...)
(let ((var stmt))
(try {bind var args ...} body ...
(finally (sql-reset/clear stmt)))))
(defmethod {read-key KvsSql}
(lambda (K key)
(with-statement (s (KvsSql-read-stmt K) key)
(match {query-fetch s}
((eq? #!void) (values {query-row s} #t))
((eq? iter-end) (values #f #f))))))
(defmethod {write-key KvsSql}
(lambda (K k v)
(with-statement (s (KvsSql-write-stmt K) k v)
{exec s})))
(defmethod {delete-key KvsSql}
(lambda (K k)
(with-statement (s (KvsSql-delete-stmt K) k)
{exec s})))