SQLite3-OCaml is an OCaml library with bindings to the SQLite3 client API. Sqlite3 is a self-contained, serverless, zero-configuration, transactional SQL database engine with outstanding performance.
The design of these bindings allows for a friendly coexistence with the old
(version 2) SQLite and its OCaml wrapper ocaml-sqlite.
The API documentation is in file src/sqlite3.mli and also here:
online.
SQLite3 has its own online documentation.
The test-directory in this distribution contains simple examples for
testing features of this library. You can execute the tests by running:
dune runtest.
SQLite3-OCaml depends on pkg-config to locate and compile against an
SQLite3 library.
If the SQLite3 version is greater than or equal to 3.3.7, the assumption is that it supports Run-Time Loadable Extensions. If this feature has been explicitly disabled in the library, building applications will fail with something like:
Undefined symbols for architecture …:
"_sqlite3_enable_load_extension", referenced from:
_caml_sqlite3_enable_load_extension in libsqlite3_stubs.a(sqlite3_stubs.o)
-
You can check if your library is missing loadable extensions by searching it for the string
OMIT_LOAD_EXTENSION. -
If you need to change where
pkg-configwill look for the SQLite3 library, set thePKG_CONFIG_PATHenvironment variable to the new directory. Setting theSQLITE3_OCAML_BREWCHECKenvironment variable automates this. This will instruct the build to check for the installation of a brewed version of SQLite and routepkg-configappropriately. -
You can explicitly disable run-time loadable extensions by calling
configurewith the flag--disable-loadable-extensionsor by setting the environment variableSQLITE3_DISABLE_LOADABLE_EXTENSIONSif linking problems persist. -
Due to frequent installation issues with loadable extensions on Mac OS X, the default there is to disable them. You will have to explicitly enable them on that platform.
-
Mikhail Fedotov wrote ocaml-sqlite for SQLite version 2. His bindings served as a reference for this wrapper, but SQLite3 is a complete rewrite.
-
Christian Szegedy wrote the initial release for SQLite version 3.
-
Markus Mottl rewrote Christian's bindings for Jane Street Holding, LLC to clean up some issues and to make it perform better in multi-threaded environments.
-
Enrico Tassi contributed support for user-defined scalar functions.
-
Markus W. Weissmann contributed backup functionality.
Please submit bugs reports, feature requests, contributions to the GitHub issue tracker.
Up-to-date information is available at: https://mmottl.github.io/sqlite3-ocaml