类型
SQLite 类型
SQLDelight 的列定义与常规 SQLite 列定义相同,但支持一个额外列约束,用于在生成的接口中指定该列的 Kotlin 类型。
sql
CREATE TABLE some_types (
some_long INTEGER, -- 在数据库中存储为 INTEGER,检索为 Long
some_double REAL, -- 在数据库中存储为 REAL,检索为 Double
some_string TEXT, -- 在数据库中存储为 TEXT,检索为 String
some_blob BLOB -- 在数据库中存储为 BLOB,检索为 ByteArray
);基元
一个为您的便利而对基元进行适配的兄弟模块。
kotlin
dependencies {
implementation("app.cash.sqldelight:primitive-adapters:2.1.0")
}groovy
dependencies {
implementation "app.cash.sqldelight:primitive-adapters:2.1.0"
}存在以下适配器:
FloatColumnAdapter— 为隐式存储为kotlin.Double的 SQL 类型检索kotlin.FloatIntColumnAdapter— 为隐式存储为kotlin.Long的 SQL 类型检索kotlin.IntShortColumnAdapter— 为隐式存储为kotlin.Long的 SQL 类型检索kotlin.Short
自定义列类型
如果您希望以自定义类型检索列,可以指定一个 Kotlin 类型:
sql
import kotlin.String;
import kotlin.collections.List;
CREATE TABLE hockeyPlayer (
cup_wins TEXT AS List<String> NOT NULL
);然而,创建 Database 需要您提供一个 ColumnAdapter,它知道如何在数据库类型与您的自定义类型之间进行映射:
kotlin
val listOfStringsAdapter = object : ColumnAdapter<List<String>, String> {
override fun decode(databaseValue: String) =
if (databaseValue.isEmpty()) {
listOf()
} else {
databaseValue.split(",")
}
override fun encode(value: List<String>) = value.joinToString(separator = ",")
}
val queryWrapper: Database = Database(
driver = driver,
hockeyPlayerAdapter = hockeyPlayer.Adapter(
cup_winsAdapter = listOfStringsAdapter
)
)枚举
为了方便起见,SQLDelight 运行时包含了一个 ColumnAdapter,用于将枚举作为字符串数据存储。
sql
import com.example.hockey.HockeyPlayer;
CREATE TABLE hockeyPlayer (
position TEXT AS HockeyPlayer.Position
)kotlin
val queryWrapper: Database = Database(
driver = driver,
hockeyPlayerAdapter = HockeyPlayer.Adapter(
positionAdapter = EnumColumnAdapter()
)
)值类型
如果需要,SQLDelight 可以为列生成一个值类型,用于包装底层数据库类型:
sql
CREATE TABLE hockeyPlayer (
id INT AS VALUE
);