Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/andrewchambers/janet-pq

Bindings to libpq.
https://github.com/andrewchambers/janet-pq

janet postgres

Last synced: 2 months ago
JSON representation

Bindings to libpq.

Awesome Lists containing this project

README

        

# janet-pq
Bindings to libpq.

# quick-examples

Basic usage:

```
(import pq)
(def conn (pq/connect "postgresql://localhost?dbname=postgres"))
(pq/exec conn "create table users(name text, data jsonb);")
(pq/exec conn "insert into users(name, data) values($1, $2);" "ac" (pq/jsonb @{"some" "data"}))
(pq/row conn "select * from users where name = $1;" "ac")
{:name "ac" :data @{"some" "data"}}
(pq/all conn "select * from users")
[{:name "ac" :data @{"some" "data"}} ...]
(pq/val conn "select data from users where name = $1;" "ac")
@{"some" "data"}
```

Transactions:

```
(import pq)
...
(pq/tx conn {:mode "isolation serializable read only" :retry true}
(unless (pq/val conn "select ....")
(pq/rollback conn))
(pq/val conn "select ...."))
```

Custom type encoding/decoding:

```
(import pq)
...

# directly insert custom encoding.
(pq/exec conn "insert into tab(x) values($1);" [TYPEOID ISBINARY BYTES])

# use a method for custom type encoding.
(pq/exec conn "insert into tab(x) values($1);" {:pq/marshal (fn [self] [TYPEOID ISBINARY BYTES])})

# Add a custom type decoder.
(put pg/*decoders* TYPEOID custom-decoder)
(pq/all conn "select * from tab;")

```

Error handling:

```
(import pq)
...
(try
...
([err] (when (pq/error? err)
(def msg (pq/result-error-field err ...)))))
```

# Special thanks

[Jon Staab](https://github.com/staab) - The author of the first janet postgres library from which this was inspired, and a core contributor to this library.