我正在使用Android数据库组件室
我已经配置了一切,但当我编译时,Android Studio给我这个警告:
架构导出目录没有提供给注释处理器,因此 我们不能导出模式。你可以提供 房间。schemaLocation注释处理器参数OR集 exportSchema为false。
根据我的理解,这是DB文件将被定位的位置
它如何影响我的应用程序?这里的最佳实践是什么?我是否应该使用默认位置(false值)?
我正在使用Android数据库组件室
我已经配置了一切,但当我编译时,Android Studio给我这个警告:
架构导出目录没有提供给注释处理器,因此 我们不能导出模式。你可以提供 房间。schemaLocation注释处理器参数OR集 exportSchema为false。
根据我的理解,这是DB文件将被定位的位置
它如何影响我的应用程序?这里的最佳实践是什么?我是否应该使用默认位置(false值)?
当前回答
@mikejonesguy答案是完美的,以防万一您计划测试房间迁移(推荐),将模式位置添加到源集。
在你的构建中。Gradle文件你指定一个文件夹来放置这些 生成模式JSON文件。当您更新您的模式时,您将结束 有几个JSON文件,每个版本一个。一定要承诺 每个生成的文件都交给源代码控制。下次你增加的时候 您的版本号再次,房间将能够使用JSON文件 测试。 Florina Muntenescu(来源)
build.gradle
android {
// [...]
defaultConfig {
// [...]
javaCompileOptions {
annotationProcessorOptions {
arguments = ["room.schemaLocation": "$projectDir/schemas".toString()]
}
}
}
// add the schema location to the source sets
// used by Room, to test migrations
sourceSets {
androidTest.assets.srcDirs += files("$projectDir/schemas".toString())
}
// [...]
}
其他回答
可能您没有将您的room类添加到@Database(entities = {your_classes})中的RoomDatabase子类中
如果你像我一样最近移动某些类到不同的包等。你使用android导航。确保将argType更改为与您的新包地址匹配。 来自:
app:argType="com.example.app.old.Item"
to:
app:argType="com.example.app.new.Item"
在构建中。gradle文件,添加到defaultConfig部分(在android部分下)。这将把模式写到项目文件夹的schemas子文件夹中。
javaCompileOptions {
annotationProcessorOptions {
arguments += ["room.schemaLocation": "$projectDir/schemas".toString()]
}
}
是这样的:
// ...
android {
// ... (compileSdkVersion, buildToolsVersion, etc)
defaultConfig {
// ... (applicationId, miSdkVersion, etc)
javaCompileOptions {
annotationProcessorOptions {
arguments += ["room.schemaLocation": "$projectDir/schemas".toString()]
}
}
}
// ... (buildTypes, compileOptions, etc)
}
// ...
@mikejonesguy答案是完美的,以防万一您计划测试房间迁移(推荐),将模式位置添加到源集。
在你的构建中。Gradle文件你指定一个文件夹来放置这些 生成模式JSON文件。当您更新您的模式时,您将结束 有几个JSON文件,每个版本一个。一定要承诺 每个生成的文件都交给源代码控制。下次你增加的时候 您的版本号再次,房间将能够使用JSON文件 测试。 Florina Muntenescu(来源)
build.gradle
android {
// [...]
defaultConfig {
// [...]
javaCompileOptions {
annotationProcessorOptions {
arguments = ["room.schemaLocation": "$projectDir/schemas".toString()]
}
}
}
// add the schema location to the source sets
// used by Room, to test migrations
sourceSets {
androidTest.assets.srcDirs += files("$projectDir/schemas".toString())
}
// [...]
}
根据文档:
您可以设置注释处理器参数(Room . schemalocation)来告诉Room将模式导出到一个文件夹中。即使它不是强制性的,在你的代码库中有版本历史记录是一个很好的实践,你应该将该文件提交到你的版本控制系统中(但不要随应用一起发布!)
因此,如果您不需要检查模式,并且希望消除警告,只需向RoomDatabase添加exportSchema = false,如下所示。
@Database(entities = { YourEntity.class }, version = 1, exportSchema = false)
public abstract class AppDatabase extends RoomDatabase {
//...
}
如果你遵循下面的@mikejonesguy回答,你将遵循文档中提到的良好实践:)。 基本上你会得到一个.json文件。/应用程序/模式/文件夹。 它看起来是这样的:
{
"formatVersion": 1,
"database": {
"version": 1,
"identityHash": "53db508c5248423325bd5393a1c88c03",
"entities": [
{
"tableName": "sms_table",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`id` INTEGER PRIMARY KEY AUTOINCREMENT, `message` TEXT, `date` INTEGER, `client_id` INTEGER)",
"fields": [
{
"fieldPath": "id",
"columnName": "id",
"affinity": "INTEGER"
},
{
"fieldPath": "message",
"columnName": "message",
"affinity": "TEXT"
},
{
"fieldPath": "date",
"columnName": "date",
"affinity": "INTEGER"
},
{
"fieldPath": "clientId",
"columnName": "client_id",
"affinity": "INTEGER"
}
],
"primaryKey": {
"columnNames": [
"id"
],
"autoGenerate": true
},
"indices": [],
"foreignKeys": []
}
],
"setupQueries": [
"CREATE TABLE IF NOT EXISTS room_master_table (id INTEGER PRIMARY KEY,identity_hash TEXT)",
"INSERT OR REPLACE INTO room_master_table (id,identity_hash) VALUES(42, \"53db508c5248423325bd5393a1c88c03\")"
]
}
}
如果我的理解是正确的,您将在每次数据库版本更新时获得这样一个文件,这样您就可以轻松地跟踪数据库的历史。