-
- All Implemented Interfaces:
-
androidx.sqlite.db.SupportSQLiteDatabase
,java.io.Closeable
,java.lang.AutoCloseable
public final class SQLiteDatabase extends SQLiteClosable implements SupportSQLiteDatabase
Exposes methods to manage a SQLite database.
SQLiteDatabase has methods to create, delete, execute SQL commands, and perform other common database management tasks.
See the Notepad sample application in the SDK for an example of creating and managing a database.
Database names must be unique within an application, not across all applications.
Localized Collation - ORDER BYIn addition to SQLite's default
BINARY
collator, Android supplies two more,LOCALIZED
, which changes with the system's current locale, andUNICODE
, which is the Unicode Collation Algorithm and not tailored to the current locale.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description public interface
SQLiteDatabase.CursorFactory
Used to allow returning sub-classes of Cursor when calling query.
public interface
SQLiteDatabase.CustomFunction
A callback interface for a custom sqlite3 function.This can be used to create a function that can be called fromsqlite3 database triggers.
-
Field Summary
Fields Modifier and Type Field Description public final static int
CONFLICT_ROLLBACK
public final static int
CONFLICT_ABORT
public final static int
CONFLICT_FAIL
public final static int
CONFLICT_IGNORE
public final static int
CONFLICT_REPLACE
public final static int
CONFLICT_NONE
public final static int
SQLITE_MAX_LIKE_PATTERN_LENGTH
public final static int
OPEN_READWRITE
public final static int
OPEN_READONLY
public final static int
NO_LOCALIZED_COLLATORS
public final static int
CREATE_IF_NECESSARY
public final static int
ENABLE_WRITE_AHEAD_LOGGING
public final static int
MAX_SQL_CACHE_SIZE
-
Method Summary
Modifier and Type Method Description static int
releaseMemory()
Attempts to release memory that SQLite holds but does not require tooperate properly. void
setLockingEnabled(boolean lockingEnabled)
Control whether or not the SQLiteDatabase is made thread-safe by using locksaround critical sections. void
beginTransaction()
Begins a transaction in EXCLUSIVE mode. void
beginTransactionNonExclusive()
Begins a transaction in IMMEDIATE mode. void
beginTransactionWithListener(SQLiteTransactionListener transactionListener)
void
beginTransactionWithListenerNonExclusive(SQLiteTransactionListener transactionListener)
void
beginTransactionWithListener(SQLiteTransactionListener transactionListener)
Begins a transaction in EXCLUSIVE mode. void
beginTransactionWithListenerNonExclusive(SQLiteTransactionListener transactionListener)
Begins a transaction in IMMEDIATE mode. void
endTransaction()
End a transaction. void
setTransactionSuccessful()
Marks the current transaction as successful. boolean
inTransaction()
Returns true if the current thread has a transaction pending. boolean
isDbLockedByCurrentThread()
Returns true if the current thread is holding an active connection to the database. boolean
isDbLockedByOtherThreads()
Always returns false. boolean
yieldIfContended()
Temporarily end the transaction to let other threads run. boolean
yieldIfContendedSafely()
Temporarily end the transaction to let other threads run. boolean
yieldIfContendedSafely(long sleepAfterYieldDelay)
Temporarily end the transaction to let other threads run. Map<String, String>
getSyncedTables()
Deprecated. static SQLiteDatabase
openDatabase(String path, SQLiteDatabase.CursorFactory factory, int flags)
Open the database according to the flags OPEN_READWRITEOPEN_READONLYCREATE_IF_NECESSARY and/or NO_LOCALIZED_COLLATORS. static SQLiteDatabase
openDatabase(String path, String password, SQLiteDatabase.CursorFactory factory, int flags, SQLiteDatabaseHook databaseHook)
Open the database according to the flags OPEN_READWRITEOPEN_READONLYCREATE_IF_NECESSARY and/or NO_LOCALIZED_COLLATORS. static SQLiteDatabase
openDatabase(String path, Array<byte> password, SQLiteDatabase.CursorFactory factory, int flags, SQLiteDatabaseHook databaseHook)
Open the database according to the flags OPEN_READWRITEOPEN_READONLYCREATE_IF_NECESSARY and/or NO_LOCALIZED_COLLATORS. static SQLiteDatabase
openDatabase(String path, SQLiteDatabase.CursorFactory factory, int flags, DatabaseErrorHandler errorHandler)
Open the database according to the flags OPEN_READWRITEOPEN_READONLYCREATE_IF_NECESSARY and/or NO_LOCALIZED_COLLATORS. static SQLiteDatabase
openDatabase(String path, String password, SQLiteDatabase.CursorFactory factory, int flags, DatabaseErrorHandler errorHandler, SQLiteDatabaseHook databaseHook)
Open the database according to the flags OPEN_READWRITEOPEN_READONLYCREATE_IF_NECESSARY and/or NO_LOCALIZED_COLLATORS. static SQLiteDatabase
openDatabase(String path, Array<byte> password, SQLiteDatabase.CursorFactory factory, int flags, DatabaseErrorHandler errorHandler, SQLiteDatabaseHook databaseHook)
Open the database according to the flags OPEN_READWRITEOPEN_READONLYCREATE_IF_NECESSARY and/or NO_LOCALIZED_COLLATORS. static SQLiteDatabase
openOrCreateDatabase(File file, SQLiteDatabase.CursorFactory factory)
Equivalent to openDatabase(file.getPath(), factory, CREATE_IF_NECESSARY). static SQLiteDatabase
openOrCreateDatabase(String path, SQLiteDatabase.CursorFactory factory)
Equivalent to openDatabase(path, factory, CREATE_IF_NECESSARY). static SQLiteDatabase
openOrCreateDatabase(String path, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler)
Equivalent to openDatabase(path, factory, CREATE_IF_NECESSARY, errorHandler). static SQLiteDatabase
openOrCreateDatabase(File file, String password, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler)
Equivalent to openDatabase(file.getAbsolutePath(), password, factory, CREATE_IF_NECESSARY, errorHandler, null). static SQLiteDatabase
openOrCreateDatabase(File file, Array<byte> password, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler)
Equivalent to openDatabase(file.getAbsolutePath(), password, factory, CREATE_IF_NECESSARY, errorHandler, null). static SQLiteDatabase
openOrCreateDatabase(String path, String password, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler)
Equivalent to openDatabase(path, password, factory, CREATE_IF_NECESSARY, errorHandler, null). static SQLiteDatabase
openOrCreateDatabase(String path, Array<byte> password, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler)
Equivalent to openDatabase(path, password, factory, CREATE_IF_NECESSARY, errorHandler, null). static SQLiteDatabase
openOrCreateDatabase(File file, String password, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler, SQLiteDatabaseHook databaseHook)
Equivalent to openDatabase(file.getAbsolutePath(), password, factory, CREATE_IF_NECESSARY, errorHandler, databaseHook). static SQLiteDatabase
openOrCreateDatabase(File file, Array<byte> password, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler, SQLiteDatabaseHook databaseHook)
Equivalent to openDatabase(file.getAbsolutePath(), password, factory, CREATE_IF_NECESSARY, errorHandler, databaseHook). static SQLiteDatabase
openOrCreateDatabase(String path, String password, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler, SQLiteDatabaseHook databaseHook)
Equivalent to openDatabase(path, password, factory, CREATE_IF_NECESSARY, errorHandler, databaseHook). static SQLiteDatabase
openOrCreateDatabase(String path, Array<byte> password, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler, SQLiteDatabaseHook databaseHook)
Equivalent to openDatabase(path, password, factory, CREATE_IF_NECESSARY, errorHandler, databaseHook). static boolean
deleteDatabase(File file)
Deletes a database including its journal file and other auxiliary filesthat may have been created by the database engine. void
reopenReadWrite()
Reopens the database in read-write mode.If the database is already read-write, does nothing. static SQLiteDatabase
create(SQLiteDatabase.CursorFactory factory)
Create a memory backed SQLite database. void
addCustomFunction(String name, int numArgs, SQLiteDatabase.CustomFunction function)
Registers a CustomFunction callback as a function that can be called fromSQLite database triggers. int
getVersion()
Gets the database version. void
setVersion(int version)
Sets the database version. long
getMaximumSize()
Returns the maximum size the database may grow to. long
setMaximumSize(long numBytes)
Sets the maximum size the database will grow to. long
getPageSize()
Returns the current database page size, in bytes. void
setPageSize(long numBytes)
Sets the database page size. Cursor
query(String query)
Cursor
query(String query, Array<Object> bindArgs)
Cursor
query(SupportSQLiteQuery query)
Cursor
query(SupportSQLiteQuery query, CancellationSignal cancellationSignal)
long
insert(String table, int conflictAlgorithm, ContentValues values)
int
delete(String table, String whereClause, Array<Object> whereArgs)
int
update(String table, int conflictAlgorithm, ContentValues values, String whereClause, Array<Object> whereArgs)
void
markTableSyncable(String table, String deletedTable)
Mark this table as syncable. void
markTableSyncable(String table, String foreignKey, String updateTable)
Mark this table as syncable, with the _sync_dirty residing in anothertable. static String
findEditTable(String tables)
Finds the name of the first table, which is editable. SQLiteStatement
compileStatement(String sql)
Compiles an SQL statement into a reusable pre-compiled statement object. Cursor
query(boolean distinct, String table, Array<String> columns, String selection, Array<String> selectionArgs, String groupBy, String having, String orderBy, String limit)
Query the given URL, returning a Cursor over the result set. Cursor
query(boolean distinct, String table, Array<String> columns, String selection, Array<String> selectionArgs, String groupBy, String having, String orderBy, String limit, CancellationSignal cancellationSignal)
Query the given URL, returning a Cursor over the result set. Cursor
queryWithFactory(SQLiteDatabase.CursorFactory cursorFactory, boolean distinct, String table, Array<String> columns, String selection, Array<String> selectionArgs, String groupBy, String having, String orderBy, String limit)
Query the given URL, returning a Cursor over the result set. Cursor
queryWithFactory(SQLiteDatabase.CursorFactory cursorFactory, boolean distinct, String table, Array<String> columns, String selection, Array<String> selectionArgs, String groupBy, String having, String orderBy, String limit, CancellationSignal cancellationSignal)
Query the given URL, returning a Cursor over the result set. Cursor
query(String table, Array<String> columns, String selection, Array<String> selectionArgs, String groupBy, String having, String orderBy)
Query the given table, returning a Cursor over the result set. Cursor
query(String table, Array<String> columns, String selection, Array<String> selectionArgs, String groupBy, String having, String orderBy, String limit)
Query the given table, returning a Cursor over the result set. Cursor
rawQuery(String sql, Array<String> selectionArgs)
Runs the provided SQL and returns a Cursor over the result set. Cursor
rawQuery(String sql, Array<Object> bindingArgs)
Runs the provided SQL and returns a Cursor over the result set. Cursor
rawQuery(String sql, Array<String> selectionArgs, CancellationSignal cancellationSignal)
Runs the provided SQL and returns a Cursor over the result set. Cursor
rawQueryWithFactory(SQLiteDatabase.CursorFactory cursorFactory, String sql, Array<String> selectionArgs, String editTable)
Runs the provided SQL and returns a cursor over the result set. Cursor
rawQueryWithFactory(SQLiteDatabase.CursorFactory cursorFactory, String sql, Array<String> selectionArgs, String editTable, CancellationSignal cancellationSignal)
Runs the provided SQL and returns a cursor over the result set. long
insert(String table, String nullColumnHack, ContentValues values)
Convenience method for inserting a row into the database. long
insertOrThrow(String table, String nullColumnHack, ContentValues values)
Convenience method for inserting a row into the database. long
replace(String table, String nullColumnHack, ContentValues initialValues)
Convenience method for replacing a row in the database.Inserts a new row if a row does not already exist. long
replaceOrThrow(String table, String nullColumnHack, ContentValues initialValues)
Convenience method for replacing a row in the database.Inserts a new row if a row does not already exist. long
insertWithOnConflict(String table, String nullColumnHack, ContentValues initialValues, int conflictAlgorithm)
General method for inserting a row into the database. int
delete(String table, String whereClause, Array<String> whereArgs)
Convenience method for deleting rows in the database. int
update(String table, ContentValues values, String whereClause, Array<String> whereArgs)
Convenience method for updating rows in the database. int
updateWithOnConflict(String table, ContentValues values, String whereClause, Array<String> whereArgs, int conflictAlgorithm)
Convenience method for updating rows in the database. void
execSQL(String sql)
Execute a single SQL statement that is NOT a SELECTor any other SQL statement that returns data. void
execSQL(String sql, Array<Object> bindArgs)
Execute a single SQL statement that is NOT a SELECT/INSERT/UPDATE/DELETE. void
rawExecSQL(String sql, Array<Object> bindArgs)
Executes a statement that returns a count of the number of rowsthat were changed. void
validateSql(String sql, CancellationSignal cancellationSignal)
Verifies that a SQL SELECT statement is valid by compiling it. boolean
isReadOnly()
Returns true if the database is opened as read only. boolean
isInMemoryDatabase()
Returns true if the database is in-memory db. boolean
isOpen()
Returns true if the database is currently open. boolean
needUpgrade(int newVersion)
Returns true if the new version code is greater than the current database version. final String
getPath()
Gets the path to the database file. void
setLocale(Locale locale)
Sets the locale for this database. void
setMaxSqlCacheSize(int cacheSize)
Sets the maximum size of the prepared-statement cache for this database.(size of the cache = number of compiled-sql-statements stored in the cache). void
setForeignKeyConstraintsEnabled(boolean enable)
Sets whether foreign key constraints are enabled for the database. boolean
enableWriteAheadLogging()
This method enables parallel execution of queries from multiple threads on thesame database. void
disableWriteAheadLogging()
This method disables the features enabled by enableWriteAheadLogging. boolean
isWriteAheadLoggingEnabled()
Returns true if write-ahead logging has been enabled for this database. List<Pair<String, String>>
getAttachedDbs()
Returns list of full pathnames of all attached databases including the main databaseby executing 'pragma database_list' on the database. boolean
isDatabaseIntegrityOk()
Runs 'pragma integrity_check' on the given database (and all the attached databases)and returns true if the given database (and all its attached databases) pass integrity_check,false otherwise. void
changePassword(String newPassword)
void
changePassword(Array<byte> newPassword)
String
toString()
static boolean
hasCodec()
void
enableLocalizedCollators()
-
Methods inherited from class net.zetetic.database.sqlcipher.SQLiteClosable
acquireReference, close, releaseReference, releaseReferenceFromContainer
-
Methods inherited from class java.io.Closeable
close
-
Methods inherited from class androidx.sqlite.db.SupportSQLiteDatabase
beginTransaction, beginTransactionNonExclusive, beginTransactionWithListener, beginTransactionWithListenerNonExclusive, compileStatement, delete, disableWriteAheadLogging, enableWriteAheadLogging, endTransaction, execPerConnectionSQL, execSQL, getAttachedDbs, getMaximumSize, getPageSize, getPath, getVersion, inTransaction, insert, isDatabaseIntegrityOk, isDbLockedByCurrentThread, isExecPerConnectionSQLSupported, isOpen, isReadOnly, isWriteAheadLoggingEnabled, needUpgrade, query, setForeignKeyConstraintsEnabled, setLocale, setMaxSqlCacheSize, setMaximumSize, setPageSize, setTransactionSuccessful, setVersion, update, yieldIfContendedSafely
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
-
Method Detail
-
releaseMemory
static int releaseMemory()
Attempts to release memory that SQLite holds but does not require tooperate properly. Typically this memory will come from the page cache.
-
setLockingEnabled
@Deprecated() void setLockingEnabled(boolean lockingEnabled)
Control whether or not the SQLiteDatabase is made thread-safe by using locksaround critical sections. This is pretty expensive, so if you know that yourDB will only be used by a single thread then you should set this to false.The default is true.
- Parameters:
lockingEnabled
- set to true to enable locks, false otherwise
-
beginTransaction
void beginTransaction()
Begins a transaction in EXCLUSIVE mode.
Transactions can be nested.When the outer transaction is ended all ofthe work done in that transaction and all of the nested transactions will be committed orrolled back. The changes will be rolled back if any transaction is ended without beingmarked as clean (by calling setTransactionSuccessful). Otherwise they will be committed.
Here is the standard idiom for transactions:
db.beginTransaction(); try { ... db.setTransactionSuccessful(); } finally { db.endTransaction(); }
-
beginTransactionNonExclusive
void beginTransactionNonExclusive()
Begins a transaction in IMMEDIATE mode. Transactions can be nested. Whenthe outer transaction is ended all of the work done in that transactionand all of the nested transactions will be committed or rolled back. Thechanges will be rolled back if any transaction is ended without beingmarked as clean (by calling setTransactionSuccessful). Otherwise theywill be committed.
Here is the standard idiom for transactions:
db.beginTransactionNonExclusive(); try { ... db.setTransactionSuccessful(); } finally { db.endTransaction(); }
-
beginTransactionWithListener
void beginTransactionWithListener(SQLiteTransactionListener transactionListener)
-
beginTransactionWithListenerNonExclusive
void beginTransactionWithListenerNonExclusive(SQLiteTransactionListener transactionListener)
-
beginTransactionWithListener
void beginTransactionWithListener(SQLiteTransactionListener transactionListener)
Begins a transaction in EXCLUSIVE mode.
Transactions can be nested.When the outer transaction is ended all ofthe work done in that transaction and all of the nested transactions will be committed orrolled back. The changes will be rolled back if any transaction is ended without beingmarked as clean (by calling setTransactionSuccessful). Otherwise they will be committed.
Here is the standard idiom for transactions:
db.beginTransactionWithListener(listener); try { ... db.setTransactionSuccessful(); } finally { db.endTransaction(); }
- Parameters:
transactionListener
- listener that should be notified when the transaction begins,commits, or is rolled back, either explicitly or by a call to yieldIfContendedSafely.
-
beginTransactionWithListenerNonExclusive
void beginTransactionWithListenerNonExclusive(SQLiteTransactionListener transactionListener)
Begins a transaction in IMMEDIATE mode. Transactions can be nested. Whenthe outer transaction is ended all of the work done in that transactionand all of the nested transactions will be committed or rolled back. Thechanges will be rolled back if any transaction is ended without beingmarked as clean (by calling setTransactionSuccessful). Otherwise theywill be committed.
Here is the standard idiom for transactions:
db.beginTransactionWithListenerNonExclusive(listener); try { ... db.setTransactionSuccessful(); } finally { db.endTransaction(); }
- Parameters:
transactionListener
- listener that should be notified when thetransaction begins, commits, or is rolled back, eitherexplicitly or by a call to yieldIfContendedSafely.
-
endTransaction
void endTransaction()
End a transaction. See beginTransaction for notes about how to use this and when transactionsare committed and rolled back.
-
setTransactionSuccessful
void setTransactionSuccessful()
Marks the current transaction as successful. Do not do any more database work betweencalling this and calling endTransaction. Do as little non-database work as possible in thatsituation too. If any errors are encountered between this and endTransaction the transactionwill still be committed.
-
inTransaction
boolean inTransaction()
Returns true if the current thread has a transaction pending.
-
isDbLockedByCurrentThread
boolean isDbLockedByCurrentThread()
Returns true if the current thread is holding an active connection to the database.
The name of this method comes from a time when having an active connectionto the database meant that the thread was holding an actual lock on thedatabase. Nowadays, there is no longer a true "database lock" although threadsmay block if they cannot acquire a database connection to perform aparticular operation.
-
isDbLockedByOtherThreads
@Deprecated() boolean isDbLockedByOtherThreads()
Always returns false.
There is no longer the concept of a database lock, so this method always returns false.
-
yieldIfContended
@Deprecated() boolean yieldIfContended()
Temporarily end the transaction to let other threads run. The transaction is assumed to besuccessful so far. Do not call setTransactionSuccessful before calling this. When thisreturns a new transaction will have been created but not marked as successful.
-
yieldIfContendedSafely
boolean yieldIfContendedSafely()
Temporarily end the transaction to let other threads run. The transaction is assumed to besuccessful so far. Do not call setTransactionSuccessful before calling this. When thisreturns a new transaction will have been created but not marked as successful. This assumesthat there are no nested transactions (beginTransaction has only been called once) and willthrow an exception if that is not the case.
-
yieldIfContendedSafely
boolean yieldIfContendedSafely(long sleepAfterYieldDelay)
Temporarily end the transaction to let other threads run. The transaction is assumed to besuccessful so far. Do not call setTransactionSuccessful before calling this. When thisreturns a new transaction will have been created but not marked as successful. This assumesthat there are no nested transactions (beginTransaction has only been called once) and willthrow an exception if that is not the case.
- Parameters:
sleepAfterYieldDelay
- if > 0, sleep this long before starting a new transaction ifthe lock was actually yielded.
-
getSyncedTables
@Deprecated() Map<String, String> getSyncedTables()
Deprecated.
-
openDatabase
static SQLiteDatabase openDatabase(String path, SQLiteDatabase.CursorFactory factory, int flags)
Open the database according to the flags OPEN_READWRITEOPEN_READONLYCREATE_IF_NECESSARY and/or NO_LOCALIZED_COLLATORS.
Sets the locale of the database to the the system's current locale.Call setLocale if you would like something else.
- Parameters:
path
- to database file to open and/or createfactory
- an optional factory class that is called to instantiate acursor when query is called, or null for defaultflags
- to control database access mode
-
openDatabase
static SQLiteDatabase openDatabase(String path, String password, SQLiteDatabase.CursorFactory factory, int flags, SQLiteDatabaseHook databaseHook)
Open the database according to the flags OPEN_READWRITEOPEN_READONLYCREATE_IF_NECESSARY and/or NO_LOCALIZED_COLLATORS.
Sets the locale of the database to the the system's current locale.Call setLocale if you would like something else.
- Parameters:
path
- to database file to open and/or createpassword
- for use with a SQLCipher databasefactory
- an optional factory class that is called to instantiate acursor when query is called, or null for defaultflags
- to control database access modedatabaseHook
- to invoke preKey and postKey operations with SQLCipher
-
openDatabase
static SQLiteDatabase openDatabase(String path, Array<byte> password, SQLiteDatabase.CursorFactory factory, int flags, SQLiteDatabaseHook databaseHook)
Open the database according to the flags OPEN_READWRITEOPEN_READONLYCREATE_IF_NECESSARY and/or NO_LOCALIZED_COLLATORS.
Sets the locale of the database to the the system's current locale.Call setLocale if you would like something else.
- Parameters:
path
- to database file to open and/or createpassword
- for use with a SQLCipher databasefactory
- an optional factory class that is called to instantiate acursor when query is called, or null for defaultflags
- to control database access modedatabaseHook
- to invoke preKey and postKey operations with SQLCipher
-
openDatabase
static SQLiteDatabase openDatabase(String path, SQLiteDatabase.CursorFactory factory, int flags, DatabaseErrorHandler errorHandler)
Open the database according to the flags OPEN_READWRITEOPEN_READONLYCREATE_IF_NECESSARY and/or NO_LOCALIZED_COLLATORS.
Sets the locale of the database to the the system's current locale.Call setLocale if you would like something else.
Accepts input param: a concrete instance of DatabaseErrorHandler to beused to handle corruption when sqlite reports database corruption.
- Parameters:
path
- to database file to open and/or createfactory
- an optional factory class that is called to instantiate acursor when query is called, or null for defaultflags
- to control database access modeerrorHandler
- the DatabaseErrorHandler obj to be used to handle corruptionwhen sqlite reports database corruption
-
openDatabase
static SQLiteDatabase openDatabase(String path, String password, SQLiteDatabase.CursorFactory factory, int flags, DatabaseErrorHandler errorHandler, SQLiteDatabaseHook databaseHook)
Open the database according to the flags OPEN_READWRITEOPEN_READONLYCREATE_IF_NECESSARY and/or NO_LOCALIZED_COLLATORS.
Sets the locale of the database to the the system's current locale.Call setLocale if you would like something else.
Accepts input param: a concrete instance of DatabaseErrorHandler to beused to handle corruption when sqlite reports database corruption.
- Parameters:
path
- to database file to open and/or createpassword
- for use with a SQLCipher databasefactory
- an optional factory class that is called to instantiate acursor when query is called, or null for defaultflags
- to control database access modeerrorHandler
- the DatabaseErrorHandler obj to be used to handle corruptionwhen sqlite reports database corruptiondatabaseHook
- to invoke preKey and postKey operations with SQLCipher
-
openDatabase
static SQLiteDatabase openDatabase(String path, Array<byte> password, SQLiteDatabase.CursorFactory factory, int flags, DatabaseErrorHandler errorHandler, SQLiteDatabaseHook databaseHook)
Open the database according to the flags OPEN_READWRITEOPEN_READONLYCREATE_IF_NECESSARY and/or NO_LOCALIZED_COLLATORS.
Sets the locale of the database to the the system's current locale.Call setLocale if you would like something else.
Accepts input param: a concrete instance of DatabaseErrorHandler to beused to handle corruption when sqlite reports database corruption.
- Parameters:
path
- to database file to open and/or createpassword
- for use with a SQLCipher databasefactory
- an optional factory class that is called to instantiate acursor when query is called, or null for defaultflags
- to control database access modeerrorHandler
- the DatabaseErrorHandler obj to be used to handle corruptionwhen sqlite reports database corruptiondatabaseHook
- to invoke preKey and postKey operations with SQLCipher
-
openOrCreateDatabase
static SQLiteDatabase openOrCreateDatabase(File file, SQLiteDatabase.CursorFactory factory)
Equivalent to openDatabase(file.getPath(), factory, CREATE_IF_NECESSARY).
-
openOrCreateDatabase
static SQLiteDatabase openOrCreateDatabase(String path, SQLiteDatabase.CursorFactory factory)
Equivalent to openDatabase(path, factory, CREATE_IF_NECESSARY).
-
openOrCreateDatabase
static SQLiteDatabase openOrCreateDatabase(String path, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler)
Equivalent to openDatabase(path, factory, CREATE_IF_NECESSARY, errorHandler).
-
openOrCreateDatabase
static SQLiteDatabase openOrCreateDatabase(File file, String password, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler)
Equivalent to openDatabase(file.getAbsolutePath(), password, factory, CREATE_IF_NECESSARY, errorHandler, null).
-
openOrCreateDatabase
static SQLiteDatabase openOrCreateDatabase(File file, Array<byte> password, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler)
Equivalent to openDatabase(file.getAbsolutePath(), password, factory, CREATE_IF_NECESSARY, errorHandler, null).
-
openOrCreateDatabase
static SQLiteDatabase openOrCreateDatabase(String path, String password, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler)
Equivalent to openDatabase(path, password, factory, CREATE_IF_NECESSARY, errorHandler, null).
-
openOrCreateDatabase
static SQLiteDatabase openOrCreateDatabase(String path, Array<byte> password, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler)
Equivalent to openDatabase(path, password, factory, CREATE_IF_NECESSARY, errorHandler, null).
-
openOrCreateDatabase
static SQLiteDatabase openOrCreateDatabase(File file, String password, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler, SQLiteDatabaseHook databaseHook)
Equivalent to openDatabase(file.getAbsolutePath(), password, factory, CREATE_IF_NECESSARY, errorHandler, databaseHook).
-
openOrCreateDatabase
static SQLiteDatabase openOrCreateDatabase(File file, Array<byte> password, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler, SQLiteDatabaseHook databaseHook)
Equivalent to openDatabase(file.getAbsolutePath(), password, factory, CREATE_IF_NECESSARY, errorHandler, databaseHook).
-
openOrCreateDatabase
static SQLiteDatabase openOrCreateDatabase(String path, String password, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler, SQLiteDatabaseHook databaseHook)
Equivalent to openDatabase(path, password, factory, CREATE_IF_NECESSARY, errorHandler, databaseHook).
-
openOrCreateDatabase
static SQLiteDatabase openOrCreateDatabase(String path, Array<byte> password, SQLiteDatabase.CursorFactory factory, DatabaseErrorHandler errorHandler, SQLiteDatabaseHook databaseHook)
Equivalent to openDatabase(path, password, factory, CREATE_IF_NECESSARY, errorHandler, databaseHook).
-
deleteDatabase
static boolean deleteDatabase(File file)
Deletes a database including its journal file and other auxiliary filesthat may have been created by the database engine.
- Parameters:
file
- The database file path.
-
reopenReadWrite
void reopenReadWrite()
Reopens the database in read-write mode.If the database is already read-write, does nothing.
-
create
static SQLiteDatabase create(SQLiteDatabase.CursorFactory factory)
Create a memory backed SQLite database. Its contents will be destroyedwhen the database is closed.
Sets the locale of the database to the the system's current locale.Call setLocale if you would like something else.
- Parameters:
factory
- an optional factory class that is called to instantiate acursor when query is called
-
addCustomFunction
void addCustomFunction(String name, int numArgs, SQLiteDatabase.CustomFunction function)
Registers a CustomFunction callback as a function that can be called fromSQLite database triggers.
- Parameters:
name
- the name of the sqlite3 functionnumArgs
- the number of arguments for the functionfunction
- callback to call when the function is executed
-
getVersion
int getVersion()
Gets the database version.
-
setVersion
void setVersion(int version)
Sets the database version.
- Parameters:
version
- the new database version
-
getMaximumSize
long getMaximumSize()
Returns the maximum size the database may grow to.
-
setMaximumSize
long setMaximumSize(long numBytes)
Sets the maximum size the database will grow to. The maximum size cannotbe set below the current size.
- Parameters:
numBytes
- the maximum database size, in bytes
-
getPageSize
long getPageSize()
Returns the current database page size, in bytes.
-
setPageSize
void setPageSize(long numBytes)
Sets the database page size. The page size must be a power of two. Thismethod does not work if any data has been written to the database file,and must be called right after the database has been created.
- Parameters:
numBytes
- the database page size, in bytes
-
query
Cursor query(SupportSQLiteQuery query)
-
query
Cursor query(SupportSQLiteQuery query, CancellationSignal cancellationSignal)
-
insert
long insert(String table, int conflictAlgorithm, ContentValues values)
-
update
int update(String table, int conflictAlgorithm, ContentValues values, String whereClause, Array<Object> whereArgs)
-
markTableSyncable
@Deprecated() void markTableSyncable(String table, String deletedTable)
Mark this table as syncable. When an update occurs in this table the_sync_dirty field will be set to ensure proper syncing operation.
- Parameters:
table
- the table to mark as syncabledeletedTable
- The deleted table that corresponds to thesyncable table
-
markTableSyncable
@Deprecated() void markTableSyncable(String table, String foreignKey, String updateTable)
Mark this table as syncable, with the _sync_dirty residing in anothertable. When an update occurs in this table the _sync_dirty field of therow in updateTable with the _id in foreignKey will be set toensure proper syncing operation.
- Parameters:
table
- an update on this table will trigger a sync time removalforeignKey
- this is the column in table whose value is an _id inupdateTableupdateTable
- this is the table that will have its _sync_dirty
-
findEditTable
static String findEditTable(String tables)
Finds the name of the first table, which is editable.
- Parameters:
tables
- a list of tables
-
compileStatement
SQLiteStatement compileStatement(String sql)
Compiles an SQL statement into a reusable pre-compiled statement object.The parameters are identical to execSQL. You may put ?s in thestatement and fill in those values with bindString and bindLong each time you want to run thestatement. Statements may not return result sets larger than 1x1.
No two threads should be using the same SQLiteStatement at the same time.
- Parameters:
sql
- The raw SQL statement, may contain ?
-
query
Cursor query(boolean distinct, String table, Array<String> columns, String selection, Array<String> selectionArgs, String groupBy, String having, String orderBy, String limit)
Query the given URL, returning a Cursor over the result set.
- Parameters:
distinct
- true if you want each row to be unique, false otherwise.table
- The table name to compile the query against.columns
- A list of which columns to return.selection
- A filter declaring which rows to return, formatted as anSQL WHERE clause (excluding the WHERE itself).selectionArgs
- You may include ?s in selection, which will bereplaced by the values from selectionArgs, in order that theyappear in the selection.groupBy
- A filter declaring how to group rows, formatted as an SQLGROUP BY clause (excluding the GROUP BY itself).having
- A filter declare which row groups to include in the cursor,if row grouping is being used, formatted as an SQL HAVINGclause (excluding the HAVING itself).orderBy
- How to order the rows, formatted as an SQL ORDER BY clause(excluding the ORDER BY itself).limit
- Limits the number of rows returned by the query,formatted as LIMIT clause.
-
query
Cursor query(boolean distinct, String table, Array<String> columns, String selection, Array<String> selectionArgs, String groupBy, String having, String orderBy, String limit, CancellationSignal cancellationSignal)
Query the given URL, returning a Cursor over the result set.
- Parameters:
distinct
- true if you want each row to be unique, false otherwise.table
- The table name to compile the query against.columns
- A list of which columns to return.selection
- A filter declaring which rows to return, formatted as anSQL WHERE clause (excluding the WHERE itself).selectionArgs
- You may include ?s in selection, which will bereplaced by the values from selectionArgs, in order that theyappear in the selection.groupBy
- A filter declaring how to group rows, formatted as an SQLGROUP BY clause (excluding the GROUP BY itself).having
- A filter declare which row groups to include in the cursor,if row grouping is being used, formatted as an SQL HAVINGclause (excluding the HAVING itself).orderBy
- How to order the rows, formatted as an SQL ORDER BY clause(excluding the ORDER BY itself).limit
- Limits the number of rows returned by the query,formatted as LIMIT clause.cancellationSignal
- A signal to cancel the operation in progress, or null if none.
-
queryWithFactory
Cursor queryWithFactory(SQLiteDatabase.CursorFactory cursorFactory, boolean distinct, String table, Array<String> columns, String selection, Array<String> selectionArgs, String groupBy, String having, String orderBy, String limit)
Query the given URL, returning a Cursor over the result set.
- Parameters:
cursorFactory
- the cursor factory to use, or null for the default factorydistinct
- true if you want each row to be unique, false otherwise.table
- The table name to compile the query against.columns
- A list of which columns to return.selection
- A filter declaring which rows to return, formatted as anSQL WHERE clause (excluding the WHERE itself).selectionArgs
- You may include ?s in selection, which will bereplaced by the values from selectionArgs, in order that theyappear in the selection.groupBy
- A filter declaring how to group rows, formatted as an SQLGROUP BY clause (excluding the GROUP BY itself).having
- A filter declare which row groups to include in the cursor,if row grouping is being used, formatted as an SQL HAVINGclause (excluding the HAVING itself).orderBy
- How to order the rows, formatted as an SQL ORDER BY clause(excluding the ORDER BY itself).limit
- Limits the number of rows returned by the query,formatted as LIMIT clause.
-
queryWithFactory
Cursor queryWithFactory(SQLiteDatabase.CursorFactory cursorFactory, boolean distinct, String table, Array<String> columns, String selection, Array<String> selectionArgs, String groupBy, String having, String orderBy, String limit, CancellationSignal cancellationSignal)
Query the given URL, returning a Cursor over the result set.
- Parameters:
cursorFactory
- the cursor factory to use, or null for the default factorydistinct
- true if you want each row to be unique, false otherwise.table
- The table name to compile the query against.columns
- A list of which columns to return.selection
- A filter declaring which rows to return, formatted as anSQL WHERE clause (excluding the WHERE itself).selectionArgs
- You may include ?s in selection, which will bereplaced by the values from selectionArgs, in order that theyappear in the selection.groupBy
- A filter declaring how to group rows, formatted as an SQLGROUP BY clause (excluding the GROUP BY itself).having
- A filter declare which row groups to include in the cursor,if row grouping is being used, formatted as an SQL HAVINGclause (excluding the HAVING itself).orderBy
- How to order the rows, formatted as an SQL ORDER BY clause(excluding the ORDER BY itself).limit
- Limits the number of rows returned by the query,formatted as LIMIT clause.cancellationSignal
- A signal to cancel the operation in progress, or null if none.
-
query
Cursor query(String table, Array<String> columns, String selection, Array<String> selectionArgs, String groupBy, String having, String orderBy)
Query the given table, returning a Cursor over the result set.
- Parameters:
table
- The table name to compile the query against.columns
- A list of which columns to return.selection
- A filter declaring which rows to return, formatted as anSQL WHERE clause (excluding the WHERE itself).selectionArgs
- You may include ?s in selection, which will bereplaced by the values from selectionArgs, in order that theyappear in the selection.groupBy
- A filter declaring how to group rows, formatted as an SQLGROUP BY clause (excluding the GROUP BY itself).having
- A filter declare which row groups to include in the cursor,if row grouping is being used, formatted as an SQL HAVINGclause (excluding the HAVING itself).orderBy
- How to order the rows, formatted as an SQL ORDER BY clause(excluding the ORDER BY itself).
-
query
Cursor query(String table, Array<String> columns, String selection, Array<String> selectionArgs, String groupBy, String having, String orderBy, String limit)
Query the given table, returning a Cursor over the result set.
- Parameters:
table
- The table name to compile the query against.columns
- A list of which columns to return.selection
- A filter declaring which rows to return, formatted as anSQL WHERE clause (excluding the WHERE itself).selectionArgs
- You may include ?s in selection, which will bereplaced by the values from selectionArgs, in order that theyappear in the selection.groupBy
- A filter declaring how to group rows, formatted as an SQLGROUP BY clause (excluding the GROUP BY itself).having
- A filter declare which row groups to include in the cursor,if row grouping is being used, formatted as an SQL HAVINGclause (excluding the HAVING itself).orderBy
- How to order the rows, formatted as an SQL ORDER BY clause(excluding the ORDER BY itself).limit
- Limits the number of rows returned by the query,formatted as LIMIT clause.
-
rawQuery
Cursor rawQuery(String sql, Array<String> selectionArgs)
Runs the provided SQL and returns a Cursor over the result set.
- Parameters:
sql
- the SQL query.selectionArgs
- You may include ?s in where clause in the query,which will be replaced by the values from selectionArgs.
-
rawQuery
Cursor rawQuery(String sql, Array<Object> bindingArgs)
Runs the provided SQL and returns a Cursor over the result set.
- Parameters:
sql
- the SQL query.bindingArgs
- You may include ?s in where clause in the query,which will be replaced by the values from bindingArgs.
-
rawQuery
Cursor rawQuery(String sql, Array<String> selectionArgs, CancellationSignal cancellationSignal)
Runs the provided SQL and returns a Cursor over the result set.
- Parameters:
sql
- the SQL query.selectionArgs
- You may include ?s in where clause in the query,which will be replaced by the values from selectionArgs.cancellationSignal
- A signal to cancel the operation in progress, or null if none.
-
rawQueryWithFactory
Cursor rawQueryWithFactory(SQLiteDatabase.CursorFactory cursorFactory, String sql, Array<String> selectionArgs, String editTable)
Runs the provided SQL and returns a cursor over the result set.
- Parameters:
cursorFactory
- the cursor factory to use, or null for the default factorysql
- the SQL query.selectionArgs
- You may include ?s in where clause in the query,which will be replaced by the values from selectionArgs.editTable
- the name of the first table, which is editable
-
rawQueryWithFactory
Cursor rawQueryWithFactory(SQLiteDatabase.CursorFactory cursorFactory, String sql, Array<String> selectionArgs, String editTable, CancellationSignal cancellationSignal)
Runs the provided SQL and returns a cursor over the result set.
- Parameters:
cursorFactory
- the cursor factory to use, or null for the default factorysql
- the SQL query.selectionArgs
- You may include ?s in where clause in the query,which will be replaced by the values from selectionArgs.editTable
- the name of the first table, which is editablecancellationSignal
- A signal to cancel the operation in progress, or null if none.
-
insert
long insert(String table, String nullColumnHack, ContentValues values)
Convenience method for inserting a row into the database.
- Parameters:
table
- the table to insert the row intonullColumnHack
- optional; may benull
.SQL doesn't allow inserting a completely empty row withoutnaming at least one column name.values
- this map contains the initial column values for therow.
-
insertOrThrow
long insertOrThrow(String table, String nullColumnHack, ContentValues values)
Convenience method for inserting a row into the database.
- Parameters:
table
- the table to insert the row intonullColumnHack
- optional; may benull
.SQL doesn't allow inserting a completely empty row withoutnaming at least one column name.values
- this map contains the initial column values for therow.
-
replace
long replace(String table, String nullColumnHack, ContentValues initialValues)
Convenience method for replacing a row in the database.Inserts a new row if a row does not already exist.
- Parameters:
table
- the table in which to replace the rownullColumnHack
- optional; may benull
.SQL doesn't allow inserting a completely empty row withoutnaming at least one column name.initialValues
- this map contains the initial column values forthe row.
-
replaceOrThrow
long replaceOrThrow(String table, String nullColumnHack, ContentValues initialValues)
Convenience method for replacing a row in the database.Inserts a new row if a row does not already exist.
- Parameters:
table
- the table in which to replace the rownullColumnHack
- optional; may benull
.SQL doesn't allow inserting a completely empty row withoutnaming at least one column name.initialValues
- this map contains the initial column values forthe row.
-
insertWithOnConflict
long insertWithOnConflict(String table, String nullColumnHack, ContentValues initialValues, int conflictAlgorithm)
General method for inserting a row into the database.
- Parameters:
table
- the table to insert the row intonullColumnHack
- optional; may benull
.SQL doesn't allow inserting a completely empty row withoutnaming at least one column name.initialValues
- this map contains the initial column values for therow.conflictAlgorithm
- for insert conflict resolver
-
delete
int delete(String table, String whereClause, Array<String> whereArgs)
Convenience method for deleting rows in the database.
- Parameters:
table
- the table to delete fromwhereClause
- the optional WHERE clause to apply when deleting.Passing null will delete all rows.whereArgs
- You may include ?s in the where clause, whichwill be replaced by the values from whereArgs.
-
update
int update(String table, ContentValues values, String whereClause, Array<String> whereArgs)
Convenience method for updating rows in the database.
- Parameters:
table
- the table to update invalues
- a map from column names to new column values.whereClause
- the optional WHERE clause to apply when updating.Passing null will update all rows.whereArgs
- You may include ?s in the where clause, whichwill be replaced by the values from whereArgs.
-
updateWithOnConflict
int updateWithOnConflict(String table, ContentValues values, String whereClause, Array<String> whereArgs, int conflictAlgorithm)
Convenience method for updating rows in the database.
- Parameters:
table
- the table to update invalues
- a map from column names to new column values.whereClause
- the optional WHERE clause to apply when updating.Passing null will update all rows.whereArgs
- You may include ?s in the where clause, whichwill be replaced by the values from whereArgs.conflictAlgorithm
- for update conflict resolver
-
execSQL
void execSQL(String sql)
Execute a single SQL statement that is NOT a SELECTor any other SQL statement that returns data.
It has no means to return any data (such as the number of affected rows).Instead, you're encouraged to use insert, update, et al, when possible.
When using enableWriteAheadLogging, journal_mode isautomatically managed by this class. So, do not set journal_modeusing "PRAGMA journal_mode'" statement if your app is using
- Parameters:
sql
- the SQL statement to be executed.
-
execSQL
void execSQL(String sql, Array<Object> bindArgs)
Execute a single SQL statement that is NOT a SELECT/INSERT/UPDATE/DELETE.
For INSERT statements, use any of the following instead.
For UPDATE statements, use any of the following instead.
For DELETE statements, use any of the following instead.
For example, the following are good candidates for using this method:
- ALTER TABLE
- CREATE or DROP table / trigger / view / index / virtual table
- REINDEX
- RELEASE
- SAVEPOINT
- PRAGMA that returns no data
When using enableWriteAheadLogging, journal_mode isautomatically managed by this class. So, do not set journal_modeusing "PRAGMA journal_mode'" statement if your app is using
- Parameters:
sql
- the SQL statement to be executed.bindArgs
- only byte[], String, Long and Double are supported in bindArgs.
-
rawExecSQL
void rawExecSQL(String sql, Array<Object> bindArgs)
Executes a statement that returns a count of the number of rowsthat were changed. No transaction state checking is performed.
- Parameters:
sql
- The SQL statement to execute.bindArgs
- The arguments to bind.
-
validateSql
void validateSql(String sql, CancellationSignal cancellationSignal)
Verifies that a SQL SELECT statement is valid by compiling it.If the SQL statement is not valid, this method will throw a SQLiteException.
- Parameters:
sql
- SQL to be validatedcancellationSignal
- A signal to cancel the operation in progress, or null if none.
-
isReadOnly
boolean isReadOnly()
Returns true if the database is opened as read only.
-
isInMemoryDatabase
boolean isInMemoryDatabase()
Returns true if the database is in-memory db.
-
isOpen
boolean isOpen()
Returns true if the database is currently open.
-
needUpgrade
boolean needUpgrade(int newVersion)
Returns true if the new version code is greater than the current database version.
- Parameters:
newVersion
- The new version code.
-
setLocale
void setLocale(Locale locale)
Sets the locale for this database. Does nothing if this database hasthe NO_LOCALIZED_COLLATORS flag set or was opened read only.
- Parameters:
locale
- The new locale.
-
setMaxSqlCacheSize
void setMaxSqlCacheSize(int cacheSize)
Sets the maximum size of the prepared-statement cache for this database.(size of the cache = number of compiled-sql-statements stored in the cache).
Maximum cache size can ONLY be increased from its current size (default = 10).If this method is called with smaller size than the current maximum value,then IllegalStateException is thrown.
This method is thread-safe.
- Parameters:
cacheSize
- the size of the cache.
-
setForeignKeyConstraintsEnabled
void setForeignKeyConstraintsEnabled(boolean enable)
Sets whether foreign key constraints are enabled for the database.
By default, foreign key constraints are not enforced by the database.This method allows an application to enable foreign key constraints.It must be called each time the database is opened to ensure that foreignkey constraints are enabled for the session.
A good time to call this method is right after calling openOrCreateDatabase or in the onConfigure callback.
When foreign key constraints are disabled, the database does not check whetherchanges to the database will violate foreign key constraints. Likewise, whenforeign key constraints are disabled, the database will not execute cascadedelete or update triggers. As a result, it is possible for the databasestate to become inconsistent. To perform a database integrity check,call isDatabaseIntegrityOk.
This method must not be called while a transaction is in progress.
See also SQLite Foreign Key Constraintsfor more details about foreign key constraint support.
- Parameters:
enable
- True to enable foreign key constraints, false to disable them.
-
enableWriteAheadLogging
boolean enableWriteAheadLogging()
This method enables parallel execution of queries from multiple threads on thesame database. It does this by opening multiple connections to the databaseand using a different database connection for each query. The databasejournal mode is also changed to enable writes to proceed concurrently with reads.
When write-ahead logging is not enabled (the default), it is not possible forreads and writes to occur on the database at the same time. Before modifying thedatabase, the writer implicitly acquires an exclusive lock on the database whichprevents readers from accessing the database until the write is completed.
In contrast, when write-ahead logging is enabled (by calling this method), writeoperations occur in a separate log file which allows reads to proceed concurrently.While a write is in progress, readers on other threads will perceive the stateof the database as it was before the write began. When the write completes, readerson other threads will then perceive the new state of the database.
It is a good idea to enable write-ahead logging whenever a database will beconcurrently accessed and modified by multiple threads at the same time.However, write-ahead logging uses significantly more memory than ordinaryjournaling because there are multiple connections to the same database.So if a database will only be used by a single thread, or if optimizingconcurrency is not very important, then write-ahead logging should be disabled.
After calling this method, execution of queries in parallel is enabled as long asthe database remains open. To disable execution of queries in parallel, eithercall disableWriteAheadLogging or close the database and reopen it.
The maximum number of connections used to execute queries in parallel isdependent upon the device memory and possibly other properties.
If a query is part of a transaction, then it is executed on the same database handle thetransaction was begun.
Writers should use beginTransactionNonExclusive or beginTransactionWithListenerNonExclusive to start a transaction. Non-exclusive mode allows database file to be in readableby other threads executing queries.
If the database has any attached databases, then execution of queries in parallel is NOTpossible. Likewise, write-ahead logging is not supported for read-only databasesor memory databases. In such cases, enableWriteAheadLogging returns false.
The best way to enable write-ahead logging is to pass the ENABLE_WRITE_AHEAD_LOGGING flag to openDatabase. This ismore efficient than calling enableWriteAheadLogging.
SQLiteDatabase db = SQLiteDatabase.openDatabase("db_filename", cursorFactory, SQLiteDatabase.CREATE_IF_NECESSARY | SQLiteDatabase.ENABLE_WRITE_AHEAD_LOGGING, myDatabaseErrorHandler); db.enableWriteAheadLogging();
Another way to enable write-ahead logging is to call enableWriteAheadLogging after opening the database.
SQLiteDatabase db = SQLiteDatabase.openDatabase("db_filename", cursorFactory, SQLiteDatabase.CREATE_IF_NECESSARY, myDatabaseErrorHandler); db.enableWriteAheadLogging();
See also SQLite Write-Ahead Logging formore details about how write-ahead logging works.
-
disableWriteAheadLogging
void disableWriteAheadLogging()
This method disables the features enabled by enableWriteAheadLogging.
-
isWriteAheadLoggingEnabled
boolean isWriteAheadLoggingEnabled()
Returns true if write-ahead logging has been enabled for this database.
-
getAttachedDbs
List<Pair<String, String>> getAttachedDbs()
Returns list of full pathnames of all attached databases including the main databaseby executing 'pragma database_list' on the database.
-
isDatabaseIntegrityOk
boolean isDatabaseIntegrityOk()
Runs 'pragma integrity_check' on the given database (and all the attached databases)and returns true if the given database (and all its attached databases) pass integrity_check,false otherwise.
If the result is false, then this method logs the errors reported by the integrity_checkcommand execution.
Note that 'pragma integrity_check' on a database can take a long time.
-
changePassword
void changePassword(String newPassword)
-
changePassword
void changePassword(Array<byte> newPassword)
-
hasCodec
static boolean hasCodec()
-
enableLocalizedCollators
void enableLocalizedCollators()
-
-
-
-