Caqti_connect.Make_unixSourceConstructs the main module used to connect to a database for the given concurrency model.
module System : Caqti_driver_sig.System_unixA pool implementation for the current concurrency library.
module type CONNECTION =
Caqti_connection_sig.S
with type 'a future := 'a System.future
and type ('a, 'err) stream := ('a, 'err) Stream.tThe connection API specialized for the current concurrency library.
Shortcut for the connection API passed as a value.
connect uri locates and loads a driver which can handle uri, passes uri to the driver, which establish a connection and returns a first-class module implementing Caqti_connection_sig.S.
If you use preemptive threading, note that the connection must only be used from the thread where it was created.
val with_connection :
Uri.t ->
(connection ->
('a, [> Caqti_error.load_or_connect ] as 'e) result System.future) ->
('a, 'e) result System.futureval connect_pool :
?max_size:int ->
?max_idle_size:int ->
?post_connect:(connection -> (unit, 'connect_error) result System.future) ->
Uri.t ->
((connection, [> Caqti_error.connect ] as 'connect_error) Pool.t,
[> Caqti_error.load ])
resultconnect_pool uri is a pool of database connections constructed by connect uri.
Do not use pooling for connections to volatile resources like sqlite3::memory: and beware of temporary tables or other objects which may not be shared across connections to the same URI.
If you use preemptive threading, note that the connection pool must only be used from the thread where it was created. Use thread local storage to create a separate pool per thread if necessary.