To connect the server, define a config map and pass it into the connect
function:
(require '[pg.core :as pg])
(def config
{:host "127.0.0.1"
:port 5432
:user "test"
:password "test"
:database "test"})
(def conn
(pg/connect config))
The conn
is an instance of the org.pg.Connection
class.
The :host
, :port
, and :password
config fields have default values and
might be skipped (the password is an empty string by default). Only the :user
and :database
fields are required when connecting. See the list of possible
fields and their values in a separate section.
To close a connection, pass it into the close
function:
(pg/close conn)
You cannot open or use this connection again afterwards.
To close the connection automatically, use either with-connection
or
with-open
macro. The with-connection
macro takes a binding symbol and a
config map; the connection gets bound to the binding symbold while the body is
executed:
(pg/with-connection [conn config]
(pg/query conn "select 1 as one"))
There is a shorter version of this macro called with-conn
:
(pg/with-conn [conn config]
(pg/query conn "select 1 as one"))
The standard with-open
macro calls the (.close connection)
method on exit:
(with-open [conn (pg/connect config)]
(pg/query conn "select 1 as one"))
Avoid situations when you close a connection manually. Use one of these two macros shown above.
Use :pg-params
field to specify connection-specific Postgres parameters. These
are "TimeZone", "application_name", "DateStyle" and more. Both keys and values
are plain strings:
(def config+
(assoc config
:pg-params
{"application_name" "Clojure"
"DateStyle" "ISO, MDY"}))
(def conn
(pg/connect config+))
The following table describes all the possible connection options with the possible values and semantics. Only the two first options are requred. All the rest have predefined values.
Field | Type | Default | Comment |
---|---|---|---|
:user | string | required | the name of the DB user |
:database | string | required | the name of the database |
:connection-uri | string | nil | A URI string with a user, database, and other parameters1 |
:host | string | 127.0.0.1 | IP or hostname |
:port | integer | 5432 | port number |
:password | string | "" | DB user password |
:pg-params | map | {} | A map of session params like {string string} |
:binary-encode? | bool | false | Whether to use binary data encoding |
:binary-decode? | bool | false | Whether to use binary data decoding |
:read-only? | bool | false | Whether to initiate this connection in READ ONLY mode (see below) |
:in-stream-buf-size | integer | 0xFFFF | Size of the input buffered socket stream |
:out-stream-buf-size | integer | 0xFFFF | Size of the output buffered socket stream |
:fn-notification | 1-arg fn | logging fn | A function to handle notifications |
:fn-protocol-version | 1-arg fn | logging fn | A function to handle negotiation version protocol event |
:fn-notice | 1-arg fn | logging fn | A function to handle notices |
:ssl? | bool | false | Whether to use an SSL connection2 |
:use-ssl? | bool | false | Deprecated: an outdated version of :ssl? |
:ssl-validation | mixed | nil | How (and if) to validate SSL certificates2 |
:ssl-context | SSLContext | nil | An custom instance of SSLContext class to wrap a socket2 |
:unix-socket? | bool | false | Whether to connect to a Unix domain socket3 |
:unix-socket-path | string | null | A custom path to Unix domain socket3 |
:so-keep-alive? | bool | true | Socket KeepAlive value |
:so-tcp-no-delay? | bool | true | Socket TcpNoDelay value |
:so-timeout | integer | 15.000 | Socket timeout value, in ms |
:so-recv-buf-size | integer | 0xFFFF | Socket receive buffer size |
:so-send-buf-size | integer | 0xFFFF | Socket send buffer size |
:cancel-timeout-ms | integer | 5.000 | Default value for the with-timeout macro, in ms |
:protocol-version | integer | 196608 | Postgres protocol version |
:object-mapper | ObjectMapper | JSON.defaultMapper | An instance of ObjectMapper for custom JSON processing (see the "JSON" section) |
The :read-only?
connection parameter does two things under the hood:
It appends the default_transaction_read_only
parameter to the startup
message set to on
. Thus, any transaction gets started on READ ONLY
mode.
It prevents the :read-only?
flag from overriding in the with-tx
macro. Say, even if the macro is called like this:
(pg/with-tx [conn {:read-only? false}] ;; try to mute the global :read-only? flag
(pg/query conn "delete from students"))
The transaction will be in READ ONLY
mode anyway.
Can you improve this documentation?Edit on GitHub
cljdoc is a website building & hosting documentation for Clojure/Script libraries
× close