Skip to content

使用 Web Worker Driver 進行多平台設定

首先在您的專案中套用 gradle 外掛程式。

kotlin
plugins {
  id("app.cash.sqldelight") version "2.1.0"
}
 
repositories {
  google()
  mavenCentral()
}

sqldelight {
  databases {
    register("Database") {
      packageName.set("com.example")
    }
  }
}
groovy
plugins {
  id "app.cash.sqldelight" version "2.1.0"
}

repositories {
  google()
  mavenCentral()
}

sqldelight {
  databases {
    register("Database") { // 這將是產生的資料庫類別名稱。
      packageName = "com.example"
    }
  }
}

SQL 陳述式撰寫在 `src/main/sqldelight` 下的 `.sq` 檔案中。
.sq` 檔案中的第一個陳述式會建立一個資料表,但您也可以建立索引或設定預設內容。

ql title="src/main/sqldelight/com/example/sqldelight/hockey/data/Player.sq"
TE TABLE hockeyPlayer (
ayer_number INTEGER PRIMARY KEY NOT NULL,
ll_name TEXT NOT NULL


TE INDEX hockeyPlayer_full_name ON hockeyPlayer(full_name);

RT INTO hockeyPlayer (player_number, full_name)
ES (15, 'Ryan Getzlaf');

陳述式,SQLDelight 將會產生一個 `Database` 類別及其關聯的 `Schema` 物件,可用於建立您的資料庫並對其執行陳述式。`Database` 類別是由 `generateSqlDelightInterface` Gradle 任務所產生的,當您編輯 `.sq` 檔案時,SQLDelight IDE 外掛程式會自動執行該任務,同時它也會作為一般 Gradle 組建的一部分來執行。

roovy
in {
 視您目標平台的不同,所需的驅動程式也會有所變化:

urceSets.androidMain.dependencies {
implementation "app.cash.sqldelight:android-driver:2.1.0"


 或 sourceSets.iosMain, sourceSets.windowsMain 等。
urceSets.nativeMain.dependencies {
implementation "app.cash.sqldelight:native-driver:2.1.0"


urceSets.jvmMain.dependencies {
implementation "app.cash.sqldelight:sqlite-driver:2.1.0"


urceSets.jsMain.dependencies {
implementation "app.cash.sqldelight:web-worker-driver:2.1.0"
implementation npm("sql.js", "1.6.2")
implementation devNpm("copy-webpack-plugin", "9.1.0")




立驅動程式

的共用程式碼中設定建立驅動程式的方法。這可以使用 `expect`/`actual` 來完成,或者簡單地使用一個通用介面以及該介面在平台特定的實作。

otlin title="src/commonMain/kotlin"
ct suspend fun provideDbDriver(
hema: SqlSchema<QueryResult.AsyncValue<Unit>>
qlDriver

Schema` 介面包含一個泛型 `QueryResult` 型別引數,用於區分在將 `generateAsync` 配置選項設定為 `true` 時產生的架構程式碼。某些驅動程式在建立或遷移架構時依賴同步行為,因此若要使用非同步架構,您可以使用 [`synchronous()`](../../2.x/extensions/async-extensions/app.cash.sqldelight.async.coroutines/#427896482%2FFunctions%2F-1043631958) 擴充方法將其調整為與同步驅動程式搭配使用。

"src/jsMain/kotlin"
actual suspend fun provideDbDriver(
  schema: SqlSchema<QueryResult.AsyncValue<Unit>>
): SqlDriver {
  return WebWorkerDriver(
    Worker(
      js("""new URL("@cashapp/sqldelight-sqljs-worker/sqljs.worker.js", import.meta.url)""")
    )
  ).also { schema.create(it).await() }
}
```
kotlin
actual suspend fun provideDbDriver(
  schema: SqlSchema<QueryResult.AsyncValue<Unit>>
): SqlDriver {
  return JdbcSqliteDriver(JdbcSqliteDriver.IN_MEMORY)
    .also { schema.create(it).await() }
}
kotlin
actual suspend fun provideDbDriver(
  schema: SqlSchema<QueryResult.AsyncValue<Unit>>
): SqlDriver {
  return AndroidSqliteDriver(schema.synchronous(), context, "test.db")
}
kotlin
actual suspend fun provideDbDriver(
  schema: SqlSchema<QueryResult.AsyncValue<Unit>>
): SqlDriver {
  return NativeSqliteDriver(schema.synchronous(), "test.db")
}