SQLiteRawStatement
class SQLiteRawStatement : Closeable
kotlin.Any | |
↳ | android.database.sqlite.SQLiteRawStatement |
A represents a SQLite prepared statement. The methods correspond very closely to SQLite APIs that operate on a sqlite_stmt object. In general, each API in this class corresponds to a single SQLite API.
A SQLiteRawStatement
must be created through a database, and there must be a transaction open at the time. Statements are implicitly closed when the outermost transaction ends, or if the current transaction is marked successful. Statements may be explicitly closed at any time with #close. The #close operation is idempotent and may be called multiple times without harm.
Multiple SQLiteRawStatement
s may be open simultaneously. They are independent of each other. Closing one statement does not affect any other statement nor does it have any effect on the enclosing transaction.
Once a SQLiteRawStatement
has been closed, no further database operations are permitted on that statement. An IllegalStateException
will be thrown if a database operation is attempted on a closed statement.
All operations on a SQLiteRawStatement
must be invoked from the thread that created it. A IllegalStateException
will be thrown if cross-thread use is detected.
A common pattern for statements is try-with-resources.
<code> // Begin a transaction. database.beginTransaction(); try (SQLiteRawStatement statement = database.createRawStatement("SELECT * FROM ...")) { while (statement.step()) { // Fetch columns from the result rows. } database.setTransactionSuccessful(); } finally { database.endTransaction(); } </code>
SQLiteRawStatement
is unrelated to SQLiteStatement
.
Summary
Constants | |
---|---|
static Int |
The constant returned by |
static Int |
The constant returned by |
static Int |
The constant returned by |
static Int |
The constant returned by |
static Int |
The constant returned by |
Public methods | |
---|---|
Unit |
Bind a blob to a parameter. |
Unit |
Bind a blob to a parameter. |
Unit |
bindDouble(parameterIndex: Int, value: Double) Bind a double to a parameter. |
Unit |
Bind an int to a parameter. |
Unit |
Bind a long to the parameter. |
Unit |
Bind a null to the parameter. |
Unit |
Bind a string to the parameter. |
Unit |
Clear all parameter bindings. |
Unit |
close() Close the object and release any native resources. |
ByteArray? |
getColumnBlob(columnIndex: Int) Return the column value of the result row as a blob. |
Double |
getColumnDouble(columnIndex: Int) Return the column value as a double. |
Int |
getColumnInt(columnIndex: Int) Return the column value as a int. |
Int |
getColumnLength(columnIndex: Int) Return the length of the column value in the result row. |
Long |
getColumnLong(columnIndex: Int) Return the column value as a long. |
String |
getColumnName(columnIndex: Int) Return the name of the column in the result row. |
String |
getColumnText(columnIndex: Int) Return the column value as a text. |
Int |
getColumnType(columnIndex: Int) Return the type of the column in the result row. |
Int |
Return the number of parameters in the statement. |
Int |
getParameterIndex(name: String) Return the index of the parameter with specified name. |
String? |
getParameterName(parameterIndex: Int) Return the name of the parameter at the specified index. |
Int |
Return the number of columns in the result set for the statement. |
Boolean |
isOpen() Return true if the statement is still open and false otherwise. |
Int |
Copy the column value of the result row, interpreted as a blob, into the buffer. |
Unit |
reset() Reset the statement. |
Boolean |
step() Step to the next result row. |
String |
toString() |
Constants
SQLITE_DATA_TYPE_BLOB
static val SQLITE_DATA_TYPE_BLOB: Int
The constant returned by getColumnType
when the column value is SQLITE_BLOB.
Value: 4
SQLITE_DATA_TYPE_FLOAT
static val SQLITE_DATA_TYPE_FLOAT: Int
The constant returned by getColumnType
when the column value is SQLITE_FLOAT.
Value: 2
SQLITE_DATA_TYPE_INTEGER
static val SQLITE_DATA_TYPE_INTEGER: Int
The constant returned by getColumnType
when the column value is SQLITE_INTEGER.
Value: 1
SQLITE_DATA_TYPE_NULL
static val SQLITE_DATA_TYPE_NULL: Int
The constant returned by getColumnType
when the column value is SQLITE_NULL.
Value: 5
SQLITE_DATA_TYPE_TEXT
static val SQLITE_DATA_TYPE_TEXT: Int
The constant returned by getColumnType
when the column value is SQLITE_TEXT.
Value: 3
Public methods
bindBlob
fun bindBlob(
parameterIndex: Int,
value: ByteArray
): Unit
Bind a blob to a parameter. Parameter indices start at 1. The function throws if the parameter index is out of bounds.
Parameters | |
---|---|
parameterIndex |
Int: The index of the parameter in the query. It is one-based. |
value |
ByteArray: The value to be bound to the parameter. This value cannot be null . |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
android.database.sqlite.SQLiteBindOrColumnIndexOutOfRangeException |
if the parameter is out of range. |
android.database.sqlite.SQLiteException |
if a native error occurs. |
See Also
bindBlob
fun bindBlob(
parameterIndex: Int,
value: ByteArray,
offset: Int,
length: Int
): Unit
Bind a blob to a parameter. Parameter indices start at 1. The function throws if the parameter index is out of bounds. The sub-array value[offset] to value[offset+length-1] is bound.
Parameters | |
---|---|
parameterIndex |
Int: The index of the parameter in the query. It is one-based. |
value |
ByteArray: The value to be bound to the parameter. This value cannot be null . |
offset |
Int: An offset into the value array |
length |
Int: The number of bytes to bind from the value array. |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
java.lang.IllegalArgumentException |
if the sub-array exceeds the bounds of the value array. |
android.database.sqlite.SQLiteBindOrColumnIndexOutOfRangeException |
if the parameter is out of range. |
android.database.sqlite.SQLiteException |
if a native error occurs. |
See Also
bindDouble
fun bindDouble(
parameterIndex: Int,
value: Double
): Unit
Bind a double to a parameter. Parameter indices start at 1. The function throws if the parameter index is out of bounds.
Parameters | |
---|---|
parameterIndex |
Int: The index of the parameter in the query. It is one-based. |
value |
Double: The value to be bound to the parameter. |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
android.database.sqlite.SQLiteBindOrColumnIndexOutOfRangeException |
if the parameter is out of range. |
android.database.sqlite.SQLiteException |
if a native error occurs. |
See Also
bindInt
fun bindInt(
parameterIndex: Int,
value: Int
): Unit
Bind an int to a parameter. Parameter indices start at 1. The function throws if the parameter index is out of bounds.
Parameters | |
---|---|
parameterIndex |
Int: The index of the parameter in the query. It is one-based. |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
android.database.sqlite.SQLiteBindOrColumnIndexOutOfRangeException |
if the parameter is out of range. |
android.database.sqlite.SQLiteException |
if a native error occurs. |
See Also
bindLong
fun bindLong(
parameterIndex: Int,
value: Long
): Unit
Bind a long to the parameter. Parameter indices start at 1. The function throws if the parameter index is out of bounds.
Parameters | |
---|---|
value |
Long: The value to be bound to the parameter. |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
android.database.sqlite.SQLiteBindOrColumnIndexOutOfRangeException |
if the parameter is out of range. |
android.database.sqlite.SQLiteException |
if a native error occurs. |
See Also
bindNull
fun bindNull(parameterIndex: Int): Unit
Bind a null to the parameter. Parameter indices start at 1. The function throws if the parameter index is out of bounds.
Parameters | |
---|---|
parameterIndex |
Int: The index of the parameter in the query. It is one-based. |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
android.database.sqlite.SQLiteBindOrColumnIndexOutOfRangeException |
if the parameter is out of range. |
android.database.sqlite.SQLiteException |
if a native error occurs. |
See Also
bindText
fun bindText(
parameterIndex: Int,
value: String
): Unit
Bind a string to the parameter. Parameter indices start at 1. The function throws if the parameter index is out of bounds. The string may not be null.
Parameters | |
---|---|
parameterIndex |
Int: The index of the parameter in the query. It is one-based. |
value |
String: The value to be bound to the parameter. This value cannot be null . |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
android.database.sqlite.SQLiteBindOrColumnIndexOutOfRangeException |
if the parameter is out of range. |
android.database.sqlite.SQLiteException |
if a native error occurs. |
See Also
clearBindings
fun clearBindings(): Unit
Clear all parameter bindings.
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
android.database.sqlite.SQLiteException |
if a native error occurs. |
See Also
close
fun close(): Unit
Close the object and release any native resources. It is not an error to call this on an already-closed object.
Exceptions | |
---|---|
java.lang.Exception |
if this resource cannot be closed |
java.io.IOException |
if an I/O error occurs |
getColumnBlob
fun getColumnBlob(columnIndex: Int): ByteArray?
Return the column value of the result row as a blob. Column indices start at 0. This throws an exception if column is not in the result. This returns null if the column value is null. The column value will be converted if it is not of type SQLITE_DATA_TYPE_BLOB
; see the sqlite documentation for details.
Parameters | |
---|---|
columnIndex |
Int: The index of a column in the result row. It is zero-based. |
Return | |
---|---|
ByteArray? |
The value of the column as a blob, or null if the column is NULL. |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
android.database.sqlite.SQLiteBindOrColumnIndexOutOfRangeException |
if the column is out of range. |
android.database.sqlite.SQLiteMisuseException |
if the row has no data. See #getColumnType(). |
android.database.sqlite.SQLiteException |
if a native error occurs. |
See Also
getColumnDouble
fun getColumnDouble(columnIndex: Int): Double
Return the column value as a double. Column indices start at 0. This throws an exception if column is not in the result. The column value will be converted if it is not of type SQLITE_DATA_TYPE_FLOAT
; see the sqlite documentation for details.
Parameters | |
---|---|
columnIndex |
Int: The index of a column in the result row. It is zero-based. |
Return | |
---|---|
Double |
The value of a column as a double. |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
android.database.sqlite.SQLiteBindOrColumnIndexOutOfRangeException |
if the column is out of range. |
android.database.sqlite.SQLiteMisuseException |
if the row has no data. See #getColumnType(). |
android.database.sqlite.SQLiteException |
if a native error occurs. |
See Also
getColumnInt
fun getColumnInt(columnIndex: Int): Int
Return the column value as a int. Column indices start at 0. This throws an exception if column is not in the result. The column value will be converted if it is not of type SQLITE_DATA_TYPE_INTEGER
; see the sqlite documentation for details.
Parameters | |
---|---|
columnIndex |
Int: The index of a column in the result row. It is zero-based. |
Return | |
---|---|
Int |
The value of the column as an int. |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
android.database.sqlite.SQLiteBindOrColumnIndexOutOfRangeException |
if the column is out of range. |
android.database.sqlite.SQLiteMisuseException |
if the row has no data. See #getColumnType(). |
android.database.sqlite.SQLiteException |
if a native error occurs. |
See Also
getColumnLength
fun getColumnLength(columnIndex: Int): Int
Return the length of the column value in the result row. Column indices start at 0. This returns 0 for a null and number of bytes for text or blob. Numeric values are converted to a string and the length of the string is returned. See the sqlite documentation for details. Note that this cannot be used to distinguish a null value from an empty text or blob. Note that this returns the number of bytes in the text value, not the number of characters.
Parameters | |
---|---|
columnIndex |
Int: The index of a column in the result row. It is zero-based. |
Return | |
---|---|
Int |
The length, in bytes, of the value in the column. |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
android.database.sqlite.SQLiteBindOrColumnIndexOutOfRangeException |
if the column is out of range. |
android.database.sqlite.SQLiteMisuseException |
if the row has no data. See #getColumnType(). |
android.database.sqlite.SQLiteException |
if a native error occurs. |
See Also
getColumnLong
fun getColumnLong(columnIndex: Int): Long
Return the column value as a long. Column indices start at 0. This throws an exception if column is not in the result. The column value will be converted if it is not of type SQLITE_DATA_TYPE_INTEGER
; see the sqlite documentation for details.
Parameters | |
---|---|
columnIndex |
Int: The index of a column in the result row. It is zero-based. |
Return | |
---|---|
Long |
The value of the column as an long. |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
android.database.sqlite.SQLiteBindOrColumnIndexOutOfRangeException |
if the column is out of range. |
android.database.sqlite.SQLiteMisuseException |
if the row has no data. See #getColumnType(). |
android.database.sqlite.SQLiteException |
if a native error occurs. |
See Also
getColumnName
fun getColumnName(columnIndex: Int): String
Return the name of the column in the result row. Column indices start at 0. This throws an exception if column is not in the result.
Parameters | |
---|---|
columnIndex |
Int: The index of a column in the result row. It is zero-based. |
Return | |
---|---|
String |
The name of the column in the result row. This value cannot be null . |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
android.database.sqlite.SQLiteBindOrColumnIndexOutOfRangeException |
if the column is out of range. |
android.database.sqlite.SQLiteMisuseException |
if the row has no data. See #getColumnType(). |
android.database.sqlite.SQLiteOutOfMemoryException |
if the database cannot allocate memory for the name. |
See Also
getColumnText
fun getColumnText(columnIndex: Int): String
Return the column value as a text. Column indices start at 0. This throws an exception if column is not in the result. The column value will be converted if it is not of type SQLITE_DATA_TYPE_TEXT
; see the sqlite documentation for details.
Parameters | |
---|---|
columnIndex |
Int: The index of a column in the result row. It is zero-based. |
Return | |
---|---|
String |
The value of the column as a string. This value cannot be null . |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
android.database.sqlite.SQLiteBindOrColumnIndexOutOfRangeException |
if the column is out of range. |
android.database.sqlite.SQLiteMisuseException |
if the row has no data. See #getColumnType(). |
android.database.sqlite.SQLiteException |
if a native error occurs. |
See Also
getColumnType
fun getColumnType(columnIndex: Int): Int
Return the type of the column in the result row. Column indices start at 0.
Parameters | |
---|---|
columnIndex |
Int: The index of a column in the result row. It is zero-based. |
Return | |
---|---|
Int |
The type of the value in the column of the result row. Value is android.database.sqlite.SQLiteRawStatement#SQLITE_DATA_TYPE_INTEGER , android.database.sqlite.SQLiteRawStatement#SQLITE_DATA_TYPE_FLOAT , android.database.sqlite.SQLiteRawStatement#SQLITE_DATA_TYPE_TEXT , android.database.sqlite.SQLiteRawStatement#SQLITE_DATA_TYPE_BLOB , or android.database.sqlite.SQLiteRawStatement#SQLITE_DATA_TYPE_NULL |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
android.database.sqlite.SQLiteBindOrColumnIndexOutOfRangeException |
if the column is out of range. |
android.database.sqlite.SQLiteMisuseException |
if the row has no data. |
android.database.sqlite.SQLiteException |
if a native error occurs. |
See Also
getParameterCount
fun getParameterCount(): Int
Return the number of parameters in the statement.
Return | |
---|---|
Int |
The number of parameters in the statement. |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
See Also
getParameterIndex
fun getParameterIndex(name: String): Int
Return the index of the parameter with specified name. If the name does not match any parameter, 0 is returned.
Parameters | |
---|---|
name |
String: The name of a parameter. This value cannot be null . |
Return | |
---|---|
Int |
The index of the parameter or 0 if the name does not identify a parameter. |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
See Also
getParameterName
fun getParameterName(parameterIndex: Int): String?
Return the name of the parameter at the specified index. Null is returned if there is no such parameter or if the parameter does not have a name.
Parameters | |
---|---|
parameterIndex |
Int: The index of the parameter. |
Return | |
---|---|
String? |
The name of the parameter. This value may be null . |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
See Also
getResultColumnCount
fun getResultColumnCount(): Int
Return the number of columns in the result set for the statement.
Return | |
---|---|
Int |
The number of columns in the result set. |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
See Also
isOpen
fun isOpen(): Boolean
Return true if the statement is still open and false otherwise.
Return | |
---|---|
Boolean |
True if the statement is open. |
readColumnBlob
fun readColumnBlob(
columnIndex: Int,
buffer: ByteArray,
offset: Int,
length: Int,
srcOffset: Int
): Int
Copy the column value of the result row, interpreted as a blob, into the buffer. Column indices start at 0. This throws an exception if column is not in the result row. Bytes are copied into the buffer starting at the offset. Bytes are copied from the blob starting at srcOffset. Length bytes are copied unless the column value has fewer bytes available. The function returns the number of bytes copied. The column value will be converted if it is not of type SQLITE_DATA_TYPE_BLOB
; see the sqlite documentation for details.
Parameters | |
---|---|
columnIndex |
Int: The index of a column in the result row. It is zero-based. |
buffer |
ByteArray: A pre-allocated array to be filled with the value of the column. This value cannot be null . |
offset |
Int: An offset into the buffer: copying starts here. |
length |
Int: The number of bytes to copy. |
srcOffset |
Int: The offset into the blob from which to start copying. |
Return | |
---|---|
Int |
the number of bytes that were copied. |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
java.lang.IllegalArgumentException |
if the buffer is too small for offset+length. |
android.database.sqlite.SQLiteBindOrColumnIndexOutOfRangeException |
if the column is out of range. |
android.database.sqlite.SQLiteMisuseException |
if the row has no data. See #getColumnType(). |
android.database.sqlite.SQLiteException |
if a native error occurs. |
See Also
reset
fun reset(): Unit
Reset the statement.
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
android.database.sqlite.SQLiteException |
if a native error occurs. |
See Also
step
fun step(): Boolean
Step to the next result row. This returns true if the statement stepped to a new row, and false if the statement is done. The method throws on any other result, including a busy or locked database. If WAL is enabled then the database should never be locked or busy.
Return | |
---|---|
Boolean |
True if a row is available and false otherwise. |
Exceptions | |
---|---|
java.lang.IllegalStateException |
if the statement is closed or this is a foreign thread. |
android.database.sqlite.SQLiteDatabaseLockedException |
if the database is locked or busy. |
android.database.sqlite.SQLiteException |
if a native error occurs. |
See Also
toString
fun toString(): String
Return | |
---|---|
String |
a string representation of the object. |