2016-12-24 12:34:27 +00:00
|
|
|
# purescript-postgresql-client
|
|
|
|
|
|
|
|
purescript-postgresql-client is a PostgreSQL client library for PureScript.
|
2016-12-25 22:58:29 +00:00
|
|
|
|
|
|
|
To use this library, you need to add `pg` as an npm dependency.
|
|
|
|
|
2016-12-24 12:34:27 +00:00
|
|
|
Included is a preprocessor, purspgpp, which finds embedded SQL queries in
|
|
|
|
PureScript source files and infers their types. Such queries can be written as
|
|
|
|
follows:
|
|
|
|
|
|
|
|
```purescript
|
|
|
|
userName = [query|
|
|
|
|
SELECT first_name, last_name
|
|
|
|
FROM users
|
|
|
|
WHERE id = $1
|
|
|
|
|]
|
|
|
|
```
|
|
|
|
|
|
|
|
purspgpp will replace this by something like the following:
|
|
|
|
|
|
|
|
```purescript
|
|
|
|
(Query """
|
|
|
|
SELECT first_name, last_name
|
|
|
|
FROM users
|
|
|
|
WHERE id = $1
|
2016-12-26 01:43:06 +00:00
|
|
|
""" :: Query (Tuple UUID Unit) (Tuple String (Tuple String Unit))
|
2016-12-24 12:34:27 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
You can integrate purspgpp into your build system. For example, here is a
|
|
|
|
PowerShell script that executes it for all `.purspg` files:
|
|
|
|
|
|
|
|
```powershell
|
|
|
|
Get-ChildItem src -Recurse -Filter *.purspg `
|
|
|
|
| ForEach-Object {
|
|
|
|
perl6 `
|
|
|
|
bower_components/purescript-postgresql-client/purspgpp `
|
|
|
|
"user=postgres password=lol123 dbname=nn" `
|
|
|
|
"$($_.FullName)" `
|
|
|
|
"$([IO.Path]::ChangeExtension($_.FullName, "purs"))"
|
|
|
|
if (!$?) {
|
|
|
|
Write-Error "Unable to preprocess $_"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|