BundledSQLiteDriver
public final class BundledSQLiteDriver implements SQLiteDriver
A SQLiteDriver that uses a bundled version of SQLite included as a native component of this library.
The bundled SQLite used by this driver is compiled in multi-thread mode which means connections opened by the driver are NOT thread-safe. If multiple connections are desired, then a connection pool is required in order for the connections be used in a multi-thread and concurrent environment. If only a single connection is needed then a thread-safe connection can be opened by using the SQLITE_OPEN_FULLMUTEX flag. If the connection usage is exclusively single threaded, then no additional configuration is required.
Summary
Public constructors |
|---|
Public methods |
|
|---|---|
final void |
addExtension(@NonNull String fileName)Registers a dynamically-linked SQLite extension to load for every subsequent connection opened with this driver. |
final void |
addExtension(@NonNull String fileName, @NonNull String entryPoint)Registers a dynamically-linked SQLite extension to load for every subsequent connection opened with this driver. |
boolean |
Identifies whether the driver has an internal connection pool or not. |
@NonNull SQLiteConnection |
Opens a new database connection. |
final @NonNull SQLiteConnection |
Opens a new database connection. |
Inherited methods |
||
|---|---|---|
|
Public constructors
Public methods
addExtension
public final void addExtension(@NonNull String fileName)
Registers a dynamically-linked SQLite extension to load for every subsequent connection opened with this driver.
The extension is loaded by SQLite in a platform-specific way. SQLite will attempt to open the file using (e.g. dlopen on POSIX) and look up a native function responsible for initializing the extension. SQLite will derive the entry function from the file name.
It is the developer's responsibility to ensure that the library is actually available with the app. If the file is not available when a connection from this driver is opened, then an androidx.sqlite.SQLiteException will be thrown during open.
See also: Load an extension
addExtension
public final void addExtension(@NonNull String fileName, @NonNull String entryPoint)
Registers a dynamically-linked SQLite extension to load for every subsequent connection opened with this driver.
The extension is loaded by SQLite in a platform-specific way. SQLite will attempt to open the file using (e.g. dlopen on POSIX) and look up a native function responsible for initializing the extension. The entryPoint defines the function name to be invoke to initialize the extension.
It is the developer's responsibility to ensure that the library is actually available with the app. If the file is not available when a connection from this driver is opened, then an androidx.sqlite.SQLiteException will be thrown during open.
See also: Load an extension
hasConnectionPool
public boolean hasConnectionPool()
Identifies whether the driver has an internal connection pool or not.
A driver with an internal pool should be capable of opening connections that are safe to be used in a multi-thread and concurrent environment whereas a driver that does not have an internal pool will require the application to manage connections in a thread-safe manner. A driver might not report containing a connection pool but might still be safe to be used in a multi-thread environment, such behavior will depend on the driver implementation.
The value returned should be used as a signal to higher abstractions in order to determine if the driver and its connections should be managed by an external connection pool or not.
open
public @NonNull SQLiteConnection open(@NonNull String fileName)
Opens a new database connection.
To open an in-memory database use the special name :memory: as the fileName.
| Returns | |
|---|---|
@NonNull SQLiteConnection |
the database connection. |
open
public final @NonNull SQLiteConnection open(@NonNull String fileName, int flags)
Opens a new database connection.
See also Opening A New Database Connection
| Returns | |
|---|---|
@NonNull SQLiteConnection |
the database connection. |