package caqti-async
Install
dune-project
Dependency
Authors
Maintainers
Sources
sha256=a15d71b6428997703273dc6d55a99045fb62c3243c751de5ae8c3fc25421f16a
sha512=386502d9ea2f1769081b81e6888bf4c2a27248498eabc0d4eb4adfde04c74f48f2aa587c0ce3a34604c73d157ed6533052b4d0b9a0fb3f352929ef847f3aa9fa
doc/caqti-async/Caqti_async/index.html
Module Caqti_asyncSource
Connector for Async.
include Caqti_connect_sig.S with type 'a future := 'a Async_kernel.Deferred.t
module Pool :
Caqti_pool_sig.S with type 'a future := 'a Async_kernel.Deferred.tA pool implementation for the current concurrency library.
module Stream :
Caqti_stream.S with type 'a future := 'a Async_kernel.Deferred.tmodule type CONNECTION =
Caqti_connection_sig.S
with type 'a future := 'a Async_kernel.Deferred.t
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.
val connect :
Uri.t ->
(connection, [> Caqti_error.load_or_connect ]) result Async_kernel.Deferred.tconnect 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 Async_kernel.Deferred.t) ->
('a, 'e) result Async_kernel.Deferred.tval connect_pool :
?max_size:int ->
?max_idle_size:int ->
?post_connect:
(connection -> (unit, 'connect_error) result Async_kernel.Deferred.t) ->
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.